jree
v1.3.0
Published
Java Runtime Environment Emulation
Downloads
117
Maintainers
Readme
Java Runtime Environment Emulation
This module contains a subset of JRE classes ported to Typescript and serves as runtime for Typescript and Javascript code that need JRE classes. It's a clean room implementation, which means no Java code was used for the implementation. Everything was written from scratch, but the Java API documentation was used as a reference. This allows to release the code under a permissive license (MIT) and to use it in any (including commercial) projects, in opposition to the GPL license of the original JRE.
It is not necessary to have Java installed, as the JREE runs purely in a Javascript interpreter (Node.js or a browser).
Installation and Use
Run
npm i jree
to install the package and then import the java
root namespace from there. With that you can use a supported class via fully qualified names:
import { java } from "jree";
const builder = new java.lang.StringBuilder();
builder.append(123);
You can also import a class directly from full path, but I recommend to stay with fully qualified identifiers. In addition to the JRE classes there's' some support code that might come in handy. See the support readme for more details.
Testing and Examples
Unit Tests
Since the implementation is created solely from the Java API documentation it is important to have a good test coverage to ensure that the classes behave as expected. Therefore a number of JDK tests have been converted to Typescript and run as part of the test suite. The overall test coverage is currently at 43%. The tests are located in the test
folder and can be run using npm run test
or npm run test-coverage
(the latter will also print a coverage report).
Examples
Additionally, there are some examples in the examples
folder. They are modelled after common Java sample programs.
To run an example in a terminal you have to install ts-node
globally:
npm i -g ts-node
Then you can run the example with
ts-node src/runner examples/HelloWorld
The HelloWorld demo is also executable using the NPM script "hello-world":
npm run hello-world
The runner script is a simple wrapper to load the given example (which must contain exactly one class with the typical main()
method, and execute it. It can serve as a starting point for your own programs.
The examples do not use the the jree node package, but work directly with the source code in this project. However, it's easy to see how they would work with the installed module.
Supported Java Classes
The JRE emulation is still work-in-progress and contains a mix of either fully or partially converted Java classes. It's not planned to convert the entire JRE, but over time more and more classes may be added (pull requests welcome!).
See the Types List for the currently implemented classes and read the features description for additional details for usage of the JREE node package.
Environments
The JREE runs in both, Node.js and a browser. Certain classes use Node.js code currently (e.g. file system or path). The System class imports dependencies dynamically and fills its properties either from the browser environment or Node.js. The File class, however, cannot be used in a browser. Solve this by using a bundler like rollup.js
or Webpack
. That should tree-shake this class out or you can provide a shim for the used node package for the bundling process.
Development and Contribution
The development process used in this repo is pretty simple. There are a number NPM scripts for building, linting and testing the classes. Run npm run build
to have typescript create the lib
folder as it is used in the node module. Execute npm run test-coverage
to run all unit tests and print some coverage info.
Adding new classes to this repository is described in more detail in How To Add.