Std AddonMgr

Description
The Std AddonMgr command opens the Addon manager. With the Addon manager you can install and manage external workbenches, macros, and preference packs provided by the FreeCAD community. By default the available addons are taken from two repositories, FreeCAD-addons and from the Macros recipes page. If GitPython and git are installed on your system, additional macros will be loaded from FreeCAD-macros. Custom repositories can be added in the Addon manager preferences.

Due to changes to the GitHub platform in the year 2020 the Addon manager no longer works if you use FreeCAD version 0.17 or earlier. You need to upgrade to version 0.18.5 or later. Alternatively you can install addons manually, see Notes below.

Usage

 * 1) Select the  option from the menu.
 * 2) If you are using the Addon manager for the first time, a dialog box will open warning you that the addons in the Addon manager are not officially part of FreeCAD. It also presents several options related to the Addon manager's data usage. Adjust those options to your liking and press the  button to confirm and continue.
 * 3) The Addon manager dialog box opens. For more information see Options.
 * 4) If you have installed or updated a workbench a new dialog box will open informing you that you have to restart FreeCAD for the changes to take effect.

Options



 * 1) The Addon manager provides two view layouts: "Condensed" and "Expanded". In "Condensed" view, each addon takes a single line, and its description is truncated to fit the available space. "Expanded" shows additional details, including more of the description text as well as maintainer information, more installation details, etc.
 * 2) Three different types of addons are supported: workbenches, macros, and preference packs. You can choose to show just one type, or all of them in a single list.
 * 3) The list can be limited to show just installed packages, just packages with available updates, or just packages that are not yet installed.
 * 4) The list can be filtered, searching for a keyword in the title, description, and tags (description and tags must be specified by the addon developer in their addon's metadata). The filter can even be a regular expression, for fine-grained control of the exact search term.
 * 5) The expanded view shows available version information, description, maintainer information, and installation version information, for packages that provide a package metadata file (or for macros with embedded metadata).
 * 6) Addon data is cached locally, with a variable cache update frequency set in the user preferences.
 * 7) At any time you can choose to manually update your local cache to see the latest updates available for each addon.
 * 8) Update checks may be set up to be automatic, or done manually via a button click (configured in user preferences). If GitPython and git are installed on your system then update information is fetched using git. If not, then update information is obtained from any present metadata file.

Clicking on an addon in this view brings up the addon's Details page:



The details page shows buttons allowing installing, uninstalling, updating, and temporarily disabling an addon. For installed addons it lists the currently installed version and the installation date, and whether that is the most recent version available. Below is an embedded web browser window showing the addon's README page (for workbenches and preference packs), or Wiki page (for macros).

Preferences
The preferences for the Addon manager can be found in the Preferences Editor.

Information for addon developers
See Addon.

Addon Manager API
Some features of the Addon Manager are designed for access via FreeCAD's Python API : in particular an Addon can be installed, updated, and removed via the Python interface. Most uses of this API require you to create an object with at least three attributes: "name", "branch", and "url". For example: class MyAddonClass: def __init__(self): self.name = "TestAddon" self.url = "https://github.com/Me/MyTestAddon" self.branch = "main" my_addon = MyAddonClass Your object is now ready for use with the Addon Manager API.

Commandline (non-GUI) use
If your code needs to install or update an Addon synchronously (e.g. without a GUI) the code can be very simple: from addonmanager_installer import AddonInstaller installer = AddonInstaller(my_addon) installer.run Note that this code blocks until complete, so you shouldn't run it on the main GUI thread. To the Addon Manager, "install" and "update" are the same call: if this Addon is already installed, and git is available, it will be updated via "git pull". If it is not installed, or was installed via a non-git installation method, it is downloaded from scratch (using git if available).

To uninstall, use from addonmanager_uninstaller import AddonUninstaller uninstaller = AddonUninstaller(my_addon) uninstaller.run

GUI Use
If you plan on your code running in a GUI, or supporting running in the full version of FreeCAD, it's best to run your installation in a separate non-GUI thread, so the GUI remains responsive. To do this, first check to see if the GUI is running, and if it is, spawn a (don't try to spawn a  if the GUI is not up: they require an active event loop to function). from PySide import QtCore from addonmanager_installer import AddonInstaller

worker_thread = QtCore.QThread installer = AddonInstaller(my_addon) installer.moveToThread(self.worker_thread) installer.success.connect(installation_succeeded) installer.failure.connect(installation_failed) installer.finished.connect(worker_thread.quit) worker_thread.started.connect(installer.run) worker_thread.start # Returns immediately Then define the functions and  to be run in each case. For uninstallation you can use the same technique, though it is usually much faster and will not block the GUI for very long, so in general it's safe to use the uninstaller directly, as shown above.