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

Side by Side Diff: mojo/shell/context.cc

Issue 256133002: Changes view manager test to connect via shell (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: merge to trunk Created 6 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « mojo/services/view_manager/view_manager_connection_unittest.cc ('k') | mojo/shell/run.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "mojo/shell/context.h" 5 #include "mojo/shell/context.h"
6 6
7 #include "build/build_config.h"
7 #include "base/command_line.h" 8 #include "base/command_line.h"
8 #include "build/build_config.h" 9 #include "base/lazy_instance.h"
10 #include "base/memory/scoped_vector.h"
9 #include "mojo/embedder/embedder.h" 11 #include "mojo/embedder/embedder.h"
10 #include "mojo/gles2/gles2_support_impl.h" 12 #include "mojo/gles2/gles2_support_impl.h"
13 #include "mojo/public/cpp/shell/application.h"
11 #include "mojo/service_manager/service_loader.h" 14 #include "mojo/service_manager/service_loader.h"
12 #include "mojo/service_manager/service_manager.h" 15 #include "mojo/service_manager/service_manager.h"
13 #include "mojo/services/native_viewport/native_viewport_service.h" 16 #include "mojo/services/native_viewport/native_viewport_service.h"
17 #include "mojo/services/view_manager/root_node_manager.h"
18 #include "mojo/services/view_manager/view_manager_connection.h"
14 #include "mojo/shell/dynamic_service_loader.h" 19 #include "mojo/shell/dynamic_service_loader.h"
15 #include "mojo/shell/in_process_dynamic_service_runner.h" 20 #include "mojo/shell/in_process_dynamic_service_runner.h"
16 #include "mojo/shell/network_delegate.h" 21 #include "mojo/shell/network_delegate.h"
17 #include "mojo/shell/out_of_process_dynamic_service_runner.h" 22 #include "mojo/shell/out_of_process_dynamic_service_runner.h"
18 #include "mojo/shell/switches.h" 23 #include "mojo/shell/switches.h"
19 #include "mojo/spy/spy.h" 24 #include "mojo/spy/spy.h"
20 25
21 #if defined(OS_LINUX) 26 #if defined(OS_LINUX)
22 #include "mojo/shell/dbus_service_loader_linux.h" 27 #include "mojo/shell/dbus_service_loader_linux.h"
23 #endif // defined(OS_LINUX) 28 #endif // defined(OS_LINUX)
24 29
25 namespace mojo { 30 namespace mojo {
26 namespace shell { 31 namespace shell {
32 namespace {
33
34 // Used to ensure we only init once.
35 class Setup {
36 public:
37 Setup() {
38 embedder::Init();
39 gles2::GLES2SupportImpl::Init();
40 }
41
42 ~Setup() {
43 }
44
45 private:
46 DISALLOW_COPY_AND_ASSIGN(Setup);
47 };
48
49 static base::LazyInstance<Setup> setup = LAZY_INSTANCE_INITIALIZER;
50
51 class ViewManagerLoader : public ServiceLoader {
52 public:
53 ViewManagerLoader() {}
54 virtual ~ViewManagerLoader() {}
55
56 private:
57 virtual void LoadService(ServiceManager* manager,
58 const GURL& url,
59 ScopedShellHandle shell_handle) OVERRIDE {
60 scoped_ptr<Application> app(new Application(shell_handle.Pass()));
61 app->AddServiceConnector(
62 new ServiceConnector<services::view_manager::ViewManagerConnection,
63 services::view_manager::RootNodeManager>(
64 &root_node_manager_));
65 apps_.push_back(app.release());
66 }
67
68 virtual void OnServiceError(ServiceManager* manager,
69 const GURL& url) OVERRIDE {
70 }
71
72 services::view_manager::RootNodeManager root_node_manager_;
73 ScopedVector<Application> apps_;
74
75 DISALLOW_COPY_AND_ASSIGN(ViewManagerLoader);
76 };
77
78 } // namespace
27 79
28 class Context::NativeViewportServiceLoader : public ServiceLoader { 80 class Context::NativeViewportServiceLoader : public ServiceLoader {
29 public: 81 public:
30 explicit NativeViewportServiceLoader(Context* context) : context_(context) {} 82 explicit NativeViewportServiceLoader(Context* context) : context_(context) {}
31 virtual ~NativeViewportServiceLoader() {} 83 virtual ~NativeViewportServiceLoader() {}
32 84
33 private: 85 private:
34 virtual void LoadService(ServiceManager* manager, 86 virtual void LoadService(ServiceManager* manager,
35 const GURL& url, 87 const GURL& url,
36 ScopedShellHandle service_handle) OVERRIDE { 88 ScopedShellHandle service_handle) OVERRIDE {
(...skipping 10 matching lines...) Expand all
47 }; 99 };
48 100
49 Context::Context() 101 Context::Context()
50 : task_runners_(base::MessageLoop::current()->message_loop_proxy()), 102 : task_runners_(base::MessageLoop::current()->message_loop_proxy()),
51 storage_(), 103 storage_(),
52 loader_(task_runners_.io_runner(), 104 loader_(task_runners_.io_runner(),
53 task_runners_.file_runner(), 105 task_runners_.file_runner(),
54 task_runners_.cache_runner(), 106 task_runners_.cache_runner(),
55 scoped_ptr<net::NetworkDelegate>(new NetworkDelegate()), 107 scoped_ptr<net::NetworkDelegate>(new NetworkDelegate()),
56 storage_.profile_path()) { 108 storage_.profile_path()) {
57 embedder::Init(); 109 setup.Get();
58 gles2::GLES2SupportImpl::Init();
59
60 CommandLine* cmdline = CommandLine::ForCurrentProcess(); 110 CommandLine* cmdline = CommandLine::ForCurrentProcess();
61 scoped_ptr<DynamicServiceRunnerFactory> runner_factory; 111 scoped_ptr<DynamicServiceRunnerFactory> runner_factory;
62 if (cmdline->HasSwitch(switches::kEnableMultiprocess)) 112 if (cmdline->HasSwitch(switches::kEnableMultiprocess))
63 runner_factory.reset(new OutOfProcessDynamicServiceRunnerFactory()); 113 runner_factory.reset(new OutOfProcessDynamicServiceRunnerFactory());
64 else 114 else
65 runner_factory.reset(new InProcessDynamicServiceRunnerFactory()); 115 runner_factory.reset(new InProcessDynamicServiceRunnerFactory());
66 116
67 service_manager_.set_default_loader( 117 service_manager_.set_default_loader(
68 scoped_ptr<ServiceLoader>( 118 scoped_ptr<ServiceLoader>(
69 new DynamicServiceLoader(this, runner_factory.Pass()))); 119 new DynamicServiceLoader(this, runner_factory.Pass())));
70 service_manager_.SetLoaderForURL( 120 service_manager_.SetLoaderForURL(
71 scoped_ptr<ServiceLoader>(new NativeViewportServiceLoader(this)), 121 scoped_ptr<ServiceLoader>(new NativeViewportServiceLoader(this)),
72 GURL("mojo:mojo_native_viewport_service")); 122 GURL("mojo:mojo_native_viewport_service"));
123 // TODO(sky): need a better way to find this. It shouldn't be linked in.
Ben Goodger (Google) 2014/04/28 19:21:09 this is related to mojo_view_manager being a compo
sky 2014/04/28 21:16:05 Things didn't work well when the rest of chrome wa
124 service_manager_.SetLoaderForURL(
125 scoped_ptr<ServiceLoader>(new ViewManagerLoader()),
126 GURL("mojo:mojo_view_manager"));
73 127
74 #if defined(OS_LINUX) 128 #if defined(OS_LINUX)
75 service_manager_.SetLoaderForScheme( 129 service_manager_.SetLoaderForScheme(
76 scoped_ptr<ServiceLoader>(new DBusServiceLoader(this)), 130 scoped_ptr<ServiceLoader>(new DBusServiceLoader(this)),
77 "dbus"); 131 "dbus");
78 #endif // defined(OS_LINUX) 132 #endif // defined(OS_LINUX)
79 133
80 if (cmdline->HasSwitch(switches::kSpy)) { 134 if (cmdline->HasSwitch(switches::kSpy)) {
81 spy_.reset(new mojo::Spy(&service_manager_, 135 spy_.reset(new mojo::Spy(&service_manager_,
82 cmdline->GetSwitchValueASCII(switches::kSpy))); 136 cmdline->GetSwitchValueASCII(switches::kSpy)));
83 } 137 }
84 } 138 }
85 139
86 Context::~Context() { 140 Context::~Context() {
87 service_manager_.set_default_loader(scoped_ptr<ServiceLoader>()); 141 service_manager_.set_default_loader(scoped_ptr<ServiceLoader>());
88 } 142 }
89 143
90 } // namespace shell 144 } // namespace shell
91 } // namespace mojo 145 } // namespace mojo
OLDNEW
« no previous file with comments | « mojo/services/view_manager/view_manager_connection_unittest.cc ('k') | mojo/shell/run.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698