Stage: Stage 1
Champions: Matthew Gaudet (Mozilla), Daniel Minor (Mozilla)
V8 has has a non-standard Stack Trace API for a while.
In August 2023, JSC also shipped this method
This method has now turned into a web-compatability problem, and as a result we should now standardize it.
To quote the V8 documentation:
Stack trace collection for custom exceptions
The stack trace mechanism used for built-in errors is implemented using a general stack trace collection API that is also available to user scripts. The function
Error.captureStackTrace(error, constructorOpt)adds a stack property to the given error object that yields the stack trace at the time captureStackTrace was called. Stack traces collected through
Error.captureStackTraceare immediately collected, formatted, and attached to the given error object.The optional
constructorOptparameter allows you to pass in a function value. When collecting the stack trace all frames above the topmost call to this function, including that call, are left out of the stack trace. This can be useful to hide implementation details that won’t be useful to the user. The usual way of defining a custom error that captures a stack trace would be:function MyError() { Error.captureStackTrace(this, MyError); // Any other initialization goes here. }Passing in
MyErroras a second argument means that the constructor call toMyErrorwon’t show up in the stack trace.
Note that although the documentation states that the stack trace is immediately collected and formatted, this is not the case in V8 because of the
existence of the Error.prepareStackTrace method. Formatting is performed when
the stack is first accessed, to avoid spending time formatting a strack trace that is potentially never accessed.
Unfortunately, the JSC implementation diverges from the V8 one:
- JSC attaches a string valued prop to the object provided, where V8 instead installs their stack-getter function.
- It uses the JSC stack string format.
Because of Error.prepareStackTrace and the existing behaviour of formatting stacks lazily in V8, it's not likely to be practical for V8 to
switch to using a data property.
The text for the contents of the stack string should probably be something along the lines of
The contents of the stack string is a textual representation of the execution context stack, however the actual format and contents are implemetation defined and should not be relied upon to be identical across implementations.
- The Error Stacks proposal is largely an orthogonal one to this, but it would provide framework and text to talk about stack strings, as mostly the current spec doesn't really talk about stacks. However, for this proposal I'd argue we don't need to specify the contents of stack strings.
- The Error Stack Accessor proposal could be the other route by which the spec starts to talk about stacks. Note that Error.captureStackTraceworks with any object, whereas the stack accessor proposal only works withErrorinstances, so the two proposals are solving different problems.