|   | GoFiler Legato Script Reference 
 Legato v 1.6e Application v 6.3a 
 | 
| Table of Contents | < < Previous | Next >> | 
Chapter Seventeen — Application Integration Functions (continued)
Overview
The MenuAddFunction function will add an item to the application’s registered functions.
Syntax/Parameters
Syntax
int = MenuAddFunction ( string[] parameters );
int = MenuAddFunction ( string code, string menu, string description );
Parameters
parameters
A string array specifying one or more parameters. At a minimum, the array must contain a key named ‘Code’. See remarks for key names. If this mode is used, then no other parameters can be provided.
code
A string containing the specific code for a function (for example, “EDGAR_SUBMIT_TEST”). When a code is employed, the menu item is assumed to belong to the “Extensions” group as part of the File | Extensions | Tool popup menu. This parameter has a maximum of 64 characters. The following parameters must also be present.
menu
A string that specifies the text for the menu item. A highlight key can be added to a letter by preceding it with an ‘&‘ character. This parameter has a maximum of 64 characters.
description
A string containing the description for the item. This parameter has a maximum of 512 characters. This is displayed on the status bar or popup tip.
Return Value
Returns an int containing the function ID or -1 on failure. Use the GetLastError to retrieve a formatted error code. Additional information can be retrieved using the GetLastErrorMessage function.
Remarks
Generally, all extension Function IDs start at a base of 17,002 and continue to 17,500. When the array is employed as an input parameter to the MenuAddFunction function, the following key names can be used:
| Code | Function Code — A required unique code that identifies the function (maximum of 48 characters). | ||
| State | Enabled State — A code that helps the ribbon and menu managers determine the state of the function (maximum of 8 characters). | ||
| Class | Class for Function — This is used to group functions. By default, the value will be ‘Extension’ which will force the function to be automatically added to the tools popup on the file ribbon. | ||
| MenuText | Text to Display in Menu — The text used to display a menu item in a popup or drop down (maximum of 64 characters). The ‘&‘ character can be used to keyboard access and underline display. | ||
| RibbonText | Text to Display on Ribbon — The text used to display as a ribbon item (maximum of 64 characters). | ||
| ShortDescription | Short Description — Short description used for dialogs and certain menus. If omitted, a short description is automatically generated (maximum of 48 characters). | ||
| Description | Long Description — Description used for popup tips and the status bar. The description can contain simple HTML inline such as <B> or <I>. In addition, return characters can be used to format text within a tool tip (maximum of 512 characters). | ||
| InternalBitmap | Bitmap Name — Bitmap name for an internal existing menu function for use to display an associated icon. This cannot point to a script defined bitmap. | ||
| SmallBitmap | Small Bitmap Name — The name of a resource defined within the script or a bitmap file. This bitmap must be 22x22 pixels or less for display as small ribbon or menu items. | ||
| LargeBitmap | Small Bitmap Name — The name of a resource defined within the script or a bitmap file. This bitmap must be 40x35 (width/height) pixels or less for display as large ribbon items. | 
Any additional array items are ignored by the function.
Bitmaps can be added to functions either by referencing an existing internal bitmap or supplying a resource. The can be a local resource defined by the BITMAP resource name or by directly referencing a file. See Section 9.8 Image Resources for additional information on defining image resources. When a script resource or file is loaded, the internal handle for the item is not released until the function is deleted or the application terminates. References to the data are not shared and therefore reloaded on each call to MenuAddFunction. Use the of SmallBitmap or LargeBitmap key name parameters automatically overrides the InternalBitmap parameter.
For display purposes, the upper left pixel (0,0) defines the transparent color for bitmaps.
The “Class” key name has special meaning for certain popup menus:
| DataExtension | Item will appear on the Spreadsheet | Extensions | Tools popup. | ||
| DocumentExtension | Item will appear on the Document | Extensions | Tools popup. | ||
| EditExtension | Item will appear on the Edit | Extensions | Tools popup. | ||
| Extension | Default, item will appear in the File | Extensions | Tools popup. | ||
| FormsViewExtension | Item will appear on the Data | Extensions | Tools popup. | ||
| HTMLFormExtension | Item will appear on the Object | Extensions | Tools popup. | ||
| ParagraphExtension | Item will appear on the Paragraph | Extensions | Tools popup. | ||
| PreferencesExtension | Item will appear on the File | Preferences popup. | ||
| PublishExtension | Item will appear in the File | Send | Publish popup. | ||
| ScriptExtension | Item will appear on the Script | Extensions | Tools popup. | ||
| TableExtension | Item will appear on the Table | Extensions | Tools popup. | ||
| TextExtension | Item will appear on the Text | Extensions | Tools popup. | 
For EDGAR products, additional “Class” keys are available depending on the product:
| EDGARExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| Form13FExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| Form13HExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| Form17AExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| Form17HExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| FormCExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| FormCFPExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| FormDExtension | Item will appear on the Submission | Extensions | Tools popup. and on the Form D ribbon as well. | ||
| FormMAExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| FormNMFPExtension | Item will appear on the Submission | Extensions | Tools popup and on the Form N-MFP ribbon as well.. | ||
| FormNSARFExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| FormSDRFExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| FormTAExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| iXBRLExtension | Item will appear on the iXBRL | Extensions | Tools popup. | ||
| RegulationAExtension | Item will appear on the Submission | Extensions | Tools popup. | ||
| Section16Extension | Item will appear on the Submission | Extensions | Tools popup. | ||
| XBRLExtension | Item will appear on the XBRL Extensions | XBRL Report | Tools popup. | ||
| XDXMarkupExtension | Item will appear on the XDX Markup | Extensions | Tools popup. | ||
| XDXReportExtension | Item will appear on the XDX Report | Extensions | Tools popup. | 
Development Notes
While developing a script and adding menu items, be advised that once a menu item has been added it will persist throughout the development session until the application is closed or the function has been deleted. As such, making changes to code surrounding adding a menu item will appear to not have an impact.
Hooks
It is up to the script to hook the menu code to a specific function. Hooked items will only receive a preprocess notification since the application function dispatch will return an ERROR_FUNCTION_NOT_SUPPORTED error and then exit prior to the post process hook.
Related Functions
Platform Support
Go13, Go16, GoFiler Complete, GoFiler Corporate, GoFiler, GoFiler Lite, GoXBRL
Legato IDE, Legato Basic
Page revised 2025-10-20
| Table of Contents | < < Previous | Next >> | 
© 2012-2025 Novaworks, LLC. All rights reserved worldwide. Unauthorized use, duplication or transmission is prohibited by law. Portions of the software are protected by US Patents 10,095,672, 10,706,221 and 11,210,456. Novaworks, GoFiler™ and Legato™ are registered trademarks of Novaworks, LLC. EDGAR® is a federally registered trademark of the U.S. Securities and Exchange Commission. Novaworks is not affiliated with or approved by the U.S. Securities and Exchange Commission. All other trademarks are the property of their respective owners. Use of the features specified in this language are subject to terms, conditions and limitations of the Software License Agreement.