Use remote vm for better error messages
This commit is contained in:
parent
b5a69db0b3
commit
8601193b51
|
@ -36,6 +36,7 @@ export * as filesystem from "./filesystem";
|
||||||
export {default as https} from "./https";
|
export {default as https} from "./https";
|
||||||
export * as electron from "./electron";
|
export * as electron from "./electron";
|
||||||
export * as crypto from "./crypto";
|
export * as crypto from "./crypto";
|
||||||
|
export * as vm from "./vm";
|
||||||
|
|
||||||
// We can expose that without any issues.
|
// We can expose that without any issues.
|
||||||
export * as path from "path";
|
export * as path from "path";
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
import vm from "vm";
|
||||||
|
|
||||||
|
export function compileFunction(code, params = [], options = {}) {
|
||||||
|
try {
|
||||||
|
return vm.compileFunction(code, params, options);
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
return {
|
||||||
|
name: error.name,
|
||||||
|
message: error.message,
|
||||||
|
stack: error.stack
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
|
@ -117,7 +117,7 @@ export default new class PluginManager extends AddonManager {
|
||||||
try {
|
try {
|
||||||
const module = {filename, exports: {}};
|
const module = {filename, exports: {}};
|
||||||
// Test if the code is valid gracefully
|
// Test if the code is valid gracefully
|
||||||
vm.compileFunction(addon.fileContent, ["require", "module", "exports", "__filename", "__dirname"]);
|
vm.compileFunction(addon.fileContent, ["require", "module", "exports", "__filename", "__dirname"], {filename: path.basename(filename)});
|
||||||
addon.fileContent += normalizeExports(addon.exports || addon.name);
|
addon.fileContent += normalizeExports(addon.exports || addon.name);
|
||||||
addon.fileContent += `\n//# sourceURL=betterdiscord://plugins/${addon.filename}`;
|
addon.fileContent += `\n//# sourceURL=betterdiscord://plugins/${addon.filename}`;
|
||||||
const wrappedPlugin = new Function(["require", "module", "exports", "__filename", "__dirname"], addon.fileContent); // eslint-disable-line no-new-func
|
const wrappedPlugin = new Function(["require", "module", "exports", "__filename", "__dirname"], addon.fileContent); // eslint-disable-line no-new-func
|
||||||
|
|
|
@ -1,3 +1,9 @@
|
||||||
export const compileFunction = function (code, params = [], filename = "") {
|
import Remote from "./remote";
|
||||||
return window.eval(`(${params.join(", ")}) => {${code}//# sourceURL=${filename.replace(/\\/g, "\\")}\n}`); // eslint-disable-line no-eval
|
|
||||||
|
export const compileFunction = function(code, params = [], options = {}) {
|
||||||
|
const returned = Remote.vm.compileFunction(code, params, options);
|
||||||
|
if (typeof(returned) === "function") return returned;
|
||||||
|
const syntaxError = new SyntaxError(returned.message);
|
||||||
|
syntaxError.stack = returned.stack;
|
||||||
|
throw syntaxError;
|
||||||
};
|
};
|
Loading…
Reference in New Issue