org.apache.tools.ant.taskdefs.optional.ejb
Class IPlanetEjbc

java.lang.Object
  extended by org.apache.tools.ant.taskdefs.optional.ejb.IPlanetEjbc

public class IPlanetEjbc
extends java.lang.Object

Compiles EJB stubs and skeletons for the iPlanet Application Server (iAS). The class will read a standard EJB descriptor (as well as an EJB descriptor specific to iPlanet Application Server) to identify one or more EJBs to process. It will search for EJB "source" classes (the remote ; * interface, home interface, and EJB implementation class) and the EJB stubs and skeletons in the specified destination directory. Only if the stubs and skeletons cannot be found or if they're out of date will the iPlanet Application Server ejbc utility be run.

Because this class (and it's assorted inner classes) may be bundled into the iPlanet Application Server distribution at some point (and removed from the Ant distribution), the class has been written to be independent of all Ant-specific classes. It is also for this reason (and to avoid cluttering the Apache Ant source files) that this utility has been packaged into a single source file.

For more information on Ant Tasks for iPlanet Application Server, see the IPlanetDeploymentTool and IPlanetEjbcTask classes.

See Also:
IPlanetDeploymentTool, IPlanetEjbcTask

Nested Class Summary
 class IPlanetEjbc.EjbcException
          This inner class is used to signal any problems during the execution of the ejbc compiler.
 
Constructor Summary
IPlanetEjbc(java.io.File stdDescriptor, java.io.File iasDescriptor, java.io.File destDirectory, java.lang.String classpath, javax.xml.parsers.SAXParser parser)
          Constructs an instance which may be used to process EJB descriptors and generate EJB stubs and skeletons, if needed.
 
Method Summary
protected  void checkConfiguration()
          Verifies that the user selections are valid.
 void execute()
          Compiles the stub and skeletons for the specified EJBs, if they need to be updated.
 java.lang.String[] getCmpDescriptors()
          Returns the list of CMP descriptors referenced in the EJB descriptors.
 java.lang.String getDisplayName()
          Returns the display-name element read from the standard EJB descriptor.
 java.util.Hashtable getEjbFiles()
          Returns a Hashtable which contains a list of EJB class files processed by the ejbc utility (both "source" class files as well as stubs and skeletons).
static void main(java.lang.String[] args)
          Main application method for the iPlanet Application Server ejbc utility.
 void registerDTD(java.lang.String publicID, java.lang.String location)
          Registers the location of a local DTD file or resource.
 void setDebugOutput(boolean debugOutput)
          If true, enables debugging output when ejbc is executed.
 void setIasHomeDir(java.io.File iasHomeDir)
          May be used to specify the "home" directory for this iAS installation.
 void setRetainSource(boolean retainSource)
          If true, the Java source files which are generated by the ejbc process are retained.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

IPlanetEjbc

public IPlanetEjbc(java.io.File stdDescriptor,
                   java.io.File iasDescriptor,
                   java.io.File destDirectory,
                   java.lang.String classpath,
                   javax.xml.parsers.SAXParser parser)
Constructs an instance which may be used to process EJB descriptors and generate EJB stubs and skeletons, if needed.

Parameters:
stdDescriptor - File referencing a standard EJB descriptor.
iasDescriptor - File referencing an iAS-specific EJB descriptor.
destDirectory - File referencing the base directory where both EJB "source" files are found and where stubs and skeletons will be written.
classpath - String representation of the classpath to be used by the iAS ejbc utility.
parser - SAXParser to be used to process both of the EJB descriptors.
To do:
classpathElements is not needed here, its never used (at least IDEA tells me so! :)
Method Detail

setRetainSource

public void setRetainSource(boolean retainSource)
If true, the Java source files which are generated by the ejbc process are retained.

Parameters:
retainSource - A boolean indicating if the Java source files for the stubs and skeletons should be retained.
To do:
This is not documented in the HTML. On purpose?

setDebugOutput

public void setDebugOutput(boolean debugOutput)
If true, enables debugging output when ejbc is executed.

Parameters:
debugOutput - A boolean indicating if debugging output should be generated

registerDTD

public void registerDTD(java.lang.String publicID,
                        java.lang.String location)
Registers the location of a local DTD file or resource. By registering a local DTD, EJB descriptors can be parsed even when the remote servers which contain the "public" DTDs cannot be accessed.

Parameters:
publicID - The public DTD identifier found in an XML document.
location - The file or resource name for the appropriate DTD stored on the local machine.

setIasHomeDir

public void setIasHomeDir(java.io.File iasHomeDir)
May be used to specify the "home" directory for this iAS installation. The directory specified should typically be [install-location]/iplanet/ias6/ias.

Parameters:
iasHomeDir - The home directory for the user's iAS installation.

getEjbFiles

public java.util.Hashtable getEjbFiles()
Returns a Hashtable which contains a list of EJB class files processed by the ejbc utility (both "source" class files as well as stubs and skeletons). The key for the Hashtable is a String representing the path to the class file (relative to the destination directory). The value for the Hashtable is a File object which reference the actual class file.

Returns:
The list of EJB files processed by the ejbc utility.

getDisplayName

public java.lang.String getDisplayName()
Returns the display-name element read from the standard EJB descriptor.

Returns:
The EJB-JAR display name.

getCmpDescriptors

public java.lang.String[] getCmpDescriptors()
Returns the list of CMP descriptors referenced in the EJB descriptors.

Returns:
An array of CMP descriptors.

main

public static void main(java.lang.String[] args)
Main application method for the iPlanet Application Server ejbc utility. If the application is run with no commandline arguments, a usage statement is printed for the user.

Parameters:
args - The commandline arguments passed to the application.

execute

public void execute()
             throws IPlanetEjbc.EjbcException,
                    java.io.IOException,
                    org.xml.sax.SAXException
Compiles the stub and skeletons for the specified EJBs, if they need to be updated.

Throws:
IPlanetEjbc.EjbcException - If the ejbc utility cannot be correctly configured or if one or more of the EJB "source" classes cannot be found in the destination directory
java.io.IOException - If the parser encounters a problem reading the XML file
org.xml.sax.SAXException - If the parser encounters a problem processing the XML descriptor (it may wrap another exception)

checkConfiguration

protected void checkConfiguration()
                           throws IPlanetEjbc.EjbcException
Verifies that the user selections are valid.

Throws:
IPlanetEjbc.EjbcException - If the user selections are invalid.