Bug 38662

Summary: Web Inspector: //# sourceURL does not work with eval and the profiler
Product: WebKit Reporter: Patrick Mueller <pmuellr>
Component: Web InspectorAssignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: bweinstein, domenic, graouts, joepeck, keishi, pfeldman, pmuellr, rik, saam, timothy, webkit-bug-importer, yurys
Priority: P2 Keywords: InRadar
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Attachments:
Description Flags
test case showing problem
none
screenshot showing problem none

Patrick Mueller
Reported 2010-05-06 10:43:13 PDT
When using the "//@sourceURL=" annotation in an eval()'d string, the source location will show up in the debugger, including using the specified sourceURL. However, no source location information is available for such "scripts" in the profiler.
Attachments
test case showing problem (3.36 KB, text/html)
2010-05-06 10:45 PDT, Patrick Mueller
no flags
screenshot showing problem (26.19 KB, image/png)
2010-05-06 10:46 PDT, Patrick Mueller
no flags
Patrick Mueller
Comment 1 2010-05-06 10:45:01 PDT
Created attachment 55261 [details] test case showing problem
Patrick Mueller
Comment 2 2010-05-06 10:46:18 PDT
Created attachment 55264 [details] screenshot showing problem The orange round-rectangles, pointed to by the red arrows, show where the source location should be displayed, but isn't.
Patrick Mueller
Comment 3 2010-05-07 12:27:06 PDT
Looks to me, like the best approach here is to arrange for the sourceID to come in from the profiling data (it currently is NOT), and then do the sourceID lookup against the _sourceIDMap in ScriptPanel back in JavaScript. The ScriptsPanel should have access to the sourceURL, which is parsed in the Script class. ScriptPanel would need to be extended to provide an sourceID->Script lookup function. One place to start looking where to get the sourceID sent back from the profiler is in CallIdentifier (JSC/profiler/CallIdentifier.h). Various places in JSC/profiler/ProfileGenerator.cpp, for instance, create CallIdentifer AND have access to the sourceID. I'm not entirely certain whether the sourceID in the profiler is the same as the one that comes into the ScriptPanel, but initial checks seem to indicate that they are. All this is just for JSC; V8 would need a different but similar set of changes, presumably. Seems kind of expensive, in terms of code hits, for a missing feature not many people have missed. One note though - message sends from the profiler into WI, seem to be sending the sourceURL all the time. If we sent the sourceID instead, we could look up the sourceURL in WI JavaScript code (as suggested above). Could be a savings there. That may even flow back farther in the Profiling code - perhaps we don't really need to ever have the sourceURL available to the profiler if the sourceID is available instead.
Radar WebKit Bug Importer
Comment 4 2014-04-14 17:47:47 PDT
Timothy Hatcher
Comment 5 2016-02-04 20:23:16 PST
Is this an issue with the new sampling profiler?
Patrick Mueller
Comment 6 2016-02-05 15:20:23 PST
The bug title specifically mentions `eval()`, which was one weird trick to do sourcemap-py stuff 6 years ago. If the bug only impacts `eval()` usage of sourcemaps, I doubt this is going to affect anyone.
Joseph Pecoraro
Comment 7 2016-04-20 17:26:02 PDT
Attached test case works as expected in the new profiler.
Note You need to log in before you can comment on or make changes to this bug.