Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(22)

Side by Side Diff: Source/core/inspector/PageRuntimeAgent.cpp

Issue 24989007: Model each Dart library as its own ScriptState when devtools are enabled. (Closed) Base URL: svn://svn.chromium.org/multivm/trunk/webkit
Patch Set: Ready for review Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2011 Google Inc. All rights reserved. 2 * Copyright (C) 2011 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 13 matching lines...) Expand all
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */ 29 */
30 30
31 #include "config.h" 31 #include "config.h"
32 #include "core/inspector/PageRuntimeAgent.h" 32 #include "core/inspector/PageRuntimeAgent.h"
33 33
34 #include "bindings/dart/DartController.h"
35 #include "bindings/dart/DartHandleProxy.h"
34 #include "bindings/v8/DOMWrapperWorld.h" 36 #include "bindings/v8/DOMWrapperWorld.h"
35 #include "bindings/v8/ScriptController.h" 37 #include "bindings/v8/ScriptController.h"
36 #include "core/inspector/InjectedScript.h" 38 #include "core/inspector/InjectedScript.h"
37 #include "core/inspector/InjectedScriptManager.h" 39 #include "core/inspector/InjectedScriptManager.h"
38 #include "core/inspector/InspectorPageAgent.h" 40 #include "core/inspector/InspectorPageAgent.h"
39 #include "core/inspector/InspectorState.h" 41 #include "core/inspector/InspectorState.h"
40 #include "core/inspector/InstrumentingAgents.h" 42 #include "core/inspector/InstrumentingAgents.h"
41 #include "core/page/Frame.h" 43 #include "core/page/Frame.h"
42 #include "core/page/Page.h" 44 #include "core/page/Page.h"
43 #include "core/page/PageConsole.h" 45 #include "core/page/PageConsole.h"
44 #include "weborigin/SecurityOrigin.h" 46 #include "weborigin/SecurityOrigin.h"
45 47
48 #include <dart_api.h>
vsm 2013/09/30 22:08:03 We should really avoid including this outside of b
Jacob 2013/10/01 00:07:05 Worse... I didn't even use this import anymore. I
49
46 using WebCore::TypeBuilder::Runtime::ExecutionContextDescription; 50 using WebCore::TypeBuilder::Runtime::ExecutionContextDescription;
47 51
48 namespace WebCore { 52 namespace WebCore {
49 53
50 namespace PageRuntimeAgentState { 54 namespace PageRuntimeAgentState {
51 static const char runtimeEnabled[] = "runtimeEnabled"; 55 static const char runtimeEnabled[] = "runtimeEnabled";
52 }; 56 };
53 57
54 PageRuntimeAgent::PageRuntimeAgent(InstrumentingAgents* instrumentingAgents, Ins pectorCompositeState* state, InjectedScriptManager* injectedScriptManager, Scrip tDebugServer* scriptDebugServer, Page* page, InspectorPageAgent* pageAgent) 58 PageRuntimeAgent::PageRuntimeAgent(InstrumentingAgents* instrumentingAgents, Ins pectorCompositeState* state, InjectedScriptManager* injectedScriptManager, Scrip tDebugServer* scriptDebugServer, Page* page, InspectorPageAgent* pageAgent)
55 : InspectorRuntimeAgent(instrumentingAgents, state, injectedScriptManager, s criptDebugServer) 59 : InspectorRuntimeAgent(instrumentingAgents, state, injectedScriptManager, s criptDebugServer)
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after
161 void PageRuntimeAgent::reportExecutionContextCreation() 165 void PageRuntimeAgent::reportExecutionContextCreation()
162 { 166 {
163 Vector<std::pair<ScriptState*, SecurityOrigin*> > isolatedContexts; 167 Vector<std::pair<ScriptState*, SecurityOrigin*> > isolatedContexts;
164 for (Frame* frame = m_inspectedPage->mainFrame(); frame; frame = frame->tree ()->traverseNext()) { 168 for (Frame* frame = m_inspectedPage->mainFrame(); frame; frame = frame->tree ()->traverseNext()) {
165 if (!frame->script()->canExecuteScripts(NotAboutToExecuteScript)) 169 if (!frame->script()->canExecuteScripts(NotAboutToExecuteScript))
166 continue; 170 continue;
167 String frameId = m_pageAgent->frameId(frame); 171 String frameId = m_pageAgent->frameId(frame);
168 172
169 ScriptState* scriptState = mainWorldScriptState(frame); 173 ScriptState* scriptState = mainWorldScriptState(frame);
170 notifyContextCreated(frameId, scriptState, 0, true); 174 notifyContextCreated(frameId, scriptState, 0, true);
175 notifyDartContextCreated(frameId, scriptState);
176
171 frame->script()->collectIsolatedContexts(isolatedContexts); 177 frame->script()->collectIsolatedContexts(isolatedContexts);
172 if (isolatedContexts.isEmpty()) 178 if (isolatedContexts.isEmpty())
173 continue; 179 continue;
174 for (size_t i = 0; i< isolatedContexts.size(); i++) 180 for (size_t i = 0; i< isolatedContexts.size(); i++)
175 notifyContextCreated(frameId, isolatedContexts[i].first, isolatedCon texts[i].second, false); 181 notifyContextCreated(frameId, isolatedContexts[i].first, isolatedCon texts[i].second, false);
176 isolatedContexts.clear(); 182 isolatedContexts.clear();
177 } 183 }
178 } 184 }
179 185
186 void PageRuntimeAgent::notifyDartContextCreated(const String& frameId, ScriptSta te* v8ScriptState)
187 {
188 ScriptExecutionContext* scriptExecutionContext = v8ScriptState->scriptExecut ionContext();
189 DartController* dartController = DartController::retrieve(scriptExecutionCon text);
190 if (dartController) {
191 Vector<ScriptState*> scriptStates;
192 dartController->collectScriptStates(v8ScriptState, scriptStates);
193 for (size_t i = 0; i< scriptStates.size(); i++)
194 notifyContextCreated(frameId, scriptStates[i], 0, false);
195 }
196 }
197
180 void PageRuntimeAgent::notifyContextCreated(const String& frameId, ScriptState* scriptState, SecurityOrigin* securityOrigin, bool isPageContext) 198 void PageRuntimeAgent::notifyContextCreated(const String& frameId, ScriptState* scriptState, SecurityOrigin* securityOrigin, bool isPageContext)
181 { 199 {
182 ASSERT(securityOrigin || isPageContext); 200 // FIXME: should Dart scripts have a security origin?
201 ASSERT(securityOrigin || isPageContext || !scriptState->isJavaScript());
183 int executionContextId = injectedScriptManager()->injectedScriptIdFor(script State); 202 int executionContextId = injectedScriptManager()->injectedScriptIdFor(script State);
184 String name = securityOrigin ? securityOrigin->toRawString() : ""; 203 String name = scriptState->name() ? *scriptState->name() : (securityOrigin ? securityOrigin->toRawString() : "");
204
185 m_frontend->executionContextCreated(ExecutionContextDescription::create() 205 m_frontend->executionContextCreated(ExecutionContextDescription::create()
186 .setId(executionContextId) 206 .setId(executionContextId)
187 .setIsPageContext(isPageContext) 207 .setIsPageContext(isPageContext)
188 .setName(name) 208 .setName(name)
189 .setFrameId(frameId) 209 .setFrameId(frameId)
190 .release()); 210 .release());
191 } 211 }
192 212
193 } // namespace WebCore 213 } // namespace WebCore
194 214
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698