OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_SYSTEM_CHANNEL_H_ | 5 #ifndef MOJO_SYSTEM_CHANNEL_H_ |
6 #define MOJO_SYSTEM_CHANNEL_H_ | 6 #define MOJO_SYSTEM_CHANNEL_H_ |
7 | 7 |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
11 #include "base/compiler_specific.h" | 11 #include "base/compiler_specific.h" |
12 #include "base/containers/hash_tables.h" | 12 #include "base/containers/hash_tables.h" |
13 #include "base/memory/ref_counted.h" | 13 #include "base/memory/ref_counted.h" |
14 #include "base/memory/scoped_ptr.h" | 14 #include "base/memory/scoped_ptr.h" |
15 #include "base/strings/string_piece.h" | 15 #include "base/strings/string_piece.h" |
16 #include "base/synchronization/lock.h" | 16 #include "base/synchronization/lock.h" |
17 #include "base/threading/thread_checker.h" | 17 #include "base/threading/thread_checker.h" |
18 #include "mojo/public/system/core.h" | 18 #include "mojo/public/system/core.h" |
19 #include "mojo/system/message_in_transit.h" | 19 #include "mojo/system/message_in_transit.h" |
20 #include "mojo/system/message_pipe.h" | 20 #include "mojo/system/message_pipe.h" |
21 #include "mojo/system/raw_channel.h" | 21 #include "mojo/system/raw_channel.h" |
| 22 #include "mojo/system/scoped_platform_handle.h" |
22 #include "mojo/system/system_impl_export.h" | 23 #include "mojo/system/system_impl_export.h" |
23 | 24 |
24 namespace base { | 25 namespace base { |
25 class MessageLoop; | 26 class MessageLoop; |
26 } | 27 } |
27 | 28 |
28 namespace mojo { | 29 namespace mojo { |
29 namespace system { | 30 namespace system { |
30 | 31 |
31 // This class is mostly thread-safe. It must be created on an "I/O thread" (see | 32 // This class is mostly thread-safe. It must be created on an "I/O thread" (see |
(...skipping 24 matching lines...) Expand all Loading... |
56 : public base::RefCountedThreadSafe<Channel>, | 57 : public base::RefCountedThreadSafe<Channel>, |
57 public RawChannel::Delegate { | 58 public RawChannel::Delegate { |
58 public: | 59 public: |
59 // The first message pipe endpoint attached will have this as its local ID. | 60 // The first message pipe endpoint attached will have this as its local ID. |
60 static const MessageInTransit::EndpointId kBootstrapEndpointId = 1; | 61 static const MessageInTransit::EndpointId kBootstrapEndpointId = 1; |
61 | 62 |
62 Channel(); | 63 Channel(); |
63 | 64 |
64 // This must be called on the creation thread before any other methods are | 65 // This must be called on the creation thread before any other methods are |
65 // called, and before references to this object are given to any other | 66 // called, and before references to this object are given to any other |
66 // threads. Takes ownership of |handle|. Returns true on success. On failure, | 67 // threads. |handle| should be a handle to a (platform-appropriate) |
67 // no other methods should be called (including |Shutdown()|). | 68 // bidirectional communication channel (e.g., a socket on POSIX, a named pipe |
68 bool Init(const PlatformChannelHandle& handle); | 69 // on Windows). Returns true on success. On failure, no other methods should |
| 70 // be called (including |Shutdown()|). |
| 71 bool Init(ScopedPlatformHandle handle); |
69 | 72 |
70 // This must be called on the creation thread before destruction (which can | 73 // This must be called on the creation thread before destruction (which can |
71 // happen on any thread). | 74 // happen on any thread). |
72 void Shutdown(); | 75 void Shutdown(); |
73 | 76 |
74 // Attaches the given message pipe/port's endpoint (which must be a | 77 // Attaches the given message pipe/port's endpoint (which must be a |
75 // |ProxyMessagePipeEndpoint|) to this channel. This assigns it a local ID, | 78 // |ProxyMessagePipeEndpoint|) to this channel. This assigns it a local ID, |
76 // which it returns. The first message pipe endpoint attached will always have | 79 // which it returns. The first message pipe endpoint attached will always have |
77 // |kBootstrapEndpointId| as its local ID. (For bootstrapping, this occurs on | 80 // |kBootstrapEndpointId| as its local ID. (For bootstrapping, this occurs on |
78 // both sides, so one should use |kBootstrapEndpointId| for the remote ID for | 81 // both sides, so one should use |kBootstrapEndpointId| for the remote ID for |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
134 // be checked for existence before use. | 137 // be checked for existence before use. |
135 MessageInTransit::EndpointId next_local_id_; | 138 MessageInTransit::EndpointId next_local_id_; |
136 | 139 |
137 DISALLOW_COPY_AND_ASSIGN(Channel); | 140 DISALLOW_COPY_AND_ASSIGN(Channel); |
138 }; | 141 }; |
139 | 142 |
140 } // namespace system | 143 } // namespace system |
141 } // namespace mojo | 144 } // namespace mojo |
142 | 145 |
143 #endif // MOJO_SYSTEM_CHANNEL_H_ | 146 #endif // MOJO_SYSTEM_CHANNEL_H_ |
OLD | NEW |