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

Side by Side Diff: mojo/public/cpp/application/lib/weak_service_provider.h

Issue 466273002: Remove OpenWindow from the WindowManager interface. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 6 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 | 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 #ifndef MOJO_PUBLIC_APPLICATION_LIB_WEAK_SERVICE_PROVIDER_H_ 5 #ifndef MOJO_PUBLIC_APPLICATION_LIB_WEAK_SERVICE_PROVIDER_H_
6 #define MOJO_PUBLIC_APPLICATION_LIB_WEAK_SERVICE_PROVIDER_H_ 6 #define MOJO_PUBLIC_APPLICATION_LIB_WEAK_SERVICE_PROVIDER_H_
7 7
8 #include "mojo/public/interfaces/application/service_provider.mojom.h" 8 #include "mojo/public/interfaces/application/service_provider.mojom.h"
9 9
10 namespace mojo { 10 namespace mojo {
11 class ServiceProviderImpl;
11 namespace internal { 12 namespace internal {
12 class ServiceConnectorBase; 13 class ServiceConnectorBase;
13 14
14 // Implements a weak pointer to a ServiceProvider. Necessary as the lifetime of 15 // Implements a weak pointer to a ServiceProvider. Necessary as the lifetime of
15 // the ServiceProviderImpl is bound to that of its pipe, but code may continue 16 // the ServiceProviderImpl is bound to that of its pipe, but code may continue
16 // to reference a remote service provider beyond the lifetime of said pipe. 17 // to reference a remote service provider beyond the lifetime of said pipe.
17 // Calls to ConnectToService() are silently dropped when the pipe is closed. 18 // Calls to ConnectToService() are silently dropped when the pipe is closed.
18 class WeakServiceProvider : public ServiceProvider { 19 class WeakServiceProvider : public ServiceProvider {
19 public: 20 public:
20 explicit WeakServiceProvider(ServiceProvider* service_provider); 21 WeakServiceProvider(ServiceProviderImpl* creator,
22 ServiceProvider* service_provider);
21 virtual ~WeakServiceProvider(); 23 virtual ~WeakServiceProvider();
22 24
23 void Clear(); 25 void Clear();
24 26
25 private: 27 private:
26 // Overridden from ServiceProvider: 28 // Overridden from ServiceProvider:
27 virtual void ConnectToService( 29 virtual void ConnectToService(
28 const String& service_name, 30 const String& service_name,
29 ScopedMessagePipeHandle client_handle) MOJO_OVERRIDE; 31 ScopedMessagePipeHandle client_handle) MOJO_OVERRIDE;
30 32
33 ServiceProviderImpl* creator_;
31 ServiceProvider* service_provider_; 34 ServiceProvider* service_provider_;
32 35
33 MOJO_DISALLOW_COPY_AND_ASSIGN(WeakServiceProvider); 36 MOJO_DISALLOW_COPY_AND_ASSIGN(WeakServiceProvider);
34 }; 37 };
35 38
36 } // namespace internal 39 } // namespace internal
37 } // namespace mojo 40 } // namespace mojo
38 41
39 #endif // MOJO_PUBLIC_APPLICATION_LIB_WEAK_SERVICE_PROVIDER_H_ 42 #endif // MOJO_PUBLIC_APPLICATION_LIB_WEAK_SERVICE_PROVIDER_H_
OLDNEW
« no previous file with comments | « mojo/public/cpp/application/lib/service_provider_impl.cc ('k') | mojo/public/cpp/application/lib/weak_service_provider.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698