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

Side by Side Diff: content/app/mojo/mojo_init.cc

Issue 218583009: Adds a way to associate key/value pairs with the environment (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: comment Created 6 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 | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "content/app/mojo/mojo_init.h" 5 #include "content/app/mojo/mojo_init.h"
6 6
7 #include "base/lazy_instance.h"
8 #include "mojo/embedder/embedder.h" 7 #include "mojo/embedder/embedder.h"
8 #include "mojo/public/cpp/environment/environment.h"
9 #include "mojo/service_manager/service_manager.h" 9 #include "mojo/service_manager/service_manager.h"
10 10
11 namespace content { 11 namespace content {
12 12
13 namespace { 13 namespace {
14 14
15 struct Initializer { 15 mojo::Environment* environment = NULL;
16 Initializer() {
17 // TODO(davemoore): Configuration goes here. For now just create the shared
18 // instance of the ServiceManager.
19 mojo::ServiceManager::GetInstance();
20 mojo::embedder::Init();
21 }
22 };
23
24 static base::LazyInstance<Initializer>::Leaky initializer =
25 LAZY_INSTANCE_INITIALIZER;
26 16
27 } // namespace 17 } // namespace
28 18
29 // Initializes mojo. Use a lazy instance to ensure we only do this once.
30 void InitializeMojo() { 19 void InitializeMojo() {
31 initializer.Get(); 20 DCHECK(!environment);
21 environment = new mojo::Environment;
22 // instance of the ServiceManager.
darin (slow to review) 2014/03/31 23:21:55 nit: "instance of" -> "Instantiate" ?
sky 2014/03/31 23:54:40 This was part of a comment on 18 (old). Makes no s
23 mojo::ServiceManager::GetInstance();
24 mojo::embedder::Init();
darin (slow to review) 2014/03/31 23:21:55 Maybe we should initialize mojo core before initia
sky 2014/03/31 23:54:40 I copied this code. Dave says order shouldn't matt
25 }
26
27 void ShutdownMojo() {
28 delete environment;
darin (slow to review) 2014/03/31 23:21:55 it is not clear why there is a benefit to storing
29 environment = NULL;
32 } 30 }
33 31
34 } // namespace content 32 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698