GEPS 005: Enhanced Plugin Interface
Proposed changes for enhancing GRAMPS by updating the plugin interface to:
- be more flexible for future changes
- be more consistent across different types of plugins
- be more abstract
Contents
Motivation
The current plugin architecture is quite nice, and allows many different types of features to be added by users, or by developers. However, it needs to be updated so that it can support all of the different types of current and future plugins.
Details
There are a fixed number of parameters that one can use in defining each plugin type. Some plugins have had to be adapted to handle additional needs (like user interactions via a GUI). There is a middle layer of code that connects the plugin code with the plugin type. In this code there are places where the args get passed around like (item[0], item[1], item[3], item[10]) depending on the plugin type. In addition, some plugins have to go all the way down to the graphics interface (gtk).
Plan:
- Refactor the MenuOptions [under review]
- Add needed MenuOptions to cover all reports
- Update all of the reports to use abstract options ("menu" options) (see discussion here RFC: Improving report options By Brian Matherly - Sep 05, 2007)
- Generalize the report dialogs and remove the need for a report plugin to ever need to define or customize a dialog.
- Rethink each plugin type (report, graph, tool, etc) to be a well-defined API
- Move each plugin registration and handler from its current specific register_TYPE() to generic register(type=TYPE)
Third-Party Plugins
- Use the new two-file plugin format (.py + .gpr.py) together in a tgz file
- Possible directory-based format
- External SVN (http://sourceforge.net/projects/gramps-addons/)
- Plugin manager
- Need local translations
- Would be nice to incorporate an image of addon for browsing, and possible use in tool/report window.
- Need URL for documentation/updates
- Version number support for out-dated plugins
Notes
This section notes some of the details of how the current system works.
- Each plugin calls a register_TYPE() function.
- src/PluginUtils/_PluginMgr.py defines those functions
- src/ViewManager.py defines the callback for the menu, which calls:
- ReportBase.report(dbstate, uistate, dbstate.get_active_person(),lst[0], lst[1], lst[2], lst[3], lst[4], lst[5])
- report() function defined in src/ReportBase/_ReportDialog.py
- which actually runs class from class Report
- src/ReportBase/_ReportDialog.py ReportDialog is the window
- Tool.gui_tool(dbstate, uistate, lst[0], lst[1], lst[2], lst[3], lst[4], dbstate.db.request_rebuild)
- gui_tool() function defined in /src/PluginUtils/_Tool.py
- which actually runs class from class PluginUtils.PluginWindows.ToolManagedWindowBatch
- ReportBase.report(dbstate, uistate, dbstate.get_active_person(),lst[0], lst[1], lst[2], lst[3], lst[4], lst[5])
Discussion
This proposal is discussed here:
- 1310 - Plugin interface is too inflexible (resolved 2011)
- Report vs. ReportDialog question, Douglas S. Blank, Oct 18, 2007
If you have ideas, comments, or questions, please note them here.
As a first step, GEPS 014: Plugin registration and management is being implemented.