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

Side by Side Diff: mojo/public/cpp/application/interface_provider.h

Issue 380413003: Mojo: Use InterfaceFactory<Interface> for service registration (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: specify ownership in the Bind call Created 6 years, 5 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #ifndef MOJO_PUBLIC_APPLICATION_INTERFACE_FACTORY_H_
6 #define MOJO_PUBLIC_APPLICATION_INTERFACE_FACTORY_H_
7
8 #include "mojo/public/cpp/bindings/interface_impl.h"
9 #include "mojo/public/cpp/system/macros.h"
10
11 namespace mojo {
12
13 class ApplicationConnection;
14 template <typename Interface>
15 class InterfaceRequest;
16
17 // Implement this class to provide implementations of a given interface and
18 // bind them to incoming requests. The implementation of this class is
19 // responsible for managing the lifetime of the implementations of the
20 // interface.
21 template <typename Interface>
22 class InterfaceProvider {
23 public:
24 virtual ~InterfaceProvider() {}
25 virtual void BindToRequest(ApplicationConnection* connection,
darin (slow to review) 2014/07/14 21:34:06 I'm still a fan of using terminology like "create
DaveMoore 2014/07/15 00:08:29 I see the Interface as an abstract definition and
26 InterfaceRequest<Interface> request) = 0;
27 };
28
29 } // namespace mojo
30
31 #endif // MOJO_PUBLIC_APPLICATION_INTERFACE_FACTORY_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698