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

Side by Side Diff: components/profile_service/profile_app.cc

Issue 1737933002: mojo leveldb: Get profile and leveldb connected to DOMStorageContext. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Keeping up with the ToT Created 4 years, 9 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "components/profile_service/profile_app.h" 5 #include "components/profile_service/profile_app.h"
6 6
7 #include "base/lazy_instance.h" 7 #include "base/lazy_instance.h"
8 #include "components/leveldb/leveldb_service_impl.h"
9 #include "components/profile_service/profile_service_impl.h" 8 #include "components/profile_service/profile_service_impl.h"
10 #include "mojo/shell/public/cpp/connection.h" 9 #include "mojo/shell/public/cpp/connection.h"
11 10
12 namespace profile { 11 namespace profile {
13 12
14 namespace { 13 namespace {
15 14
16 base::LazyInstance<std::map<uint32_t, base::FilePath>> g_user_id_to_data_dir = 15 base::LazyInstance<std::map<uint32_t, base::FilePath>> g_user_id_to_data_dir =
17 LAZY_INSTANCE_INITIALIZER; 16 LAZY_INSTANCE_INITIALIZER;
18 17
19 } // namespace 18 } // namespace
20 19
21 scoped_ptr<mojo::ShellClient> CreateProfileApp() { 20 scoped_ptr<mojo::ShellClient> CreateProfileApp() {
22 return make_scoped_ptr(new ProfileApp); 21 return make_scoped_ptr(new ProfileApp);
23 } 22 }
24 23
25 ProfileApp::ProfileApp() 24 ProfileApp::ProfileApp()
26 : lock_table_(new filesystem::LockTable) { 25 : lock_table_(new filesystem::LockTable),
26 profiles_outstanding_(0) {
27 } 27 }
28 28
29 ProfileApp::~ProfileApp() {} 29 ProfileApp::~ProfileApp() {}
30 30
31 // static 31 // static
32 void ProfileApp::AssociateMojoUserIDWithProfileDir( 32 void ProfileApp::AssociateMojoUserIDWithProfileDir(
33 uint32_t user_id, 33 uint32_t user_id,
34 const base::FilePath& profile_data_dir) { 34 const base::FilePath& profile_data_dir) {
35 g_user_id_to_data_dir.Get()[user_id] = profile_data_dir; 35 g_user_id_to_data_dir.Get()[user_id] = profile_data_dir;
36 } 36 }
37 37
38 void ProfileApp::OnProfileServiceDestroyed() {
39 profiles_outstanding_--;
40 if (profiles_outstanding_ == 0)
41 base::MessageLoop::current()->QuitNow();
Ben Goodger (Google) 2016/03/04 20:50:49 you can also use mojo/shell/public/cpp/message_loo
Elliot Glaysher 2016/03/10 21:00:35 Done. (Here and in leveldb.)
42 }
43
38 void ProfileApp::Initialize(mojo::Connector* connector, 44 void ProfileApp::Initialize(mojo::Connector* connector,
39 const std::string& url, 45 const std::string& url,
40 uint32_t id, 46 uint32_t id,
41 uint32_t user_id) { 47 uint32_t user_id) {
42 tracing_.Initialize(connector, url); 48 tracing_.Initialize(connector, url);
43 leveldb_service_.reset(new leveldb::LevelDBServiceImpl);
44 49
45 auto it = g_user_id_to_data_dir.Get().find(user_id); 50 auto it = g_user_id_to_data_dir.Get().find(user_id);
46 DCHECK(it != g_user_id_to_data_dir.Get().end()); 51 DCHECK(it != g_user_id_to_data_dir.Get().end());
47 profile_data_dir_ = it->second; 52 profile_data_dir_ = it->second;
48 } 53 }
49 54
50 bool ProfileApp::AcceptConnection(mojo::Connection* connection) { 55 bool ProfileApp::AcceptConnection(mojo::Connection* connection) {
51 connection->AddInterface<leveldb::LevelDBService>(this);
52 connection->AddInterface<ProfileService>(this); 56 connection->AddInterface<ProfileService>(this);
53 return true; 57 return true;
54 } 58 }
55 59
56 void ProfileApp::Create(mojo::Connection* connection, 60 void ProfileApp::Create(mojo::Connection* connection,
57 mojo::InterfaceRequest<ProfileService> request) { 61 mojo::InterfaceRequest<ProfileService> request) {
58 // No, we need one of these per connection. 62 profiles_outstanding_++;
59 new ProfileServiceImpl(connection, 63 new ProfileServiceImpl(connection,
60 std::move(request), 64 std::move(request),
65 base::Bind(&ProfileApp::OnProfileServiceDestroyed,
66 base::Unretained(this)),
61 profile_data_dir_, 67 profile_data_dir_,
62 lock_table_.get()); 68 lock_table_.get());
63 } 69 }
64 70
65 void ProfileApp::Create(
66 mojo::Connection* connection,
67 mojo::InterfaceRequest<leveldb::LevelDBService> request) {
68 leveldb_bindings_.AddBinding(leveldb_service_.get(), std::move(request));
69 }
70
71 } // namespace profile 71 } // namespace profile
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698