Skip to content Apex code analyser using the Tooling API and Canvas
JavaScript Java CSS
Branch: master
Clone or download
Latest commit 5f80d91 Oct 6, 2014
Type Name Latest commit message Commit time
Failed to load latest commit information.
src Initial commit Feb 2, 2013
LICENSE Create LICENSE Oct 6, 2014
Procfile Initial commit Feb 2, 2013
README.markdown Update README.markdown Feb 2, 2013
pom.xml Initial commit Feb 2, 2013


Apex Code Analysis Tool using Tooling API and Canvas

This tool utilises the new Spring'13 Tooling API and the Canvas technology to fill a gap in the Apex developers toolkit. That being the ability to perform analysis on the Apex code they are developing. This initial prototype shows how the SymbolTable information can be used to list unused Apex methods. More information and background to this can be found at my blog here. For more information on how to run and deploy this sample, please refer to the Canvas Developers Guide.


For more information see my blog entry Spring'13 Clean Apex Code with the Tooling API.

Generating the Tooling API Client Proxies (with JAX-WS) and Maven

In order to consume the Tooling API in Java I chose the SOAP protocol, since Java is a type safe language and interacting with the data types and operations of the API is much easier using Java's native features. These are the steps I took to accomplish this in Maven, you may want to use a different tool or approach.

  • Downloaded the Tooling API WSDL (from the Setup > Develop > API page)
  • Edited my pom.xml to plugin the JAX-WS xsimport tool and configure it.
  • As Salesforce schema types use the minOccurs="0" and nillable="true" convention, this resulted in less desirable (but techncially accurate) generated code to support this convention. As such I created a /bindings/bindings.xml file to customise the generated code to produce more typical get/set methods.
  • The WSDL available (pre-spring'13 launch) did appear to have some issues / missing elements.
    • I needed to add the SessionHeader soap header declaration to some of the operations I wanted (others had it).
    • I also needed to remove 'id' element declarations that appeared to be duplicates of what would be inherited from the SObject base schema type in the WSDL. This caused the generated code to stop generating get/set methods and fall back to name/value pair convention.

I am not sure if the Salesforce WSC compiler tool would have had these issues, thats something I want to look into. However for now the JAX-WS tool does work great inside a Maven build project once the above is sorted.

You can’t perform that action at this time.