You are here: Rhino project page > JavaScript Compiler
JavaScript Compiler
The JavaScript compiler translates JavaScript source into Java class files. The resulting Java class files can then be loaded and executed at another time, providing a convenient method for transfering JavaScript, and for avoiding translation cost.
Note that the top-level functions available to the shell (such as
print
) are not available to compiled scripts
when they are run outside the shell.
Invoking the Compiler
java org.mozilla.javascript.tools.jsc.Main [options] file1.js file2.js...]
where options are:
- -extends java-class-name
- Specifies that a java class extending the Java class java-class-name should be generated from the incoming JavaScript source file. Each global function in the source file is made a method of the generated class, overriding any methods in the base class by the same name.
- -implements java-intf-name
- Specifies that a java class implementing the Java interface
java-intf-name
should be generated from the incoming JavaScript source file. Each global function in the source file is made a method of the generated class, implementing any methods in the interface by the same name. - -debug
- -g
- Specifies that debug information should be generated. May not be combined
with optimization at an
optLevel
greater than zero. - -nosource
- Does not save the source in the class file. Functions and scripts compiled this way cannot be decompiled. This option can be used to avoid distributing source or simply to save space in the resulting class file.
- -o outputFile
- Writes the class file to the given file (which should end in
.class
). The string outputFile must be a writable filename. - -opt optLevel
- -O optLevel
- Optimizes at level optLevel, which must be an integer between
-1 and 9. See Optimization for more details. If
optLevel is greater than zero,
-debug
may not be specified. - -package packageName
- Specifies the package to generate the class into. The string packageName must be composed of valid identifier characters optionally separated by periods.
- -version versionNumber
- Specifies the language version to compile with. The string
versionNumber
must be one of 100, 110, 120, 130, 140, 150, or 160. See JavaScript Language Versions for more information on language versions.
Examples
$ cat test.js java.lang.System.out.println("hi, mom!"); $ java org.mozilla.javascript.tools.jsc.Main test.js $ ls *.class test.class $ java test hi, mom! $ java org.mozilla.javascript.tools.jsc.Main -extends java.applet.Applet -implements java.lang.Runnable NervousText.js