Extending Forrest with Plugins
Overview
Forrest provides the core functionality for generating documentation in various output formats from a range of input formats. However, it does not end there. Forrest can be extended through the addition of plugins. This document serves as an introduction to the Forrest plugin mechanism.
What plugins are available?
You can run the command forrest available-plugins to get a list of the known plugins for Forrest.
If you would like to have your own plugin added to this list then contact the developer mailing list.
How is a Plugin Installed?
List of Plugins Needed by the Project
If a site requires one or more plugins then the site designer will have to list them in the project.required.plugins property in the projects forrest.properties file. When Forrest builds the site it will automatically discover the plugins and install them. In otherwords, the user needs do nothing.
For example,
project.required.plugins=org.apache.forrest.plugin.output.pdf, org.apache.forrest.plugin.input.simplifiedDocbook
(note that that is all in one line with no spaces) will cause Forrest to load the plugins called "org.apache.forrest.plugin.output.pdf" and "org.apache.forrest.plugin.input.simplifiedDocbook".
What Version of Plugins will be used ?
In the absence of a version number for the plugin (as is the case in the example above) the most recent version that is applicabe to your release of Forrest will be used. This may result in unexpected behaviour if a new version of the plugin has been released that is incompatible with your current site. To force Forrest into using a specific version of a plugin you should add "-VERSION_NUMBER" to the end of the plugin name. For example, to force forrest to use the version 0.2 of the "output.pdf" plugin you would use org.apache.forrest.plugin.output.pdf-0.2. If you define a version of the plugin that does not exist then it will fall back to using the most recent version available. This feature is useful when developing a new site as you can quickly force a plugin upgrade by deleting all installed plugins (use the command 'ant cleanPlugins'). However, this might result in the installation of an in-development plugin, therefore in a production environment you should always specify a known working version.
Where does Forrest look for Plugins sources?
Overview
This is fairly complex, so here is a simple overview. If you want to know the details you need to read the rest of this section. For most people this overview will be sufficient.
Forrest will try and retrieve a plugin from local source files first, if that fails it will look on a remote distribution server. Once it finds a copy of the plugin it will deploy it to the local Forrest instance and use it from there.
The local directories that will be searched are defined in the project.required.plugins.src property, which is defined in the forrest.properties file. By default this is set to ${forrest.home}/plugins,${forrest.home}/whiteboard/plugins, which means that these two directories will be searched for plugins.
If you have a collection of local plugins the directory in which they are located must be added this property. For example, if your local plugins are in /export/forrest_plugins this property should be something like: project.required.plugins.src=${forrest.home}/plugins,${forrest.home}/whiteboard/plugins,/export/forrest_plugins
You can add this line to your projects forrest.properties file. However, it may be more convenient to add it to a forrest.properties file in your users home directory.
Forrest uses a fall back mecanism to find the plugins to install for a project.
For an unversionned plugin, Forrest tries to get it from :
- different local sources directories (project.required.plugins.src property)
- if not found : the remote site in the forrest version directory
- if not found : the remote site (with no forrest version directory)
For a versionned plugin, Forrest tries to get :
- the versionned plugin from different local sources directories (project.required.plugins.src property)
- if not found : the versionned plugin from the remote site in the forrest version directory
- if not found : the unversionned plugin in different local sources directory (project.required.plugins.src property again)
- if not found : the unversionned plugin from the remote site in the forrest version directory
- if not found : the remote site (with no forrest version directory)
By default, forrest looks into the two following directories to find plugins sources : ${forrest.home}/plugins and ${forrest.home}/whiteboard/plugins. It is possible to add other sources locations by specifying the project.required.plugins.src property in the projects forrest.properties file.
For example,
project.required.plugins.src=${forrest.home}/plugins,${forrest.home}/whiteboard/plugins,/export/forrest_plugins
will add the project specific directory ${project.home}/plugins to the list of directories to search in.
If sources are not found, forrest will try to get them from the Web. Forrest knows the plugins description with plugins descriptors files in which plugins are described as follows :
<plugin name="org.apache.forrest.plugin.output.pdf" type="output" author="Apache Forrest Project" website="http://forrest.apache.org/pluginDocs/plugins_0_80/org.apache.forrest.plugin.output.pdf" url="http://forrest.apache.org/plugins/" version="0.2"> <description> Enable Forrest documents to be output in PDF format. </description> <forrestVersion>0.8</forrestVersion> </plugin>
The url to download the different plugins is indicated in this file.
By default, forrest gets the two following plugins descriptors files : http://forrest.apache.org/plugins/plugins.xml and http://forrest.apache.org/plugins/whiteboard-plugins.xml. It is possible to add other plugins descriptors files by specifying the forrest.plugins.descriptors property in the projects forrest.properties file.
For example,
forrest.plugins.descriptors=http://forrest.apache.org/plugins/plugins.xml,http://forrest.apache.org/plugins/whiteboard-plugins.xml,file:///${project.home}/plugins/plugins.xml
will add the project specific plugins descriptors file file:///${project.home}/plugins/plugins.xml to the list of descriptors.
Editing plugins sources to enhance functionality
If you need to add specific behaviour to an existing plugin, you should first consider whether your changes will be of use to all users of the plugin or not. If they are of general use then you can edit the plugin source files in their original location (i.e. not in the build directory). Once you have completed your changes please prepare a patch and submit it for inclusion in code base.
If your changes are specific to your own use of the plugin you can create a local copy of the plugin for this. However, we strongly advise against this since you will need to manually update your plugin each time a new release of the original is made. In the vast majority of cases local enhancements to a plugin wil be of use to the wider communtiy. Please donate back to the project and help keep it vibrant and useful. See the Further Reading section at the end of this document for links to documents with more information.
Upgrading from a Version of Forrest Without Plugins
The plugin functionality was introduced in version 0.7 of Forrest. At this time some of the functionality previously in Forrest was extracted into a plugin. However, we have not broken backward compatability with earlier versions. In the absence of a project.required.plugins property in the projects forrest.properties file all plugins that contain functionality previously part of Forrest itself will be loaded automatically. Unless you intend to use new functionality provided by a plugin you will not need to make any changes to your project.
If you do require additional plugin functionality, be sure to include all required plugins in the project.required.plugins property in the project's forrest.properties. You can view main/webapp/default-forrest.properties to see the names of plugins that provide previously core functionality.
It is also worth noting that there is a small performance improvement if you remove plugins that are not in use. Therefore, if you do not use one or more of the plugins named in the project.required.plugins property of main/webapp/default-forrest.properties it is recomended that you override this value in your project's forrest.properties file.
Avoiding Plugin Conflicts
Clashes between plugins can occur. For example, the simplified-docbook and full docbook plugins may try and process the same files. In this instance the one that is mounted first will take precedence. Plugins are mounted in the order they appear in the project.required.plugins property, therefore the mounting order and therefore processing precedence is under user control.