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

Unified Diff: src/inspector/v8-inspector-impl.cc

Issue 2905543004: [inspector] Prepare some methods in V8InspectorImpl to multiple sessions (Closed)
Patch Set: rebased Created 3 years, 7 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/inspector/v8-inspector-impl.h ('k') | src/inspector/v8-inspector-session-impl.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/inspector/v8-inspector-impl.cc
diff --git a/src/inspector/v8-inspector-impl.cc b/src/inspector/v8-inspector-impl.cc
index 3c55507c5a0a5523bfa168e0f343d05510cee50c..3e12c861d3af6bb51d4a0a4bd2dd92baa38a81b8 100644
--- a/src/inspector/v8-inspector-impl.cc
+++ b/src/inspector/v8-inspector-impl.cc
@@ -30,6 +30,8 @@
#include "src/inspector/v8-inspector-impl.h"
+#include <vector>
+
#include "src/inspector/inspected-context.h"
#include "src/inspector/string-util.h"
#include "src/inspector/v8-console-agent-impl.h"
@@ -74,27 +76,6 @@ int V8InspectorImpl::contextGroupId(int contextId) {
return it != m_contextIdToGroupIdMap.end() ? it->second : 0;
}
-V8DebuggerAgentImpl* V8InspectorImpl::enabledDebuggerAgentForGroup(
- int contextGroupId) {
- V8InspectorSessionImpl* session = sessionForContextGroup(contextGroupId);
- V8DebuggerAgentImpl* agent = session ? session->debuggerAgent() : nullptr;
- return agent && agent->enabled() ? agent : nullptr;
-}
-
-V8RuntimeAgentImpl* V8InspectorImpl::enabledRuntimeAgentForGroup(
- int contextGroupId) {
- V8InspectorSessionImpl* session = sessionForContextGroup(contextGroupId);
- V8RuntimeAgentImpl* agent = session ? session->runtimeAgent() : nullptr;
- return agent && agent->enabled() ? agent : nullptr;
-}
-
-V8ProfilerAgentImpl* V8InspectorImpl::enabledProfilerAgentForGroup(
- int contextGroupId) {
- V8InspectorSessionImpl* session = sessionForContextGroup(contextGroupId);
- V8ProfilerAgentImpl* agent = session ? session->profilerAgent() : nullptr;
- return agent && agent->enabled() ? agent : nullptr;
-}
-
v8::MaybeLocal<v8::Value> V8InspectorImpl::compileAndRunInternalScript(
v8::Local<v8::Context> context, v8::Local<v8::String> source) {
v8::Local<v8::UnboundScript> unboundScript;
@@ -171,15 +152,19 @@ std::unique_ptr<V8InspectorSession> V8InspectorImpl::connect(
int contextGroupId, V8Inspector::Channel* channel,
const StringView& state) {
DCHECK(m_sessions.find(contextGroupId) == m_sessions.cend());
+ int sessionId = ++m_lastSessionId;
std::unique_ptr<V8InspectorSessionImpl> session =
- V8InspectorSessionImpl::create(this, contextGroupId, channel, state);
+ V8InspectorSessionImpl::create(this, contextGroupId, sessionId, channel,
+ state);
m_sessions[contextGroupId] = session.get();
+ m_sessionById[sessionId] = session.get();
return std::move(session);
}
void V8InspectorImpl::disconnect(V8InspectorSessionImpl* session) {
DCHECK(m_sessions.find(session->contextGroupId()) != m_sessions.end());
m_sessions.erase(session->contextGroupId());
+ m_sessionById.erase(session->sessionId());
}
InspectedContext* V8InspectorImpl::getContext(int groupId,
@@ -327,12 +312,6 @@ void V8InspectorImpl::discardInspectedContext(int contextGroupId,
if (m_contexts[contextGroupId]->empty()) m_contexts.erase(contextGroupId);
}
-const V8InspectorImpl::ContextByIdMap* V8InspectorImpl::contextGroup(
- int contextGroupId) {
- ContextsByGroupMap::iterator iter = m_contexts.find(contextGroupId);
- return iter == m_contexts.end() ? nullptr : iter->second.get();
-}
-
V8InspectorSessionImpl* V8InspectorImpl::sessionForContextGroup(
int contextGroupId) {
if (!contextGroupId) return nullptr;
@@ -340,9 +319,31 @@ V8InspectorSessionImpl* V8InspectorImpl::sessionForContextGroup(
return iter == m_sessions.end() ? nullptr : iter->second;
}
+V8InspectorSessionImpl* V8InspectorImpl::sessionById(int sessionId) {
+ auto it = m_sessionById.find(sessionId);
+ return it == m_sessionById.end() ? nullptr : it->second;
+}
+
V8Console* V8InspectorImpl::console() {
if (!m_console) m_console.reset(new V8Console(this));
return m_console.get();
}
+void V8InspectorImpl::forEachContext(
+ int contextGroupId, std::function<void(InspectedContext*)> callback) {
+ auto it = m_contexts.find(contextGroupId);
+ if (it == m_contexts.end()) return;
+ std::vector<int> ids;
+ ids.reserve(it->second->size());
+ for (auto& contextIt : *(it->second)) ids.push_back(contextIt.first);
+
+ // Retrieve by ids each time since |callback| may destroy some contexts.
+ for (auto& contextId : ids) {
+ it = m_contexts.find(contextGroupId);
+ if (it == m_contexts.end()) continue;
+ auto contextIt = it->second->find(contextId);
+ if (contextIt != it->second->end()) callback(contextIt->second.get());
+ }
+}
+
} // namespace v8_inspector
« no previous file with comments | « src/inspector/v8-inspector-impl.h ('k') | src/inspector/v8-inspector-session-impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698