nodemjs
v0.1.15
Published
Run .mjs files from your command line, with all the tweaks from esmod-pmb.
Downloads
291
Readme
nodemjs
Run .mjs files from your command line, with all the tweaks from esmod-pmb.
Added features:
- Legacy-resolves module names passed with
-r
if they would otherwise yield theERR_MODULE_RESOLUTION_LEGACY
error. - Pre-imports all modules listed in env var
NODEMJS_PRELOAD
and npm settingnodemjs-preload
(see caveats below). Multiple module specs can be separated with spaces. They will be loaded even before the-r
pre-imports.
API
No.
CLI
$ nodemjs test/uc1st.mjs
{ scriptFile: '/mnt/…/nodemjs/test/uc1st.mjs' }
uc1st: [ 'Using dummy input', 'Because there were', 'No CLI args' ]
$ ./test/uc1st.mjs foo bar qux
{ scriptFile: '/mnt/…/nodemjs/test/uc1st.mjs' }
uc1st: [ 'Foo', 'Bar', 'Qux' ]
$ ./test/dynamicMap.mjs rot-13 '' foo bar qux ; echo rv=$?
dynamicMap: import failed for: rot-13
(node:11549) UnhandledPromiseRejectionWarning: Error: Cannot find module 'rot-13'
at […]
(node:11549) [DEP0018] DeprecationWarning: Unhandled promise rejections are
deprecated. In the future, promise rejections […] terminate […] Node.js […]
rv=0
# Fortunately, you can just pre-import the future with -r:
$ nodemjs -r p-fatal test/dynamicMap.mjs rot-13 '' foo bar qux ; echo rv=$?
dynamicMap: import failed for: rot-13
Error: Cannot find module 'rot-13'
at […]
rv=1
# … or via the env var:
$ export NODEMJS_PRELOAD='p-fatal'
$ ./test/dynamicMap.mjs rot-13 '' foo bar qux ; echo rv=$?
dynamicMap: import failed for: rot-13
Error: Cannot find module 'rot-13'
at […]
rv=1
# and once you've installed it…
$ ./test/dynamicMap.mjs rot-13 '' foo bar qux
[ 'sbb', 'one', 'dhk' ]
Setup
npm install --global nodemjs
- Make sure you have a node.js (compatible) binary available as the
nodejs
command. If you use sane package sources, you probably do. If you don't, just make a symlinknodejs
tonode
or whatever it's called on your system. (If you'd like to argue the supremacy of the more genericnode
command name, file an issue, ideally after you've renamed the Node.js foundation to Node foundation.) As of 0.1.7, you can configure your favoritenodejs
replacement via theNODEJS_CMD
env var.
Known issues
Currently no support for setting
process.mainModule
, see the upstream bug ticket.npm config caveat: The
nodemjs-preload
npm setting is currently ignored if its value as a string is literallyundefined
. If you want to pre-load a module with that name and nothing else, put it in twice, with a space between. See also: Duplicate pre-imports.Duplicate pre-imports:
nodemjs
currently does not check whether a module you're trying to pre-import had already been imported before. Usually node's module cache voids all non-first import attempts per module, so this won't matter — unless you use cache-busting modules, in which case you're on your own.REPL: The REPL isn't upgraded to ESM because
esm
currently cannot expose its REPL in a clean and easy way.The
invokedAs
context property fornodemjsCliMain
doesn't work.Needs more/better tests and docs.
License
ISC