| 
 | BEA Systems, Inc. | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
java.lang.Object | +--weblogic.apache.xml.utils.synthetic.JavaUtils
This class supports invoking Java compilation from within a Java program. Recent versions of the Java environment have provided such an API (in tools.jar). But that isn't available on all platforms, and a fallback to the command line may be needed (though this too may not always be available, eg. for security reasons).
There's an additional complication in some environments -- such as Microsoft's VJ++ -- where the classpath as seen in the System Properties may not be the one the user expects. The code here is parameterized to try to deal with that.
This class is based on an implementation from the Apache XML Project. In future releases the XML parser, XSLT processor, and associated classes will likely be updated to be based on a later version of the Apache implementations. Since Apache does not guarantee backwards compatibility between versions of their software, we cannot guarantee backwards compatibility of any of the classes contained in the weblogic.apache package or sub-packages.
| Constructor Summary | |
| JavaUtils() | |
| Method Summary | |
| static boolean | JDKcompile(java.lang.String fileName,
           java.lang.String classPath)Try to compile a .java file on disk. | 
| static void | setDebug(boolean newDebug)Control whether compilation occurs with the -g option (debugging information included in generated classfile). | 
| Methods inherited from class java.lang.Object | 
| clone, 
equals, 
finalize, 
getClass, 
hashCode, 
notify, 
notifyAll, 
toString, 
wait, 
wait, 
wait | 
| Constructor Detail | 
public JavaUtils()
| Method Detail | 
public static void setDebug(boolean newDebug)
TODO: Consider whether debug should be a parameter.
boolean - newDebug True to request debugging data,
 false to request optimized output. (It's uncommon to
 want both or neither!)
public static boolean JDKcompile(java.lang.String fileName,
                                 java.lang.String classPath)
NOTE: This must be _compiled_ with sun.java.tools.* (tools.jar) available. We could change that to use reflection instead, if we accept some overhead... minor compared to the cost of running the compiler!
This has complications on some platforms. For example, under Microsoft Visual Java ++ (at least, as installed on my test system), I found that I had to specify paths to both javac and xerces.jar rather than counting on the shell's path and classpath having been set to reach these. For that reason I've parameterized this method with a few system properties, so you can adapt it to your own system's needs without modifying the code:
String - fileName Which .java file to compile. Note that this may
 be relative to the "current directory".String - classPath Additional places to look for classes that
 this .java file depends upon. Becomes the javac command's
 -classpath parameter value.| 
 | Documentation is available at http://download.oracle.com/docs/cd/E13222_01/wls/docs61 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||