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

Side by Side Diff: mojo/public/cpp/bindings/interface_handle.h

Issue 1682113003: Mojo C++ bindings: Generate InterfaceHandle<> instead of InterfacePtr<>. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: delay InterfacePtr::Create() until you actually need an InterfacePtr. GetProxy() and ConnectToAppl… Created 4 years, 10 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
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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_CPP_BINDINGS_INTERFACE_PTR_INFO_H_ 5 #ifndef MOJO_PUBLIC_CPP_BINDINGS_INTERFACE_PTR_INFO_H_
6 #define MOJO_PUBLIC_CPP_BINDINGS_INTERFACE_PTR_INFO_H_ 6 #define MOJO_PUBLIC_CPP_BINDINGS_INTERFACE_PTR_INFO_H_
7 7
8 #include <cstddef>
9
8 #include "mojo/public/cpp/system/macros.h" 10 #include "mojo/public/cpp/system/macros.h"
9 #include "mojo/public/cpp/system/message_pipe.h" 11 #include "mojo/public/cpp/system/message_pipe.h"
10 12
11 namespace mojo { 13 namespace mojo {
12 14
15 template <typename Interface>
16 class InterfacePtr;
17
13 // InterfaceHandle stores necessary information to communicate with a remote 18 // InterfaceHandle stores necessary information to communicate with a remote
14 // interface implementation, which could be used to construct an InterfacePtr. 19 // interface implementation, which could be used to construct an InterfacePtr.
15 template <typename Interface> 20 template <typename Interface>
16 class InterfaceHandle { 21 class InterfaceHandle {
17 public: 22 public:
18 InterfaceHandle() : version_(0u) {} 23 InterfaceHandle() : version_(0u) {}
24 InterfaceHandle(std::nullptr_t) : version_(0u) {}
19 25
20 InterfaceHandle(ScopedMessagePipeHandle handle, uint32_t version) 26 InterfaceHandle(ScopedMessagePipeHandle handle, uint32_t version)
21 : handle_(handle.Pass()), version_(version) {} 27 : handle_(handle.Pass()), version_(version) {}
22 28
23 InterfaceHandle(InterfaceHandle&& other) 29 InterfaceHandle(InterfaceHandle&& other)
24 : handle_(other.handle_.Pass()), version_(other.version_) { 30 : handle_(other.handle_.Pass()), version_(other.version_) {
25 other.version_ = 0u; 31 other.version_ = 0u;
26 } 32 }
27 33
34 // Making this constructor templated ensures that it is not type-instantiated
35 // unless it is used, making the InterfacePtr<->InterfaceHandle codependency
36 // less fragile.
37 template <typename SameInterfaceAsAbove>
viettrungluu 2016/02/11 18:26:29 If you want to make it clearer that users probably
vardhan 2016/02/11 22:47:53 Done.
38 InterfaceHandle(InterfacePtr<SameInterfaceAsAbove>&& ptr) {
39 *this = ptr.PassInterfaceHandle();
40 }
41
28 ~InterfaceHandle() {} 42 ~InterfaceHandle() {}
29 43
30 InterfaceHandle& operator=(InterfaceHandle&& other) { 44 InterfaceHandle& operator=(InterfaceHandle&& other) {
31 if (this != &other) { 45 if (this != &other) {
32 handle_ = other.handle_.Pass(); 46 handle_ = other.handle_.Pass();
33 version_ = other.version_; 47 version_ = other.version_;
34 other.version_ = 0u; 48 other.version_ = 0u;
35 } 49 }
36 50
37 return *this; 51 return *this;
38 } 52 }
39 53
54 // Tests as true if we have a valid handle.
55 explicit operator bool() const { return is_valid(); }
40 bool is_valid() const { return handle_.is_valid(); } 56 bool is_valid() const { return handle_.is_valid(); }
41 57
42 ScopedMessagePipeHandle PassHandle() { return handle_.Pass(); } 58 ScopedMessagePipeHandle PassHandle() { return handle_.Pass(); }
43 const ScopedMessagePipeHandle& handle() const { return handle_; } 59 const ScopedMessagePipeHandle& handle() const { return handle_; }
44 void set_handle(ScopedMessagePipeHandle handle) { handle_ = handle.Pass(); } 60 void set_handle(ScopedMessagePipeHandle handle) { handle_ = handle.Pass(); }
45 61
46 uint32_t version() const { return version_; } 62 uint32_t version() const { return version_; }
47 void set_version(uint32_t version) { version_ = version; } 63 void set_version(uint32_t version) { version_ = version; }
48 64
49 private: 65 private:
50 ScopedMessagePipeHandle handle_; 66 ScopedMessagePipeHandle handle_;
51 uint32_t version_; 67 uint32_t version_;
52 68
53 MOJO_MOVE_ONLY_TYPE(InterfaceHandle); 69 MOJO_MOVE_ONLY_TYPE(InterfaceHandle);
54 }; 70 };
55 71
56 } // namespace mojo 72 } // namespace mojo
57 73
58 #endif // MOJO_PUBLIC_CPP_BINDINGS_INTERFACE_PTR_INFO_H_ 74 #endif // MOJO_PUBLIC_CPP_BINDINGS_INTERFACE_PTR_INFO_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698