| OLD | NEW | 
|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 #include "remoting/client/rectangle_update_decoder.h" | 5 #include "remoting/client/rectangle_update_decoder.h" | 
| 6 | 6 | 
| 7 #include "base/logging.h" | 7 #include "base/logging.h" | 
| 8 #include "base/message_loop.h" | 8 #include "base/message_loop.h" | 
| 9 #include "media/base/callback.h" | 9 #include "media/base/callback.h" | 
| 10 #include "remoting/base/decoder.h" | 10 #include "remoting/base/decoder.h" | 
| 11 #include "remoting/base/decoder_verbatim.h" | 11 #include "remoting/base/decoder_row_based.h" | 
| 12 #include "remoting/base/decoder_zlib.h" |  | 
| 13 #include "remoting/base/protocol/chromotocol.pb.h" | 12 #include "remoting/base/protocol/chromotocol.pb.h" | 
|  | 13 #include "remoting/base/protocol_util.h" | 
| 14 #include "remoting/base/tracer.h" | 14 #include "remoting/base/tracer.h" | 
| 15 #include "remoting/client/frame_consumer.h" | 15 #include "remoting/client/frame_consumer.h" | 
| 16 | 16 | 
| 17 using media::AutoTaskRunner; | 17 using media::AutoTaskRunner; | 
| 18 | 18 | 
| 19 namespace remoting { | 19 namespace remoting { | 
| 20 | 20 | 
| 21 namespace { | 21 namespace { | 
| 22 | 22 | 
| 23 class PartialFrameCleanup : public Task { | 23 class PartialFrameCleanup : public Task { | 
| (...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 188     // | 188     // | 
| 189     // For now though, assume that only one encoding is used throughout. | 189     // For now though, assume that only one encoding is used throughout. | 
| 190     // | 190     // | 
| 191     // Note, this may be as simple as just deleting the current decoder. | 191     // Note, this may be as simple as just deleting the current decoder. | 
| 192     // However, we need to verify the flushing semantics of the decoder first. | 192     // However, we need to verify the flushing semantics of the decoder first. | 
| 193     CHECK(decoder_->Encoding() == format.encoding()); | 193     CHECK(decoder_->Encoding() == format.encoding()); | 
| 194   } else { | 194   } else { | 
| 195     // Initialize a new decoder based on this message encoding. | 195     // Initialize a new decoder based on this message encoding. | 
| 196     if (format.encoding() == EncodingNone) { | 196     if (format.encoding() == EncodingNone) { | 
| 197       TraceContext::tracer()->PrintString("Creating Verbatim decoder."); | 197       TraceContext::tracer()->PrintString("Creating Verbatim decoder."); | 
| 198       decoder_.reset(new DecoderVerbatim()); | 198       decoder_.reset(DecoderRowBased::CreateVerbatimDecoder()); | 
| 199     } else if (format.encoding() == EncodingZlib) { | 199     } else if (format.encoding() == EncodingZlib) { | 
| 200       TraceContext::tracer()->PrintString("Creating Zlib decoder"); | 200       TraceContext::tracer()->PrintString("Creating Zlib decoder"); | 
| 201       decoder_.reset(new DecoderZlib()); | 201       decoder_.reset(DecoderRowBased::CreateZlibDecoder()); | 
| 202     } else { | 202     } else { | 
| 203       NOTREACHED() << "Invalid Encoding found: " << format.encoding(); | 203       NOTREACHED() << "Invalid Encoding found: " << format.encoding(); | 
| 204     } | 204     } | 
| 205   } | 205   } | 
| 206 | 206 | 
| 207   // TODO(ajwong): This can happen in the face of corrupt input data.  Figure | 207   // TODO(ajwong): This can happen in the face of corrupt input data.  Figure | 
| 208   // out the right behavior and make this more resilient. | 208   // out the right behavior and make this more resilient. | 
| 209   CHECK(updated_rects_.empty()); | 209   CHECK(updated_rects_.empty()); | 
| 210 | 210 | 
| 211   gfx::Rect rectangle_size(format.x(), format.y(), | 211   gfx::Rect rectangle_size(format.x(), format.y(), | 
| 212                            format.width(), format.height()); | 212                            format.width(), format.height()); | 
| 213   updated_rects_.push_back(rectangle_size); | 213   updated_rects_.push_back(rectangle_size); | 
| 214   decoder_->Initialize(frame_, rectangle_size); | 214   decoder_->Initialize(frame_, rectangle_size, | 
|  | 215                        GetBytesPerPixel(format.pixel_format())); | 
| 215   TraceContext::tracer()->PrintString("Decoder is Initialized"); | 216   TraceContext::tracer()->PrintString("Decoder is Initialized"); | 
| 216 } | 217 } | 
| 217 | 218 | 
| 218 }  // namespace remoting | 219 }  // namespace remoting | 
| OLD | NEW | 
|---|