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

Side by Side Diff: remoting/protocol/pepper_p2p_channel.cc

Issue 7200037: Channel adapter for Pepper P2P Transport API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: - Created 9 years, 6 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "remoting/protocol/pepper_p2p_channel.h"
6
7 #include "base/logging.h"
8 #include "net/base/io_buffer.h"
9 #include "net/base/net_errors.h"
10 #include "ppapi/c/pp_errors.h"
11 #include "ppapi/cpp/dev/transport_dev.h"
12 #include "ppapi/cpp/var.h"
13
14 namespace remoting {
15
16 namespace {
17
18 const char kPepperUdpProtocol[] = "udp";
Wez 2011/06/20 22:19:31 nit: Should this be kPepper[Transport]UdpProtocolN
Sergey Ulanov 2011/06/21 00:23:20 Done.
19
20 // Maps value returned by Recv() and Send() Pepper methods to net::Error.
21 int MapPepperError(int result) {
Wez 2011/06/20 22:19:31 nit: PPErrorToNetError?
Sergey Ulanov 2011/06/21 00:23:20 Done.
22 if (result > 0)
23 return result;
24
25 switch (result) {
26 case PP_OK:
27 return net::OK;
28 case PP_OK_COMPLETIONPENDING:
29 return net::ERR_IO_PENDING;
30 default:
31 return net::ERR_FAILED;
32 }
33 }
34
35 } // namespace
36
37
38 PepperP2PChannel::PepperP2PChannel(
39 pp::Instance* pp_instance,
40 const char* name,
41 const IncomingCandidateCallback& candidate_callback)
42 : candidate_callback_(candidate_callback),
43 read_callback_(NULL),
44 write_callback_(NULL) {
45 transport_.reset(
46 new pp::Transport_Dev(pp_instance, name, kPepperUdpProtocol));
47 ProcessCandidates();
48 }
49
50 PepperP2PChannel::~PepperP2PChannel() {
51 }
52
53 void PepperP2PChannel::AddRemoteCandidate(const std::string& candidate) {
Wez 2011/06/20 22:19:31 DCHECK(CalledOnValidThread())?
Sergey Ulanov 2011/06/21 00:23:20 Done.
54 transport_->ReceiveRemoteAddress(candidate);
55 }
56
57 int PepperP2PChannel::Read(net::IOBuffer* buf, int buf_len,
58 net::CompletionCallback* callback) {
59 DCHECK(CalledOnValidThread());
60 DCHECK(!read_callback_);
61 DCHECK(!read_buffer_);
62
63 int result = MapPepperError(transport_->Recv(
64 buf->data(), buf_len,
65 pp::CompletionCallback(&PepperP2PChannel::ReadCallback, this)));
66
67 if (result == net::ERR_IO_PENDING) {
68 read_callback_ = callback;
69 read_buffer_ = buf;
70 }
71
72 return result;
73 }
74
75 int PepperP2PChannel::Write(net::IOBuffer* buf, int buf_len,
76 net::CompletionCallback* callback) {
77 DCHECK(CalledOnValidThread());
78 DCHECK(!write_callback_);
79 DCHECK(!write_buffer_);
80
81 int result = MapPepperError(transport_->Send(
82 buf->data(), buf_len,
83 pp::CompletionCallback(&PepperP2PChannel::WriteCallback, this)));
84
85 if (result == net::ERR_IO_PENDING) {
86 write_callback_ = callback;
87 write_buffer_ = buf;
88 }
89
90 return result;
91 }
92
93 bool PepperP2PChannel::SetReceiveBufferSize(int32 size) {
94 DCHECK(CalledOnValidThread());
95 NOTIMPLEMENTED();
96 return false;
97 }
98
99 bool PepperP2PChannel::SetSendBufferSize(int32 size) {
100 DCHECK(CalledOnValidThread());
101 NOTIMPLEMENTED();
102 return false;
103 }
104
105 void PepperP2PChannel::ProcessCandidates() {
106 pp::Var address;
107 while (true) {
108 int result = transport_->GetNextAddress(
109 &address,
110 pp::CompletionCallback(&PepperP2PChannel::NextAddressCallback, this));
111 if (result == PP_OK_COMPLETIONPENDING)
112 break;
113
114 if (result == PP_OK) {
115 candidate_callback_.Run(address.AsString());
116 } else {
117 LOG(ERROR) << "GetNextAddress() returned an error " << result;
Wez 2011/06/20 22:19:31 Are there any failure modes for GetNextAddress() t
Sergey Ulanov 2011/06/21 00:23:20 Yes, it returns PP_ERROR_NOINTERFACE in that case.
118 break;
119 }
120 }
121 }
122
123 // static
124 void PepperP2PChannel::NextAddressCallback(void* data, int32_t result) {
125 PepperP2PChannel* channel = reinterpret_cast<PepperP2PChannel*>(data);
126 DCHECK(channel->CalledOnValidThread());
127 channel->ProcessCandidates();
128 }
129
130 // static
131 void PepperP2PChannel::ReadCallback(void* data, int32_t result) {
132 PepperP2PChannel* channel = reinterpret_cast<PepperP2PChannel*>(data);
133 DCHECK(channel->CalledOnValidThread());
134 DCHECK(channel->read_callback_);
135 DCHECK(channel->read_buffer_);
136 net::CompletionCallback* callback = channel->read_callback_;
137 channel->read_callback_ = NULL;
138 channel->read_buffer_ = NULL;
139 callback->Run(result);
Wez 2011/06/20 22:19:31 The net::Socket interface allows for the Socket be
Sergey Ulanov 2011/06/21 00:23:20 Yes, Pepper implementation should be able to handl
140 }
141
142 // static
143 void PepperP2PChannel::WriteCallback(void* data, int32_t result) {
144 PepperP2PChannel* channel = reinterpret_cast<PepperP2PChannel*>(data);
145 DCHECK(channel->CalledOnValidThread());
146 DCHECK(channel->write_callback_);
147 DCHECK(channel->write_buffer_);
148 net::CompletionCallback* callback = channel->write_callback_;
149 channel->write_callback_ = NULL;
150 channel->write_buffer_ = NULL;
151 callback->Run(result);
152 }
153
154 } // namespace remoting
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698