dln*_*385 8 adobe extendscript indesign-server adobe-indesign
当我在ExtendScript中捕获错误时,我希望能够记录其堆栈跟踪.似乎错误在ExtendScript中不包含堆栈跟踪,所以我正在尝试将错误添加到堆栈跟踪.
我知道获得堆栈跟踪的唯一方法是$.stack.该字段$.stack包含您访问该字段时的当前堆栈跟踪.
我的第一次尝试是创建自己的包含堆栈的错误对象.该Error对象非常特殊,因为它可以获取创建它的代码的行和文件名.例如,
try {
throw new Error("Houston, we have a problem.");
}
catch (e) {
$.writeln("Line: " + e.line);
$.writeln("File: " + e.fileName);
$.writeln("Message: " + e.message);
}
Run Code Online (Sandbox Code Playgroud)
将打印:
Line: 2
File: ~/Desktop/Source1.jsx
Message: Houston, we have a problem.
Run Code Online (Sandbox Code Playgroud)
我不认为用这种能力创建你自己的对象是可能的.我能得到的最接近的是:
function MyError(msg, file, line) {
this.message = msg;
this.fileName = file;
this.line = line;
this.stack = $.stack;
}
try {
throw new MyError("Houston, we have a problem.", $.fileName, $.line);
}
catch (e) {
$.writeln("Line: " + e.line);
$.writeln("File: " + e.fileName);
$.writeln("Message: " + e.message);
$.writeln("Stack: " + e.stack);
}
Run Code Online (Sandbox Code Playgroud)
哪个印刷品:
Line: 9
File: ~/Desktop/Source2.jsx
Message: Houston, we have a problem.
Stack: [Source3.jsx]
MyError("Houston, we have a p"...,"~/Desktop/Source2.js"...,9)
Run Code Online (Sandbox Code Playgroud)
在这里,我们可以看到我正在创建自己的错误对象并明确地传递它的行和文件名(因为MyError无法自行解决).我还在创建错误时包含了当前堆栈.
这在我调用自己的错误对象时工作正常,但是当其他代码调用常规Error对象或自动生成错误时(例如通过非法访问),它不起作用.我希望能够获得任何错误的堆栈跟踪,无论它是如何生成的.
其他方法可能是修改Error构造函数,修改Error原型或Error完全替换 对象.我无法使用任何这些方法.
另一个想法是在我的代码的每个方法中放置一个catch块,并将当前堆栈添加到错误中(如果它还没有).如果可能的话,我想避免这个选项.
我没有想法.有没有办法让堆栈跟踪错误?
它并不完美,但我找到了部分解决方案。
事实 1:Error.prototype是一个 Error 对象。
Error.prototype.toString事实 2:只要产生错误,就会调用该方法。
事实 3:该字段Error.prototype.toString可以修改。
该方法通常只返回字符串“Error”,因此我们可以将其替换为我们自己的存储堆栈的方法,然后返回字符串“Error”。
Error.prototype.toString = function() {
if (typeof this.stack === "undefined" || this.stack === null) {
this.stack = "placeholder";
// The previous line is needed because the next line may indirectly call this method.
this.stack = $.stack;
}
return "Error";
}
try {
throw new Error("Houston, we have a problem.");
}
catch (e) {
$.writeln("Line: " + e.line);
$.writeln("File: " + e.fileName);
$.writeln("Message: " + e.message);
$.writeln("Stack: " + e.stack);
}
Run Code Online (Sandbox Code Playgroud)
结果:
Line: 11
File: ~/Desktop/Source10.jsx
Message: Houston, we have a problem.
Stack: [Source10.jsx]
toString()
Run Code Online (Sandbox Code Playgroud)
有用!唯一的问题是自动错误。
Line: 11
File: ~/Desktop/Source10.jsx
Message: Houston, we have a problem.
Stack: [Source10.jsx]
toString()
Run Code Online (Sandbox Code Playgroud)
结果:
Line: 12
File: ~/Desktop/Source12.jsx
Message: null is not an object
Stack: undefined
Run Code Online (Sandbox Code Playgroud)
所以它并不适用于所有错误,而是适用于其进度。
| 归档时间: |
|
| 查看次数: |
2611 次 |
| 最近记录: |