OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 REMOTING_PROTOCOL_STREAM_CHANNEL_FACTORY_H_ | 5 #ifndef REMOTING_PROTOCOL_STREAM_CHANNEL_FACTORY_H_ |
6 #define REMOTING_PROTOCOL_STREAM_CHANNEL_FACTORY_H_ | 6 #define REMOTING_PROTOCOL_STREAM_CHANNEL_FACTORY_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/callback.h" | 10 #include "base/callback.h" |
(...skipping 11 matching lines...) Expand all Loading... |
22 class StreamChannelFactory : public base::NonThreadSafe { | 22 class StreamChannelFactory : public base::NonThreadSafe { |
23 public: | 23 public: |
24 // TODO(sergeyu): Specify connection error code when channel | 24 // TODO(sergeyu): Specify connection error code when channel |
25 // connection fails. | 25 // connection fails. |
26 typedef base::Callback<void(scoped_ptr<net::StreamSocket>)> | 26 typedef base::Callback<void(scoped_ptr<net::StreamSocket>)> |
27 ChannelCreatedCallback; | 27 ChannelCreatedCallback; |
28 | 28 |
29 StreamChannelFactory() {} | 29 StreamChannelFactory() {} |
30 | 30 |
31 // Creates new channels and calls the |callback| when then new channel is | 31 // Creates new channels and calls the |callback| when then new channel is |
32 // created and connected. The |callback| is called with NULL if connection | 32 // created and connected. The |callback| is called with nullptr if connection |
33 // failed for any reason. Callback may be called synchronously, before the | 33 // failed for any reason. Callback may be called synchronously, before the |
34 // call returns. All channels must be destroyed, and CancelChannelCreation() | 34 // call returns. All channels must be destroyed, and CancelChannelCreation() |
35 // called for any pending channels, before the factory is destroyed. | 35 // called for any pending channels, before the factory is destroyed. |
36 virtual void CreateChannel(const std::string& name, | 36 virtual void CreateChannel(const std::string& name, |
37 const ChannelCreatedCallback& callback) = 0; | 37 const ChannelCreatedCallback& callback) = 0; |
38 | 38 |
39 // Cancels a pending CreateChannel() operation for the named channel. If the | 39 // Cancels a pending CreateChannel() operation for the named channel. If the |
40 // channel creation already completed then canceling it has no effect. When | 40 // channel creation already completed then canceling it has no effect. When |
41 // shutting down this method must be called for each channel pending creation. | 41 // shutting down this method must be called for each channel pending creation. |
42 virtual void CancelChannelCreation(const std::string& name) = 0; | 42 virtual void CancelChannelCreation(const std::string& name) = 0; |
43 | 43 |
44 protected: | 44 protected: |
45 virtual ~StreamChannelFactory() {} | 45 virtual ~StreamChannelFactory() {} |
46 | 46 |
47 private: | 47 private: |
48 DISALLOW_COPY_AND_ASSIGN(StreamChannelFactory); | 48 DISALLOW_COPY_AND_ASSIGN(StreamChannelFactory); |
49 }; | 49 }; |
50 | 50 |
51 } // namespace protocol | 51 } // namespace protocol |
52 } // namespace remoting | 52 } // namespace remoting |
53 | 53 |
54 #endif // REMOTING_PROTOCOL_STREAM_CHANNEL_FACTORY_H_ | 54 #endif // REMOTING_PROTOCOL_STREAM_CHANNEL_FACTORY_H_ |
OLD | NEW |