summaryrefslogtreecommitdiffstats
path: root/js/src
diff options
context:
space:
mode:
authorMoonchild <moonchild@palemoon.org>2020-07-03 14:15:55 +0000
committerMoonchild <moonchild@palemoon.org>2020-07-10 18:29:52 +0000
commit7bf3e4c46475a7aa936d702eb38d65d9126008f2 (patch)
treeb43009d64e8470586980538d43b062122a13bf68 /js/src
parent57523a0debf898dc9583bfbc6c12f3e024f40b23 (diff)
downloadUXP-7bf3e4c46475a7aa936d702eb38d65d9126008f2.tar
UXP-7bf3e4c46475a7aa936d702eb38d65d9126008f2.tar.gz
UXP-7bf3e4c46475a7aa936d702eb38d65d9126008f2.tar.lz
UXP-7bf3e4c46475a7aa936d702eb38d65d9126008f2.tar.xz
UXP-7bf3e4c46475a7aa936d702eb38d65d9126008f2.zip
Issue #618 - Add APIs to query module record errors
Ref: BZ 1388728
Diffstat (limited to 'js/src')
-rw-r--r--js/src/jsapi.cpp14
-rw-r--r--js/src/jsapi.h6
2 files changed, 20 insertions, 0 deletions
diff --git a/js/src/jsapi.cpp b/js/src/jsapi.cpp
index 53ea4ebc6..f8c34885b 100644
--- a/js/src/jsapi.cpp
+++ b/js/src/jsapi.cpp
@@ -4739,6 +4739,20 @@ JS::GetModuleScript(JSContext* cx, JS::HandleObject moduleArg)
return moduleArg->as<ModuleObject>().script();
}
+JS_PUBLIC_API(bool)
+JS::IsModuleErrored(JSObject* moduleArg)
+{
+ AssertHeapIsIdle();
+ return moduleArg->as<ModuleObject>().status() == MODULE_STATUS_ERRORED;
+}
+
+JS_PUBLIC_API(JS::Value)
+JS::GetModuleError(JSObject* moduleArg)
+{
+ AssertHeapIsIdle();
+ return moduleArg->as<ModuleObject>().error();
+}
+
JS_PUBLIC_API(JSObject*)
JS_New(JSContext* cx, HandleObject ctor, const JS::HandleValueArray& inputArgs)
{
diff --git a/js/src/jsapi.h b/js/src/jsapi.h
index 9138a4a92..5e0259587 100644
--- a/js/src/jsapi.h
+++ b/js/src/jsapi.h
@@ -4396,6 +4396,12 @@ GetRequestedModules(JSContext* cx, JS::HandleObject moduleRecord);
extern JS_PUBLIC_API(JSScript*)
GetModuleScript(JSContext* cx, JS::HandleObject moduleRecord);
+extern JS_PUBLIC_API(bool)
+IsModuleErrored(JSObject* moduleRecord);
+
+extern JS_PUBLIC_API(JS::Value)
+GetModuleError(JSObject* moduleRecord);
+
} /* namespace JS */
extern JS_PUBLIC_API(bool)