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

Side by Side Diff: headless/lib/browser/headless_browser_context_impl.cc

Issue 2830753004: Pipe the devTools FrameId from blink into the browser for headless (Closed)
Patch Set: Changes for Sami and creis@ Created 3 years, 8 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "headless/lib/browser/headless_browser_context_impl.h" 5 #include "headless/lib/browser/headless_browser_context_impl.h"
6 6
7 #include <memory> 7 #include <memory>
8 #include <string> 8 #include <string>
9 #include <utility> 9 #include <utility>
10 #include <vector> 10 #include <vector>
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after
137 std::vector<HeadlessWebContents*> result; 137 std::vector<HeadlessWebContents*> result;
138 result.reserve(web_contents_map_.size()); 138 result.reserve(web_contents_map_.size());
139 139
140 for (const auto& web_contents_pair : web_contents_map_) { 140 for (const auto& web_contents_pair : web_contents_map_) {
141 result.push_back(web_contents_pair.second.get()); 141 result.push_back(web_contents_pair.second.get());
142 } 142 }
143 143
144 return result; 144 return result;
145 } 145 }
146 146
147 void HeadlessBrowserContextImpl::SetFrameTreeNodeId(int render_process_id,
148 int render_frame_id,
149 int frame_tree_node_id) {
150 base::AutoLock lock(frame_tree_node_map_lock_);
151 frame_tree_node_map_[std::make_pair(render_process_id, render_frame_id)] =
152 frame_tree_node_id;
153 }
154
155 void HeadlessBrowserContextImpl::RemoveFrameTreeNode(int render_process_id,
156 int render_frame_id) {
157 base::AutoLock lock(frame_tree_node_map_lock_);
158 frame_tree_node_map_.erase(
159 std::make_pair(render_process_id, render_frame_id));
160 }
161
162 int HeadlessBrowserContextImpl::GetFrameTreeNodeId(int render_process_id,
163 int render_frame_id) const {
164 base::AutoLock lock(frame_tree_node_map_lock_);
165 const auto& find_it = frame_tree_node_map_.find(
166 std::make_pair(render_process_id, render_frame_id));
167 if (find_it == frame_tree_node_map_.end())
168 return -1;
169 return find_it->second;
170 }
171
147 void HeadlessBrowserContextImpl::Close() { 172 void HeadlessBrowserContextImpl::Close() {
148 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); 173 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
149 browser_->DestroyBrowserContext(this); 174 browser_->DestroyBrowserContext(this);
150 } 175 }
151 176
152 void HeadlessBrowserContextImpl::InitWhileIOAllowed() { 177 void HeadlessBrowserContextImpl::InitWhileIOAllowed() {
153 if (!context_options_->user_data_dir().empty()) { 178 if (!context_options_->user_data_dir().empty()) {
154 path_ = context_options_->user_data_dir(); 179 path_ = context_options_->user_data_dir();
155 } else { 180 } else {
156 PathService::Get(base::DIR_EXE, &path_); 181 PathService::Get(base::DIR_EXE, &path_);
(...skipping 265 matching lines...) Expand 10 before | Expand all | Expand 10 after
422 HeadlessBrowserContext::Builder::MojoBindings::MojoBindings() {} 447 HeadlessBrowserContext::Builder::MojoBindings::MojoBindings() {}
423 448
424 HeadlessBrowserContext::Builder::MojoBindings::MojoBindings( 449 HeadlessBrowserContext::Builder::MojoBindings::MojoBindings(
425 const std::string& mojom_name, 450 const std::string& mojom_name,
426 const std::string& js_bindings) 451 const std::string& js_bindings)
427 : mojom_name(mojom_name), js_bindings(js_bindings) {} 452 : mojom_name(mojom_name), js_bindings(js_bindings) {}
428 453
429 HeadlessBrowserContext::Builder::MojoBindings::~MojoBindings() {} 454 HeadlessBrowserContext::Builder::MojoBindings::~MojoBindings() {}
430 455
431 } // namespace headless 456 } // namespace headless
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698