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

Side by Side Diff: mojo/shell/public/cpp/lib/interface_factory_binder.h

Issue 1877753003: Move mojo\shell to services\shell (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@62scan
Patch Set: . Created 4 years, 8 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
(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_SHELL_PUBLIC_CPP_LIB_INTERFACE_FACTORY_BINDER_H_
6 #define MOJO_SHELL_PUBLIC_CPP_LIB_INTERFACE_FACTORY_BINDER_H_
7
8 #include <utility>
9
10 #include "mojo/public/cpp/bindings/interface_request.h"
11 #include "mojo/shell/public/cpp/interface_binder.h"
12 #include "mojo/shell/public/cpp/interface_factory.h"
13
14 namespace mojo {
15 namespace internal {
16
17 template <typename Interface>
18 class InterfaceFactoryBinder : public InterfaceBinder {
19 public:
20 explicit InterfaceFactoryBinder(InterfaceFactory<Interface>* factory)
21 : factory_(factory) {}
22 ~InterfaceFactoryBinder() override {}
23
24 void BindInterface(Connection* connection,
25 const std::string& interface_name,
26 ScopedMessagePipeHandle client_handle) override {
27 factory_->Create(connection,
28 MakeRequest<Interface>(std::move(client_handle)));
29 }
30
31 private:
32 InterfaceFactory<Interface>* factory_;
33 DISALLOW_COPY_AND_ASSIGN(InterfaceFactoryBinder);
34 };
35
36 } // namespace internal
37 } // namespace mojo
38
39 #endif // MOJO_SHELL_PUBLIC_CPP_LIB_INTERFACE_FACTORY_BINDER_H_
OLDNEW
« no previous file with comments | « mojo/shell/public/cpp/lib/init_commandline.cc ('k') | mojo/shell/public/cpp/lib/interface_registry.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698