Come vengono caricati i moduli JavaScript precompilati in Ringojs?
-
14-12-2019 - |
Domanda
Okay, quindi ho creato un file JavaScript chiamato test.js
che contiene il seguente codice:
print("It works!");
.
L'ho compilato usando il compilatore JavaScript Rhino senza errori.Quindi ho creato un nuovo file chiamato foo.js
che contiene questo codice:
var test = require("./test.class");
.
Ora quando eseguo foo.js
in Ringo in Getta la seguente eccezione e traccia di pila:
Uncaught exception:
java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:616)
at org.ringojs.tools.launcher.Main.run(Main.java:66)
at org.ringojs.tools.launcher.Main.main(Main.java:45)
Caused by: java.lang.NoClassDefFoundError: /home/aaditmshah/test (wrong name: test)
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:634)
at org.mozilla.javascript.DefiningClassLoader.defineClass(DefiningClassLoader.java:62)
at org.ringojs.engine.ClassModuleLoader.load(ModuleLoader.java:126)
at org.ringojs.engine.ReloadableScript.compileScript(ReloadableScript.java:153)
at org.ringojs.engine.ReloadableScript.getScript(ReloadableScript.java:118)
at org.ringojs.engine.ReloadableScript.exec(ReloadableScript.java:227)
at org.ringojs.engine.ReloadableScript.load(ReloadableScript.java:215)
at org.ringojs.engine.RingoWorker.loadModuleInternal(RingoWorker.java:283)
at org.ringojs.engine.Require.call(Require.java:81)
at org.mozilla.javascript.optimizer.OptRuntime.callName(OptRuntime.java:97)
at org.mozilla.javascript.gen._home_aaditmshah_foo_js_3._c_script_0(/home/aaditmshah/foo.js:1)
at org.mozilla.javascript.gen._home_aaditmshah_foo_js_3.call(/home/aaditmshah/foo.js)
at org.mozilla.javascript.ContextFactory.doTopCall(ContextFactory.java:426)
at org.mozilla.javascript.ScriptRuntime.doTopCall(ScriptRuntime.java:3178)
at org.mozilla.javascript.gen._home_aaditmshah_foo_js_3.call(/home/aaditmshah/foo.js)
at org.mozilla.javascript.gen._home_aaditmshah_foo_js_3.exec(/home/aaditmshah/foo.js)
at org.ringojs.engine.ReloadableScript.evaluate(ReloadableScript.java:186)
at org.ringojs.engine.RingoWorker.evaluateScript(RingoWorker.java:315)
at org.ringojs.engine.RhinoEngine.runScript(RhinoEngine.java:186)
at org.ringojs.tools.RingoRunner.run(RingoRunner.java:152)
... 6 more
enter code here
.
Non so dove sto andando male.Ho le ultime versioni di Ringo e Rhino 1.7R3.Ho aggiunto la directory corrente al mio classpath preparando la seguente riga a foo.js
:
addToClasspath(module.resolve("."));
.
Tuttavia, genera ancora lo stesso errore.Non ho idea di come fare questo lavoro.Qualsiasi aiuto sarà molto apprezzato.
Soluzione
OK, ho guardato la traccia dello stack un po 'più vicina e ho reso conto che si trova correttamente il file di classe, tenta solo di caricarlo dal pacchetto errato (home.aaditmshah.test
anziché solo test
).Se il file di classe è nel percorso del modulo, è possibile caricarlo correttamente con il nome del modulo (classe).Per impostazione predefinita, la directory corrente non è nel percorso del modulo, quindi dovrai aggiungerlo prima:
require.paths.push('.')
var test = require("test.class");
.