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_MESSAGE_PIPE_DISPATCHER_H_ | 5 #ifndef MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ |
6 #define MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ | 6 #define MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
10 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
11 #include "mojo/system/dispatcher.h" | 11 #include "mojo/system/dispatcher.h" |
12 #include "mojo/system/system_impl_export.h" | 12 #include "mojo/system/system_impl_export.h" |
13 | 13 |
14 namespace mojo { | 14 namespace mojo { |
15 namespace system { | 15 namespace system { |
16 | 16 |
17 class MessagePipe; | 17 class MessagePipe; |
18 | 18 |
19 // This is the |Dispatcher| implementation for message pipes (created by the | 19 // This is the |Dispatcher| implementation for message pipes (created by the |
20 // Mojo primitive |MojoCreateMessagePipe()|). This class is thread-safe. | 20 // Mojo primitive |MojoCreateMessagePipe()|). This class is thread-safe. |
21 class MOJO_SYSTEM_IMPL_EXPORT MessagePipeDispatcher : public Dispatcher { | 21 class MOJO_SYSTEM_IMPL_EXPORT MessagePipeDispatcher : public Dispatcher { |
22 public: | 22 public: |
23 MessagePipeDispatcher(); | 23 MessagePipeDispatcher(); |
24 | 24 |
25 // Must be called before any other methods. (This method is not thread-safe.) | 25 // Must be called before any other methods. (This method is not thread-safe.) |
26 void Init(scoped_refptr<MessagePipe> message_pipe, unsigned port); | 26 void Init(scoped_refptr<MessagePipe> message_pipe, unsigned port); |
27 | 27 |
| 28 // Gets a dumb pointer to |message_pipe_|. This must be called under the |
| 29 // |Dispatcher| lock (that it's a dumb pointer is okay since it's under lock). |
| 30 // This is needed when sending handles across processes, where nontrivial, |
| 31 // invasive work needs to be done. |
| 32 MessagePipe* GetMessagePipeNoLock() const; |
| 33 // Similarly for the port. |
| 34 unsigned GetPortNoLock() const; |
| 35 |
28 virtual Type GetType() OVERRIDE; | 36 virtual Type GetType() OVERRIDE; |
29 | 37 |
30 private: | 38 private: |
31 friend class base::RefCountedThreadSafe<MessagePipeDispatcher>; | 39 friend class base::RefCountedThreadSafe<MessagePipeDispatcher>; |
32 virtual ~MessagePipeDispatcher(); | 40 virtual ~MessagePipeDispatcher(); |
33 | 41 |
34 // |Dispatcher| implementation/overrides: | 42 // |Dispatcher| implementation/overrides: |
35 virtual void CancelAllWaitersNoLock() OVERRIDE; | 43 virtual void CancelAllWaitersNoLock() OVERRIDE; |
36 virtual MojoResult CloseImplNoLock() OVERRIDE; | 44 virtual MojoResult CloseImplNoLock() OVERRIDE; |
37 virtual MojoResult WriteMessageImplNoLock( | 45 virtual MojoResult WriteMessageImplNoLock( |
(...skipping 16 matching lines...) Expand all Loading... |
54 scoped_refptr<MessagePipe> message_pipe_; // This will be null if closed. | 62 scoped_refptr<MessagePipe> message_pipe_; // This will be null if closed. |
55 unsigned port_; | 63 unsigned port_; |
56 | 64 |
57 DISALLOW_COPY_AND_ASSIGN(MessagePipeDispatcher); | 65 DISALLOW_COPY_AND_ASSIGN(MessagePipeDispatcher); |
58 }; | 66 }; |
59 | 67 |
60 } // namespace system | 68 } // namespace system |
61 } // namespace mojo | 69 } // namespace mojo |
62 | 70 |
63 #endif // MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ | 71 #endif // MOJO_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ |
OLD | NEW |