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

Side by Side Diff: services/user/user_shell_client.cc

Issue 2179023004: Make Service own ServiceContext. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 4 years, 4 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
« no previous file with comments | « services/user/user_shell_client.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 "services/user/user_shell_client.h" 5 #include "services/user/user_shell_client.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/memory/ptr_util.h" 8 #include "base/memory/ptr_util.h"
9 #include "base/memory/weak_ptr.h" 9 #include "base/memory/weak_ptr.h"
10 #include "components/filesystem/lock_table.h" 10 #include "components/filesystem/lock_table.h"
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
81 scoped_refptr<base::SingleThreadTaskRunner> user_service_runner, 81 scoped_refptr<base::SingleThreadTaskRunner> user_service_runner,
82 scoped_refptr<base::SingleThreadTaskRunner> leveldb_service_runner) 82 scoped_refptr<base::SingleThreadTaskRunner> leveldb_service_runner)
83 : user_service_runner_(std::move(user_service_runner)), 83 : user_service_runner_(std::move(user_service_runner)),
84 leveldb_service_runner_(std::move(leveldb_service_runner)) {} 84 leveldb_service_runner_(std::move(leveldb_service_runner)) {}
85 85
86 UserShellClient::~UserShellClient() { 86 UserShellClient::~UserShellClient() {
87 user_service_runner_->DeleteSoon(FROM_HERE, user_objects_.release()); 87 user_service_runner_->DeleteSoon(FROM_HERE, user_objects_.release());
88 leveldb_service_runner_->DeleteSoon(FROM_HERE, leveldb_objects_.release()); 88 leveldb_service_runner_->DeleteSoon(FROM_HERE, leveldb_objects_.release());
89 } 89 }
90 90
91 void UserShellClient::OnStart(shell::Connector* connector, 91 void UserShellClient::OnStart(const shell::Identity& identity) {
92 const shell::Identity& identity,
93 uint32_t id) {
94 user_objects_.reset(new UserShellClient::UserServiceObjects( 92 user_objects_.reset(new UserShellClient::UserServiceObjects(
95 GetUserDirForUserId(identity.user_id()))); 93 GetUserDirForUserId(identity.user_id())));
96 leveldb_objects_.reset( 94 leveldb_objects_.reset(
97 new UserShellClient::LevelDBServiceObjects(leveldb_service_runner_)); 95 new UserShellClient::LevelDBServiceObjects(leveldb_service_runner_));
98 } 96 }
99 97
100 bool UserShellClient::OnConnect(shell::Connection* connection) { 98 bool UserShellClient::OnConnect(shell::Connection* connection) {
101 connection->AddInterface<leveldb::mojom::LevelDBService>(this); 99 connection->AddInterface<leveldb::mojom::LevelDBService>(this);
102 connection->AddInterface<mojom::UserService>(this); 100 connection->AddInterface<mojom::UserService>(this);
103 return true; 101 return true;
(...skipping 12 matching lines...) Expand all
116 leveldb::mojom::LevelDBServiceRequest request) { 114 leveldb::mojom::LevelDBServiceRequest request) {
117 leveldb_service_runner_->PostTask( 115 leveldb_service_runner_->PostTask(
118 FROM_HERE, 116 FROM_HERE,
119 base::Bind( 117 base::Bind(
120 &UserShellClient::LevelDBServiceObjects::OnLevelDBServiceRequest, 118 &UserShellClient::LevelDBServiceObjects::OnLevelDBServiceRequest,
121 leveldb_objects_->AsWeakPtr(), remote_identity, 119 leveldb_objects_->AsWeakPtr(), remote_identity,
122 base::Passed(&request))); 120 base::Passed(&request)));
123 } 121 }
124 122
125 } // namespace user_service 123 } // namespace user_service
OLDNEW
« no previous file with comments | « services/user/user_shell_client.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698