summaryrefslogtreecommitdiffstats
path: root/remoting/protocol/protobuf_video_writer.cc
diff options
context:
space:
mode:
authorsergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-08-09 22:31:43 +0000
committersergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-08-09 22:31:43 +0000
commit19c28bfec867442cc416fa5a3108418e01c714fb (patch)
treee832b7ec5f9792c27152470d1b44046ff5a2fc6f /remoting/protocol/protobuf_video_writer.cc
parent8ec98cd25edd4f9329c0acefd98d4b6f69e4632d (diff)
downloadchromium_src-19c28bfec867442cc416fa5a3108418e01c714fb.zip
chromium_src-19c28bfec867442cc416fa5a3108418e01c714fb.tar.gz
chromium_src-19c28bfec867442cc416fa5a3108418e01c714fb.tar.bz2
Remove video_channel() from Session interface
BUG=None TEST=Unittests. Review URL: http://codereview.chromium.org/7508044 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@96089 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'remoting/protocol/protobuf_video_writer.cc')
-rw-r--r--remoting/protocol/protobuf_video_writer.cc30
1 files changed, 27 insertions, 3 deletions
diff --git a/remoting/protocol/protobuf_video_writer.cc b/remoting/protocol/protobuf_video_writer.cc
index a03a4e6..2d37f65 100644
--- a/remoting/protocol/protobuf_video_writer.cc
+++ b/remoting/protocol/protobuf_video_writer.cc
@@ -1,10 +1,13 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "remoting/protocol/protobuf_video_writer.h"
+#include "base/bind.h"
#include "base/task.h"
+#include "net/socket/stream_socket.h"
+#include "remoting/base/constants.h"
#include "remoting/proto/video.pb.h"
#include "remoting/protocol/rtp_writer.h"
#include "remoting/protocol/session.h"
@@ -17,14 +20,35 @@ ProtobufVideoWriter::ProtobufVideoWriter() { }
ProtobufVideoWriter::~ProtobufVideoWriter() { }
-void ProtobufVideoWriter::Init(protocol::Session* session) {
+void ProtobufVideoWriter::Init(protocol::Session* session,
+ const InitializedCallback& callback) {
+ initialized_callback_ = callback;
+
+ session->CreateStreamChannel(
+ kVideoChannelName,
+ base::Bind(&ProtobufVideoWriter::OnChannelReady, base::Unretained(this)));
+}
+
+void ProtobufVideoWriter::OnChannelReady(const std::string& name,
+ net::StreamSocket* socket) {
+ DCHECK_EQ(name, std::string(kVideoChannelName));
+ if (!socket) {
+ initialized_callback_.Run(false);
+ return;
+ }
+
+ DCHECK(!channel_.get());
+ channel_.reset(socket);
buffered_writer_ = new BufferedSocketWriter();
// TODO(sergeyu): Provide WriteFailedCallback for the buffered writer.
- buffered_writer_->Init(session->video_channel(), NULL);
+ buffered_writer_->Init(socket, NULL);
+
+ initialized_callback_.Run(true);
}
void ProtobufVideoWriter::Close() {
buffered_writer_->Close();
+ channel_.reset();
}
void ProtobufVideoWriter::ProcessVideoPacket(const VideoPacket* packet,