Macro documentation

Description
All macros should be properly documented in the same way Gui Commands are documented. They should have an individual wiki page, and should be listed in one of the categories in Macros recipes.

The Macros recipes page has a good selection of macros created by experienced users, and many of them can be directly installed from the Addon Manager.

See GuiCommand model and macro pages like Macro Loft and Macro Site From Contours to see how macros should be documented. At least two sections should be included, a section with general usage information, and a  section to hold the actual macro code. Other sections may be included as needed to explain with more detail the usage of the macro.

If a macro provides a well defined functionality, and is well documented, it could be included eventually as part of an existing workbench or a new one.

New macro page
Create a new page for the macro starting with the word, for example,. The link can be used without underscores as, which results in Macro Excellent Modification; the spaces are automatically converted to underscores.

In the new page you should use Template:Macro at the top, with a minimum of information:

You can add a custom icon if it doesn't have the same name as the macro; you can also add other fields of information.

When translating the page, use a localized template. You need to specify the name with the two letter language code, and you need to indicate the icon explicitly.


 * Use Special:Upload to upload the custom icon in SVG or PNG formats. It should have the same name as the macro.
 * Otherwise it will default to  [[Image:Text-x-python.png|32px]].

Adding the macro documentation

 * Just like a Gui Command, explain what the macro does, its inputs, outputs, options, and limitations, if any.
 * Add one or more images to clarify its usage.
 * If the macro performs a complex task, consider adding an animated GIF that shows its capabilities. The GIF image should have a maximum size of 500 x 500 pixels; if the GIF is bigger, the animation may not work. Do not resize the GIF as the wiki will not play resized GIFs.
 * Mention related macros and workbenches that complement the function of this macro.
 * Mention the version of FreeCAD used to create the macro. This information can be gathered from.


 * When this information is pasted, it looks like this

Consider adding this information in a comment block inside the code of the macro.

Adding the macro code
Inside the section, use Template:Code to place the code of the macro in the page. This will create a block of text that uses monospace font, which will preserve the whitespace that is essential for Python.

Add header information before your actual code.

This information can be used by the addons_installer.FCMacro macro, or by the Plugin Loader program, to install the macro and check for new versions. Starting with FreeCAD 0.17, this information is also used by the Addon Manager, which downloads the macro from the FreeCAD-macros repository.

Adding macro code outside of the wiki
If your macro is too big that it exceeds 64 KB, it won't be able to be hosted on the wiki. In this case, use Template:Codeextralink with a link to the raw web address of the code.

For example:

It will be displayed as:

This template must be placed at the beginning of the macro page, in the section. It must be the first block of code in the page so that the Addon Manager can automatically detect it and import it. See Macro CirclePlus for an example of the usage.

Adding the new macro to the list
Use Template:MacroLink to include a line in the appropriate category in Macros recipes; create a new category if needed.


 * The first argument is the name of the macro page in the wiki.
 * The second argument is the displayed text, which may be different from the page name.
 * What follows is a short description of the macro.


 * The optional parameter  may be given to specify the image file that will be used at the start of the line. The icon should be an SVG or a PNG file, and should have the same name as your macro. If this parameter is not given it will use the default icon for a Python script, [[Image:Text-x-python.png|24px]].