-
Notifications
You must be signed in to change notification settings - Fork 66
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use the build_id (or something else) to split name section #186
Comments
My initial thought is that this would be a great fit for a build ID. One of the main use cases for a build ID is associating a stripped file with one that still has all the debug info (or with a separate debug-info file). We've generally thought of a name section as just sort of a special case of debug info, so I would think the build ID would fit with that as well. I guess it does mean that there's no explicit URL, so that it's the responsibility of the system that manages those artifacts and symbolizes the stack traces, etc to track that. |
Hm, so I can see this working for an offline tool, but how do you think we could make this work for a developer loading the wasm file from the prod server on their own machine? It feels like we'd need some kind of browser integration to make that work. |
Ah, I see what you mean. Currently we have |
Actually it occured to me that source maps also have the |
I tinkered a bit with trying to generate a source map with names entries to provide function names, but at least in my limited experimenting I couldn't get Chrome to understand it. Concretely I generated a source map that had this data:
And then I generated a stack trace. The Chrome debugger showed that I had successfully mapped two different functions to two different file names ( However, I may have gotten the source map spec totally wrong here! It's not at all clear to me how the |
CC @concavelenz (hi John, long time no see!) just in case he had some advice. :) |
Yes; to be clear, I don't think that Chrome understands the name fields in source maps today. But I expect it could be made to work. |
sourceMappingURL works without the DWARF extension, that's a separate mechanism in DevTools.
DevTools understands sourcemaps, including the names, but V8 does not. V8 makes the exception object including its backtrace, but it does not consider sourcemaps. That's why DevTools shows you names on the callstack but the backtrace doesn't. If the use case is to look at production profiles or stacktraces, wouldn't it be easier to have whatever tool displays these symbolize them on the fly? That would get us back into the "offline tool" waters where build-ids are easy to use. |
Similar to #133, it would be nice to be able to serve a wasm file without a name section, but have it associated with a wasm file that has a name section. In particular this would be useful for developers profiling or getting stack traces from a wasm file in production.
I'm not sure if
build_id
is the right mechanism for this, or perhaps a custom section with a private URL. Any thoughts?The text was updated successfully, but these errors were encountered: