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

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

Issue 1674263002: headless: Initial headless embedder API implementation (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix shutdown memory leak. Created 4 years, 10 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "headless/lib/browser/headless_browser_impl.h"
6
7 #include "base/thread_task_runner_handle.h"
8 #include "content/public/app/content_main.h"
9 #include "content/public/browser/browser_thread.h"
10 #include "content/public/browser/web_contents.h"
11 #include "headless/lib/browser/headless_browser_context.h"
12 #include "headless/lib/browser/headless_browser_main_parts.h"
13 #include "headless/lib/browser/headless_web_contents_impl.h"
14 #include "headless/lib/headless_content_main_delegate.h"
15 #include "ui/aura/env.h"
16 #include "ui/aura/window_tree_host.h"
17 #include "ui/gfx/geometry/size.h"
18
19 namespace headless {
20
21 HeadlessBrowserImpl::~HeadlessBrowserImpl() {}
22
23 scoped_ptr<HeadlessWebContents> HeadlessBrowserImpl::CreateWebContents(
24 const gfx::Size& size) {
25 DCHECK(BrowserMainThread()->BelongsToCurrentThread());
26 return make_scoped_ptr(new HeadlessWebContentsImpl(
27 browser_context(), window_tree_host_->window(), size));
28 }
29
30 scoped_refptr<base::SingleThreadTaskRunner>
31 HeadlessBrowserImpl::BrowserMainThread() const {
32 return content::BrowserThread::GetMessageLoopProxyForThread(
33 content::BrowserThread::UI);
34 }
35
36 void HeadlessBrowserImpl::Shutdown() {
37 DCHECK(BrowserMainThread()->BelongsToCurrentThread());
38 BrowserMainThread()->PostTask(FROM_HERE,
39 base::MessageLoop::QuitWhenIdleClosure());
40 }
41
42 HeadlessBrowserContext* HeadlessBrowserImpl::browser_context() const {
43 DCHECK(BrowserMainThread()->BelongsToCurrentThread());
44 DCHECK(browser_main_parts());
45 return browser_main_parts()->browser_context();
46 }
47
48 HeadlessBrowserMainParts* HeadlessBrowserImpl::browser_main_parts() const {
49 DCHECK(BrowserMainThread()->BelongsToCurrentThread());
50 return browser_main_parts_;
51 }
52
53 void HeadlessBrowserImpl::set_browser_main_parts(
54 HeadlessBrowserMainParts* browser_main_parts) {
55 DCHECK(!browser_main_parts_);
56 browser_main_parts_ = browser_main_parts;
57 }
58
59 void HeadlessBrowserImpl::RunOnStartCallback() {
60 DCHECK(aura::Env::GetInstance());
61 window_tree_host_.reset(aura::WindowTreeHost::Create(gfx::Rect()));
62 window_tree_host_->InitHost();
63
64 DCHECK(!on_start_callback_.is_null());
Ryan Sleevi 2016/02/25 22:04:36 ? Isn't this better dchecked in the HeadlessBrowse
Sami 2016/02/26 18:49:16 Agreed & done.
65 on_start_callback_.Run(this);
66 on_start_callback_ = base::Callback<void(HeadlessBrowser*)>();
67 }
68
69 HeadlessBrowserImpl::HeadlessBrowserImpl(
70 const base::Callback<void(HeadlessBrowser*)>& on_start_callback,
71 const HeadlessBrowser::Options& options)
72 : on_start_callback_(on_start_callback),
73 options_(options),
74 browser_main_parts_(nullptr) {}
75
76 int HeadlessBrowserMain(
77 const HeadlessBrowser::Options& options,
78 const base::Callback<void(HeadlessBrowser*)>& on_browser_start_callback) {
79 scoped_ptr<HeadlessBrowserImpl> browser(
80 new HeadlessBrowserImpl(on_browser_start_callback, options));
81
82 // TODO(skyostil): Implement custom message pumps.
83 DCHECK(!options.message_pump);
84
85 headless::HeadlessContentMainDelegate delegate(std::move(browser));
86 content::ContentMainParams params(&delegate);
87 params.argc = options.argc;
88 params.argv = options.argv;
89 return content::ContentMain(params);
90 }
91
92 } // namespace headless
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698