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

Side by Side Diff: mojo/edk/system/message_pipe_dispatcher.h

Issue 668663006: Standardize usage of virtual/override/final in mojo/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 2 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 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_EDK_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ 5 #ifndef MOJO_EDK_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_
6 #define MOJO_EDK_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ 6 #define MOJO_EDK_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/memory/ref_counted.h" 9 #include "base/memory/ref_counted.h"
10 #include "mojo/edk/system/dispatcher.h" 10 #include "mojo/edk/system/dispatcher.h"
(...skipping 25 matching lines...) Expand all
36 // |MojoCreateMessagePipeOptions| and will be entirely overwritten on success 36 // |MojoCreateMessagePipeOptions| and will be entirely overwritten on success
37 // (it may be partly overwritten on failure). 37 // (it may be partly overwritten on failure).
38 static MojoResult ValidateCreateOptions( 38 static MojoResult ValidateCreateOptions(
39 UserPointer<const MojoCreateMessagePipeOptions> in_options, 39 UserPointer<const MojoCreateMessagePipeOptions> in_options,
40 MojoCreateMessagePipeOptions* out_options); 40 MojoCreateMessagePipeOptions* out_options);
41 41
42 // Must be called before any other methods. (This method is not thread-safe.) 42 // Must be called before any other methods. (This method is not thread-safe.)
43 void Init(scoped_refptr<MessagePipe> message_pipe, unsigned port); 43 void Init(scoped_refptr<MessagePipe> message_pipe, unsigned port);
44 44
45 // |Dispatcher| public methods: 45 // |Dispatcher| public methods:
46 virtual Type GetType() const override; 46 Type GetType() const override;
47 47
48 // Creates a |MessagePipe| with a local endpoint (at port 0) and a proxy 48 // Creates a |MessagePipe| with a local endpoint (at port 0) and a proxy
49 // endpoint, and creates/initializes a |MessagePipeDispatcher| (attached to 49 // endpoint, and creates/initializes a |MessagePipeDispatcher| (attached to
50 // the message pipe, port 0). 50 // the message pipe, port 0).
51 // TODO(vtl): This currently uses |kDefaultCreateOptions|, which is okay since 51 // TODO(vtl): This currently uses |kDefaultCreateOptions|, which is okay since
52 // there aren't any options, but eventually options should be plumbed through. 52 // there aren't any options, but eventually options should be plumbed through.
53 static scoped_refptr<MessagePipeDispatcher> CreateRemoteMessagePipe( 53 static scoped_refptr<MessagePipeDispatcher> CreateRemoteMessagePipe(
54 scoped_refptr<ChannelEndpoint>* channel_endpoint); 54 scoped_refptr<ChannelEndpoint>* channel_endpoint);
55 55
56 // The "opposite" of |SerializeAndClose()|. (Typically this is called by 56 // The "opposite" of |SerializeAndClose()|. (Typically this is called by
57 // |Dispatcher::Deserialize()|.) 57 // |Dispatcher::Deserialize()|.)
58 static scoped_refptr<MessagePipeDispatcher> Deserialize(Channel* channel, 58 static scoped_refptr<MessagePipeDispatcher> Deserialize(Channel* channel,
59 const void* source, 59 const void* source,
60 size_t size); 60 size_t size);
61 61
62 private: 62 private:
63 friend class MessagePipeDispatcherTransport; 63 friend class MessagePipeDispatcherTransport;
64 64
65 virtual ~MessagePipeDispatcher(); 65 ~MessagePipeDispatcher() override;
66 66
67 // Gets a dumb pointer to |message_pipe_|. This must be called under the 67 // Gets a dumb pointer to |message_pipe_|. This must be called under the
68 // |Dispatcher| lock (that it's a dumb pointer is okay since it's under lock). 68 // |Dispatcher| lock (that it's a dumb pointer is okay since it's under lock).
69 // This is needed when sending handles across processes, where nontrivial, 69 // This is needed when sending handles across processes, where nontrivial,
70 // invasive work needs to be done. 70 // invasive work needs to be done.
71 MessagePipe* GetMessagePipeNoLock() const; 71 MessagePipe* GetMessagePipeNoLock() const;
72 // Similarly for the port. 72 // Similarly for the port.
73 unsigned GetPortNoLock() const; 73 unsigned GetPortNoLock() const;
74 74
75 // |Dispatcher| protected methods: 75 // |Dispatcher| protected methods:
76 virtual void CancelAllWaitersNoLock() override; 76 void CancelAllWaitersNoLock() override;
77 virtual void CloseImplNoLock() override; 77 void CloseImplNoLock() override;
78 virtual scoped_refptr<Dispatcher> 78 scoped_refptr<Dispatcher> CreateEquivalentDispatcherAndCloseImplNoLock()
79 CreateEquivalentDispatcherAndCloseImplNoLock() override; 79 override;
80 virtual MojoResult WriteMessageImplNoLock( 80 MojoResult WriteMessageImplNoLock(
81 UserPointer<const void> bytes, 81 UserPointer<const void> bytes,
82 uint32_t num_bytes, 82 uint32_t num_bytes,
83 std::vector<DispatcherTransport>* transports, 83 std::vector<DispatcherTransport>* transports,
84 MojoWriteMessageFlags flags) override; 84 MojoWriteMessageFlags flags) override;
85 virtual MojoResult ReadMessageImplNoLock(UserPointer<void> bytes, 85 MojoResult ReadMessageImplNoLock(UserPointer<void> bytes,
86 UserPointer<uint32_t> num_bytes, 86 UserPointer<uint32_t> num_bytes,
87 DispatcherVector* dispatchers, 87 DispatcherVector* dispatchers,
88 uint32_t* num_dispatchers, 88 uint32_t* num_dispatchers,
89 MojoReadMessageFlags flags) override; 89 MojoReadMessageFlags flags) override;
90 virtual HandleSignalsState GetHandleSignalsStateImplNoLock() const override; 90 HandleSignalsState GetHandleSignalsStateImplNoLock() const override;
91 virtual MojoResult AddWaiterImplNoLock( 91 MojoResult AddWaiterImplNoLock(Waiter* waiter,
92 Waiter* waiter, 92 MojoHandleSignals signals,
93 MojoHandleSignals signals, 93 uint32_t context,
94 uint32_t context, 94 HandleSignalsState* signals_state) override;
95 HandleSignalsState* signals_state) override; 95 void RemoveWaiterImplNoLock(Waiter* waiter,
96 virtual void RemoveWaiterImplNoLock( 96 HandleSignalsState* signals_state) override;
97 Waiter* waiter, 97 void StartSerializeImplNoLock(Channel* channel,
98 HandleSignalsState* signals_state) override; 98 size_t* max_size,
99 virtual void StartSerializeImplNoLock(Channel* channel, 99 size_t* max_platform_handles) override;
100 size_t* max_size, 100 bool EndSerializeAndCloseImplNoLock(
101 size_t* max_platform_handles) override;
102 virtual bool EndSerializeAndCloseImplNoLock(
103 Channel* channel, 101 Channel* channel,
104 void* destination, 102 void* destination,
105 size_t* actual_size, 103 size_t* actual_size,
106 embedder::PlatformHandleVector* platform_handles) override; 104 embedder::PlatformHandleVector* platform_handles) override;
107 105
108 // Protected by |lock()|: 106 // Protected by |lock()|:
109 scoped_refptr<MessagePipe> message_pipe_; // This will be null if closed. 107 scoped_refptr<MessagePipe> message_pipe_; // This will be null if closed.
110 unsigned port_; 108 unsigned port_;
111 109
112 DISALLOW_COPY_AND_ASSIGN(MessagePipeDispatcher); 110 DISALLOW_COPY_AND_ASSIGN(MessagePipeDispatcher);
(...skipping 13 matching lines...) Expand all
126 return static_cast<MessagePipeDispatcher*>(dispatcher()); 124 return static_cast<MessagePipeDispatcher*>(dispatcher());
127 } 125 }
128 126
129 // Copy and assign allowed. 127 // Copy and assign allowed.
130 }; 128 };
131 129
132 } // namespace system 130 } // namespace system
133 } // namespace mojo 131 } // namespace mojo
134 132
135 #endif // MOJO_EDK_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_ 133 #endif // MOJO_EDK_SYSTEM_MESSAGE_PIPE_DISPATCHER_H_
OLDNEW
« no previous file with comments | « mojo/edk/system/local_message_pipe_endpoint.h ('k') | mojo/edk/system/message_pipe_dispatcher_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698