This closes #113 issue on Github.
return NJS_ERROR;
}
+ if (vm->modules != NULL && vm->options.accumulative) {
+ njs_module_reset(vm);
+ }
+
parser = nxt_mp_zalloc(vm->mem_pool, sizeof(njs_parser_t));
if (nxt_slow_path(parser == NULL)) {
return NJS_ERROR;
} else {
ret = njs_vm_invoke(vm, &module->function, NULL, 0, module->index);
if (ret == NXT_ERROR) {
- goto done;
+ return ret;
}
}
item++;
}
- ret = NXT_OK;
+ return NXT_OK;
+}
+
-done:
+void
+njs_module_reset(njs_vm_t *vm)
+{
+ nxt_uint_t i;
+ njs_module_t **item, *module;
+ nxt_lvlhsh_query_t lhq;
- if (vm->options.accumulative) {
- nxt_array_reset(vm->modules);
+ if (vm->modules == NULL) {
+ return;
+ }
+
+ item = vm->modules->start;
+
+ for (i = 0; i < vm->modules->items; i++) {
+ module = *item;
+
+ if (!module->function.native) {
+ lhq.key = module->name;
+ lhq.key_hash = nxt_djb_hash(lhq.key.start, lhq.key.length);
+ lhq.proto = &njs_modules_hash_proto;
+ lhq.pool = vm->mem_pool;
+
+ (void) nxt_lvlhsh_delete(&vm->modules_hash, &lhq);
+ }
+
+ item++;
}
- return ret;
+ nxt_array_reset(vm->modules);
}
nxt_int_t njs_module_load(njs_vm_t *vm);
+void njs_module_reset(njs_vm_t *vm);
nxt_int_t njs_parser_module(njs_vm_t *vm, njs_parser_t *parser);
njs_ret_t njs_module_require(njs_vm_t *vm, njs_value_t *args,
nxt_uint_t nargs, njs_index_t unused);
--- /dev/null
+export default {type:typeof undeclared, undeclared};
# modules
njs_test {
- {"import lib1 from 'lib1.js'\r\n"
- "undefined\r\n"}
- {"import lib2 from 'lib1.js'\r\n"
+ {"import lib1 from 'lib1.js'; import lib2 from 'lib1.js'\r\n"
"undefined\r\n"}
{"lib2.inc()\r\n"
"undefined\r\n"}
"Identifier \"default\" has already been declared in export.js:5\r\n"}
{"import m from 'export_non_default.js'\r\n"
"Non-default export is not supported in export_non_default.js:3\r\n"}
+ {"import ref from 'ref_exception.js'\r\n"
+ "ReferenceError: \"undeclared\" is not defined in ref_exception.js:1"}
+ {"ref\r\n"
+ "ReferenceError: \"ref\" is not defined in shell:1\r\n"}
+ {"var ref\r\n"
+ "undefined\r\n"}
+ {"import ref from 'ref_exception.js'\r\n"
+ "ReferenceError: \"undeclared\" is not defined in ref_exception.js:1"}
{"import m from 'loading_exception.js'\r\n"
"Error: loading exception\r\n at module \\(loading_exception.js:1\\)"}
{"import lib3 from 'lib1.js'\r\n"