|
|
bf4e26 |
diff --git a/configure.ac b/configure.ac
|
|
|
bf4e26 |
index 5c37e481147466fd5a3a0a6b814f20fd2fe6bce8..5cedb4eca980f050fb5855ab577e93100adf8fec 100644
|
|
|
bf4e26 |
--- a/configure.ac
|
|
|
bf4e26 |
+++ b/configure.ac
|
|
|
bf4e26 |
@@ -79,7 +79,7 @@ PKG_CHECK_MODULES(GLIB, [gmodule-2.0 gio-unix-2.0 >= 2.30.0])
|
|
|
bf4e26 |
AC_SUBST(GLIB_CFLAGS)
|
|
|
bf4e26 |
AC_SUBST(GLIB_LIBS)
|
|
|
bf4e26 |
|
|
|
bf4e26 |
-PKG_CHECK_MODULES(LIBJS, [mozjs-52])
|
|
|
bf4e26 |
+PKG_CHECK_MODULES(LIBJS, [mozjs-60])
|
|
|
bf4e26 |
|
|
|
bf4e26 |
AC_SUBST(LIBJS_CFLAGS)
|
|
|
bf4e26 |
AC_SUBST(LIBJS_CXXFLAGS)
|
|
|
bf4e26 |
diff --git a/src/polkitbackend/polkitbackendjsauthority.cpp b/src/polkitbackend/polkitbackendjsauthority.cpp
|
|
|
bf4e26 |
index 76027149d4dfdc54064be48a3aeafeec8326a67b..984a0f0e579d51c09117f4e495b0c3fdc46fe61b 100644
|
|
|
bf4e26 |
--- a/src/polkitbackend/polkitbackendjsauthority.cpp
|
|
|
bf4e26 |
+++ b/src/polkitbackend/polkitbackendjsauthority.cpp
|
|
|
bf4e26 |
@@ -150,18 +150,17 @@ G_DEFINE_TYPE (PolkitBackendJsAuthority, polkit_backend_js_authority, POLKIT_BAC
|
|
|
bf4e26 |
/* ---------------------------------------------------------------------------------------------------- */
|
|
|
bf4e26 |
|
|
|
bf4e26 |
static const struct JSClassOps js_global_class_ops = {
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL
|
|
|
bf4e26 |
+ nullptr, // addProperty
|
|
|
bf4e26 |
+ nullptr, // deleteProperty
|
|
|
bf4e26 |
+ nullptr, // enumerate
|
|
|
bf4e26 |
+ nullptr, // newEnumerate
|
|
|
bf4e26 |
+ nullptr, // resolve
|
|
|
bf4e26 |
+ nullptr, // mayResolve
|
|
|
bf4e26 |
+ nullptr, // finalize
|
|
|
bf4e26 |
+ nullptr, // call
|
|
|
bf4e26 |
+ nullptr, // hasInstance
|
|
|
bf4e26 |
+ nullptr, // construct
|
|
|
bf4e26 |
+ JS_GlobalObjectTraceHook
|
|
|
bf4e26 |
};
|
|
|
bf4e26 |
|
|
|
bf4e26 |
static JSClass js_global_class = {
|
|
|
bf4e26 |
@@ -172,18 +171,17 @@ static JSClass js_global_class = {
|
|
|
bf4e26 |
|
|
|
bf4e26 |
/* ---------------------------------------------------------------------------------------------------- */
|
|
|
bf4e26 |
static const struct JSClassOps js_polkit_class_ops = {
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL,
|
|
|
bf4e26 |
- NULL
|
|
|
bf4e26 |
+ nullptr, // addProperty
|
|
|
bf4e26 |
+ nullptr, // deleteProperty
|
|
|
bf4e26 |
+ nullptr, // enumerate
|
|
|
bf4e26 |
+ nullptr, // newEnumerate
|
|
|
bf4e26 |
+ nullptr, // resolve
|
|
|
bf4e26 |
+ nullptr, // mayResolve
|
|
|
bf4e26 |
+ nullptr, // finalize
|
|
|
bf4e26 |
+ nullptr, // call
|
|
|
bf4e26 |
+ nullptr, // hasInstance
|
|
|
bf4e26 |
+ nullptr, // construct
|
|
|
bf4e26 |
+ nullptr // trace
|
|
|
bf4e26 |
};
|
|
|
bf4e26 |
|
|
|
bf4e26 |
static JSClass js_polkit_class = {
|
|
|
bf4e26 |
@@ -469,19 +467,18 @@ polkit_backend_js_authority_constructed (GObject *object)
|
|
|
bf4e26 |
|
|
|
bf4e26 |
{
|
|
|
bf4e26 |
JS::CompartmentOptions compart_opts;
|
|
|
bf4e26 |
- compart_opts.behaviors().setVersion(JSVERSION_LATEST);
|
|
|
bf4e26 |
+
|
|
|
bf4e26 |
JS::RootedObject global(authority->priv->cx);
|
|
|
bf4e26 |
|
|
|
bf4e26 |
authority->priv->js_global = new JS::Heap<JSObject*> (JS_NewGlobalObject (authority->priv->cx, &js_global_class, NULL, JS::FireOnNewGlobalHook, compart_opts));
|
|
|
bf4e26 |
|
|
|
bf4e26 |
global = authority->priv->js_global->get ();
|
|
|
bf4e26 |
-
|
|
|
bf4e26 |
- if (global == NULL)
|
|
|
bf4e26 |
+ if (!global)
|
|
|
bf4e26 |
goto fail;
|
|
|
bf4e26 |
|
|
|
bf4e26 |
authority->priv->ac = new JSAutoCompartment(authority->priv->cx, global);
|
|
|
bf4e26 |
|
|
|
bf4e26 |
- if (authority->priv->ac == NULL)
|
|
|
bf4e26 |
+ if (!authority->priv->ac)
|
|
|
bf4e26 |
goto fail;
|
|
|
bf4e26 |
|
|
|
bf4e26 |
if (!JS_InitStandardClasses (authority->priv->cx, global))
|
|
|
bf4e26 |
@@ -493,7 +490,7 @@ polkit_backend_js_authority_constructed (GObject *object)
|
|
|
bf4e26 |
|
|
|
bf4e26 |
polkit = authority->priv->js_polkit->get ();
|
|
|
bf4e26 |
|
|
|
bf4e26 |
- if (polkit == NULL)
|
|
|
bf4e26 |
+ if (!polkit)
|
|
|
bf4e26 |
goto fail;
|
|
|
bf4e26 |
|
|
|
bf4e26 |
if (!JS_DefineProperty(authority->priv->cx, global, "polkit", polkit, JSPROP_ENUMERATE))
|
|
|
bf4e26 |
@@ -504,7 +501,7 @@ polkit_backend_js_authority_constructed (GObject *object)
|
|
|
bf4e26 |
js_polkit_functions))
|
|
|
bf4e26 |
goto fail;
|
|
|
bf4e26 |
|
|
|
bf4e26 |
- JS::CompileOptions options(authority->priv->cx, JSVERSION_UNKNOWN);
|
|
|
bf4e26 |
+ JS::CompileOptions options(authority->priv->cx);
|
|
|
bf4e26 |
JS::RootedValue rval(authority->priv->cx);
|
|
|
bf4e26 |
if (!JS::Evaluate (authority->priv->cx,
|
|
|
bf4e26 |
options,
|
|
|
bf4e26 |
@@ -684,7 +681,9 @@ set_property_strv (PolkitBackendJsAuthority *authority,
|
|
|
bf4e26 |
JS::AutoValueVector elems(authority->priv->cx);
|
|
|
bf4e26 |
guint n;
|
|
|
bf4e26 |
|
|
|
bf4e26 |
- elems.resize(value->len);
|
|
|
bf4e26 |
+ if (!elems.resize(value->len))
|
|
|
bf4e26 |
+ g_error ("Unable to resize vector");
|
|
|
bf4e26 |
+
|
|
|
bf4e26 |
for (n = 0; n < value->len; n++)
|
|
|
bf4e26 |
{
|
|
|
bf4e26 |
const char *c_string = (const char *) g_ptr_array_index(value, n);
|
|
|
bf4e26 |
@@ -741,7 +740,7 @@ subject_to_jsval (PolkitBackendJsAuthority *authority,
|
|
|
bf4e26 |
GError **error)
|
|
|
bf4e26 |
{
|
|
|
bf4e26 |
gboolean ret = FALSE;
|
|
|
bf4e26 |
- JS::CompileOptions options(authority->priv->cx, JSVERSION_UNKNOWN);
|
|
|
bf4e26 |
+ JS::CompileOptions options(authority->priv->cx);
|
|
|
bf4e26 |
const char *src;
|
|
|
bf4e26 |
JS::RootedObject obj(authority->priv->cx);
|
|
|
bf4e26 |
pid_t pid;
|
|
|
bf4e26 |
@@ -868,7 +867,7 @@ action_and_details_to_jsval (PolkitBackendJsAuthority *authority,
|
|
|
bf4e26 |
GError **error)
|
|
|
bf4e26 |
{
|
|
|
bf4e26 |
gboolean ret = FALSE;
|
|
|
bf4e26 |
- JS::CompileOptions options(authority->priv->cx, JSVERSION_UNKNOWN);
|
|
|
bf4e26 |
+ JS::CompileOptions options(authority->priv->cx);
|
|
|
bf4e26 |
const char *src;
|
|
|
bf4e26 |
JS::RootedObject obj(authority->priv->cx);
|
|
|
bf4e26 |
gchar **keys;
|
|
|
bf4e26 |
|