[gjs] importer: Replace load_module_init implementation with import_file
- From: Jasper St. Pierre <jstpierre src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gjs] importer: Replace load_module_init implementation with import_file
- Date: Tue, 1 Oct 2013 22:38:16 +0000 (UTC)
commit fc7e6a536c43e747da20574aa23419e4c710dafe
Author: Jasper St. Pierre <jstpierre mecheye net>
Date: Fri Sep 27 17:08:55 2013 -0400
importer: Replace load_module_init implementation with import_file
gjs/importer.c | 67 ++++---------------------------------------------------
1 files changed, 5 insertions(+), 62 deletions(-)
---
diff --git a/gjs/importer.c b/gjs/importer.c
index 2301513..1e7b78f 100644
--- a/gjs/importer.c
+++ b/gjs/importer.c
@@ -328,11 +328,7 @@ load_module_init(JSContext *context,
JSObject *in_object,
const char *full_path)
{
- char *script;
- gsize script_len;
- jsval script_retval;
JSObject *module_obj;
- GError *error;
JSBool found;
jsid module_init_name;
@@ -350,67 +346,14 @@ load_module_init(JSContext *context,
}
}
- module_obj = JS_NewObject(context, NULL, NULL, NULL);
- if (module_obj == NULL) {
- return JS_FALSE;
- }
-
- /* https://bugzilla.mozilla.org/show_bug.cgi?id=599651 means we
- * can't just pass in the global as the parent */
- JS_SetParent(context, module_obj,
- gjs_get_import_global (context));
-
- /* Define module in importer for future use and to avoid module_obj
- * object to be garbage collected during the evaluation of the script */
- JS_DefinePropertyById(context, in_object,
- module_init_name, OBJECT_TO_JSVAL(module_obj),
- NULL, NULL,
- GJS_MODULE_PROP_FLAGS & ~JSPROP_PERMANENT);
-
- script_len = 0;
- error = NULL;
-
- if (!g_file_get_contents(full_path, &script, &script_len, &error)) {
- if (!g_error_matches(error, G_FILE_ERROR, G_FILE_ERROR_ISDIR) &&
- !g_error_matches(error, G_FILE_ERROR, G_FILE_ERROR_NOTDIR) &&
- !g_error_matches(error, G_FILE_ERROR, G_FILE_ERROR_NOENT))
- gjs_throw_g_error(context, error);
- else
- g_error_free(error);
-
+ if (!import_file (context, "__init__", full_path, &module_obj))
return NULL;
- }
-
- g_assert(script != NULL);
-
- gjs_debug(GJS_DEBUG_IMPORTER, "Importing %s", full_path);
-
- if (!JS_EvaluateScript(context,
- module_obj,
- script,
- script_len,
- full_path,
- 1, /* line number */
- &script_retval)) {
- g_free(script);
-
- /* If JSOPTION_DONT_REPORT_UNCAUGHT is set then the exception
- * would be left set after the evaluate and not go to the error
- * reporter function.
- */
- if (JS_IsExceptionPending(context)) {
- gjs_debug(GJS_DEBUG_IMPORTER,
- "Module " MODULE_INIT_FILENAME " left an exception set");
- gjs_log_and_keep_exception(context);
- } else {
- gjs_throw(context,
- "JS_EvaluateScript() returned FALSE but did not set exception");
- }
+ if (!JS_DefinePropertyById(context, in_object,
+ module_init_name, OBJECT_TO_JSVAL(module_obj),
+ NULL, NULL,
+ GJS_MODULE_PROP_FLAGS & ~JSPROP_PERMANENT))
return NULL;
- }
-
- g_free(script);
return module_obj;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]