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

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

Issue 380413003: Mojo: Use InterfaceFactory<Interface> for service registration (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: convert everything over, remove ApplicationConnection::AddService 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_CPP_APPLICATION_CONTEXT_INTERFACE_FACTORY_H_
6 #define MOJO_PUBLIC_CPP_APPLICATION_CONTEXT_INTERFACE_FACTORY_H_
7
8 #include "mojo/public/cpp/application/interface_factory.h"
9
10 namespace mojo {
11
12 // Use this class to allocate and bind instances of Impl constructed with a
13 // context parameter response to requests for interface Interface.
darin (slow to review) 2014/07/15 06:10:37 nit: seems like a period belongs after "parameter"
14 template <typename Impl,
15 typename Context,
16 typename Interface = typename Impl::Implements>
17 class ContextInterfaceFactory : public InterfaceFactory<Interface> {
darin (slow to review) 2014/07/15 06:10:38 nit: How about renaming this to InterfaceFactoryWi
18 public:
19 explicit ContextInterfaceFactory(Context* context) : context_(context) {}
20 virtual ~ContextInterfaceFactory() {}
21
22 virtual void Create(ApplicationConnection* connection,
23 InterfaceRequest<Interface> request) MOJO_OVERRIDE {
24 mojo::BindToRequest(new Impl(context_), &request);
25 }
26
27 private:
28 Context* context_;
29 };
30
31 } // namespace mojo
32
33 #endif // MOJO_PUBLIC_CPP_APPLICATION_CONTEXT_INTERFACE_FACTORY_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698