A Nashorn implementation of CommonJS Modules/1.1.1.
The initial goal was to pass all CommonJS Modules tests. Since that test suite is not complete with respect to the specification, the missing tests have been added. In addition, parts of the NodeJS module specification have been implemented as well. Furthermore, since we're in Java land, nashorn-require can load modules from inside JAR files.
The following test blocks exists:
commonjs/tests/modules
- the modules tests from the CommonJS repo (as a sub module).tests/commonjs-missing
- tests missing from the CommonJS repo for mandatory features.tests/commonjs-optional
- tests missing from the CommonJS repo for optional features.tests/nodesjs
- tests for NodeJS-specific features.tests/misc
- tests for other things, for example implementation details.
TBD
Build the JS file:
$ npm install .
$ npm run build
Make the nashorn-require.js
file available somewhere for your code to access.
Invoke the following Nashorn code:
var nashornRequirePath = ...; // you're on your own here
var nashornRequireOptions = {}; // see below
var initRequire = load(nashornRequirePath);
initRequire(nashornRequireOptions);
The following options are recognized:
mainFile
(required) - the path to the main module of the application. This is the module for whichrequire.main
doesn't returnundefined
. Its parent directory is used as the initial top-level path (against which to resolve non-relative module paths).extensions
- list of extensions to search when a module is required. Defaults to['.js', '']
, which means that a module required without extension may exist without the extension or with a ".js" extensions. Note that currently specifying this option will overwrite the default list.debug
- set totrue
to enable debug output.classLoader
- an optional class loader that will be used for loading a top-level resource module if it's not found in any of the fixed or user-defined module paths.
- Items added to
require.paths
will be treated as top-level paths. It's possible to add a path to a JAR file.
Use npm test
to run all tests. This will build and lint the code first.
Use npm run lint
to just lint. This will build the code first.
Use npm run build
to build the code. The resulting file will be in the dist
folder.
- Open an issue for something you feel is broken or missing.
- Submit a PR if you want to help fix an issue. Please discuss the issue before doing that.
There are no explicit code guidelines. Make sure the linter is happy and that all code is test-driven! :-)
I have tried to use this require implementation, but I encountered problems with Windows paths. I also found the implementation a bit inflexible, e.g. when it comes to which class loader to use when loading embedded resources. On the plus side, it supports Rhino.
Didn't try this one, but there are no tests and the author's comments towards the end of the README are a bit disheartening.