|
@@ -257,13 +257,34 @@ V8JS_METHOD(require)
|
|
|
MAKE_STD_ZVAL(normalised_path_zend);
|
|
|
ZVAL_STRING(normalised_path_zend, normalised_module_id, 1);
|
|
|
|
|
|
- zval **params[1] = {&normalised_path_zend};
|
|
|
- if (FAILURE == call_user_function_ex(EG(function_table), NULL, c->module_loader, &module_code, 1, params, 0, NULL TSRMLS_CC)) {
|
|
|
+ int call_result;
|
|
|
+
|
|
|
+ zend_try {
|
|
|
+ {
|
|
|
+ isolate->Exit();
|
|
|
+ v8::Unlocker unlocker(isolate);
|
|
|
+
|
|
|
+ zval **params[1] = {&normalised_path_zend};
|
|
|
+ call_result = call_user_function_ex(EG(function_table), NULL, c->module_loader, &module_code, 1, params, 0, NULL TSRMLS_CC);
|
|
|
+ }
|
|
|
+
|
|
|
+ isolate->Enter();
|
|
|
+
|
|
|
+ if (call_result == FAILURE) {
|
|
|
+ info.GetReturnValue().Set(isolate->ThrowException(V8JS_SYM("Module loader callback failed")));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ zend_catch {
|
|
|
+ v8js_terminate_execution(isolate);
|
|
|
+ V8JSG(fatal_error_abort) = 1;
|
|
|
+ call_result = FAILURE;
|
|
|
+ }
|
|
|
+ zend_end_try();
|
|
|
+
|
|
|
+ if (call_result == FAILURE) {
|
|
|
zval_ptr_dtor(&normalised_path_zend);
|
|
|
efree(normalised_module_id);
|
|
|
efree(normalised_path);
|
|
|
-
|
|
|
- info.GetReturnValue().Set(isolate->ThrowException(V8JS_SYM("Module loader callback failed")));
|
|
|
return;
|
|
|
}
|
|
|
zval_ptr_dtor(&normalised_path_zend);
|