This contain tools to generate api reports for eclipse plugins, from Ant or Maven. It relies on PDE API Tools This effort is done on the context of JBoss Tools and Eclipse Common Build Infrastructure. You might want to read the following bug reports: for JBoss Tools and for Eclipse.
These tools are divided in several parts:
- org.eclipse.pde.apitools.ant contains extracted Ant tasks related to apitools for from org.eclipse.pde.apitools/src-ant. The tasks are essentially (I think?) unchanged. All other work is original or possibly broken out of those classes into utility classes. Many other classes have been brought in from other eclipse plugins (such as IMemento and XMLMemento) to help clean up the xml handling and report generation.
- binaries folder contains a jar to use if you want to use these Ant tasks
- antSetup folder contains sample Ant build.xml files to consume the tasks
- maven-plugins folder contains a maven plugin, that can be used to run the API analysis with Maven.
Add the following repositories to your pom:
<repositories>
<repository>
<id>jbosstools-experiments</id>
<url>https://repository.jboss.org/nexus/content/repositories/jbosstools-experiments/</url>
</repository>
<repository>
<id>jbosstools-experiments-snapshots</id>
<url>https://repository.jboss.org/nexus/content/repositories/jbosstools-experiments-snapshots/</url>
</repository>
</repositories>
Those repositories contain:
- Eclipse dependencies (PDE, Resources...) as Maven artifacts
- org.eclipse.pde.apitooling.ant bundles available as a Maven artifact
- The Maven plugin that uses tasks from org.eclipse.pde.apitooling.ant
Just add this to your pom.xml:
<plugin>
<groupId>org.eclipse.cbi</groupId>
<artifactId>apitools-plugin</artifactId>
<version>0.0.1-SNAPSHOT</version>
<executions>
<execution>
<id>api-reports</id>
<goals>
<goal>generate-reports</goal>
</goals>
<phase>verify</phase>
<configuration>
<baseline>/home/mistria/jbdevstudio/studio/plugins</baseline>
</configuration>
</execution>
</executions>
</plugin>
Then run mvn verify
or maven reports
depending on the chosen phase, and see your reports in target/reports/api
API Tools can also generate an API description file for your bundle (based on @since annotions and so on), that can be used after in your reports. You can enable generation of such file on any eclipse-plugin
<plugin>
<groupId>org.eclipse.cbi</groupId>
<artifactId>apitools-plugin</artifactId>
<version>0.0.1-SNAPSHOT</version>
<executions>
<execution>
<id>api-reports</id>
<goals>
<goal>generate-description</goal>
</goals>
<phase>compile</phase>
</execution>
</executions>
</plugin>
- Clone the repository
- modify antSetup/build.xml
- Modify eclipse.install.dir to point to a base installation of eclipse, no custom plugins necessary
- Modify baseline to point to a directory full of eclipse plugins, including your custom plugin
- Modify nightly to point to a directory full of eclipse plugins, including a slightly modified version of your custom plugin
- Modify apitooling.root to point to the folder you git cloned, containing this README.md
- Modify includesFile to contain a list of the symbolic names of the bundles you want reports run on. No commas necessary.
- Run the build by typing "ant"
- verify output/20121219/your.plugin/report.xml exists
- cp antSetup/web/analysis.xsl antSetup/output/20121219/your.plugin/ (move xsl into same folder as your report)
- View in web browser, see the ugly progress
Ant tasks were originally part of the git repo found at git://git.eclipse.org/gitroot/pde/eclipse.pde.ui.git, however the ant tasks were bundled in the same plugin when clearly they should be broken out.
The package named net.oxbeef.apitools.core.ant is a clone of the ant tasks in pde.ui, and are essentially (I think?) unchanged. All other work is original or possibly broken out of those classes into utility classes. Many other classes have been brought in from other eclipse plugins (such as IMemento and XMLMemento) to help clean up the xml handling and report generation.
Necessarily, this project is an EPL project.
- Import the project org.eclipse.pde.apitools.ant as an Eclipse plugin project into an Eclipse suitable for plugin development
- Modify sources locally
- To use it with Maven: Install it into your local Maven repository with
mvn install
- To use it with Ant: Right-click the project, export as -> jar, destination file = ${apitooling.root}/binaries/apitooling-ant.jar
- Import the project maven-plugins/apitools-plugin into your workspace
- Make your changes
- Run
mvn install
to install it locally.