[Webkit-unassigned] [Bug 99801] Web Inspector: [JSC] implement WorkerScriptDebugServer
bugzilla-daemon at webkit.org
bugzilla-daemon at webkit.org
Tue Oct 23 21:00:20 PDT 2012
https://bugs.webkit.org/show_bug.cgi?id=99801
--- Comment #7 from Peter Wang <peter.wang at torchmobile.com.cn> 2012-10-23 21:01:23 PST ---
In the new patch, what I did according to these comments:
(In reply to comment #5)
> (In reply to comment #2)
> > (From update of attachment 169578 [details] [details])
> > View in context: https://bugs.webkit.org/attachment.cgi?id=169578&action=review
> >
> > Inspector part of the change looks good to me except a few minor things. I am pretty sure we should be able to treat page and worker debuggers similarly in Source/JavaScriptCore/debugger but I'm not an expert in JSC so you need someone working on JSC to review that part.
> >
> > > Source/JavaScriptCore/parser/Parser.h:998
> > > + if (debugger && !debugger->isWorkerDebugger() && !ParsedNode::scopeIsFunction)
> >
> > I still don't understand why we should treat parse events differently in case of workers. We need someone familiar with JSC code to look at this part.
> >
> Because when Inspector is attached, the JS code is demanded to be recompiled, and JSC send the code to Inspector ("debugger!=null" means Inspector is attached) by these statements of "Parser.h". If we inspecting a normal web page, JS code just recompiled once, and then the "compiled"(not exactly) code is executed, the related statements of "Parser.h" is never be invoked, so Inspector has only one copy of code.
> But for worker js with timer, there is a problem.
Based no newest code, good news is now the worker JS code doesn't recompiled every executed, bad news is I cannot find which patch do me the favour.
I'm investigating, at least it doesn't bother us so far.
> > > Source/WebCore/bindings/js/ScriptDebugServer.cpp:370
> > > + dispatchDidParseSource(*listeners, sourceProvider, isWorkerDebugger() ? false : isContentScript(exec));
> >
> > Please make isContentScript a virtual method on ScriptDebugServer and provide appropriate implementations for Page/WorkerScriptDebug instead of introducing isWorkerDebugger.
> >
> ok
I did it as your comment.
> > > Source/WebCore/bindings/js/WorkerScriptDebugServer.cpp:58
> > > + // If JavaScript stack is not empty postpone recompilation.
> >
> > It seems that we can safely assume the JS stack is empty if recompileAllJSFunctions is invoked by Timer but this is a different issue.
> >
> Yes, it's another issue of JSC. So far, we can just use these code as "PageScriptDebugeServer". Actually, the statement
> "if (JSDOMWindow::commonJSGlobalData()->dynamicGlobalObject)" has problem when there are two pages in one process, and being Inspected in same time.
>
> > > Source/WebCore/bindings/js/WorkerScriptDebugServer.cpp:73
> > > + recompileAllJSFunctions(0);
> >
> > recompileAllJSFunctionsSoon
> sorry, thx.
I checked code again, I really need "recompileAllJSFunctions(0)", it's a protect wrapper. We're not always sure the situation of JSC engine when it's invoked here.
--
Configure bugmail: https://bugs.webkit.org/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
You are the assignee for the bug.
More information about the webkit-unassigned
mailing list