Index: media/cast/framer/frame_buffer.cc |
diff --git a/media/cast/framer/frame_buffer.cc b/media/cast/framer/frame_buffer.cc |
index 2bfdeb5166907de08f323be1ee345dad937efcee..90b97bc3e4fc37dc049c8aff2da681fb30a5290f 100644 |
--- a/media/cast/framer/frame_buffer.cc |
+++ b/media/cast/framer/frame_buffer.cc |
@@ -13,7 +13,6 @@ FrameBuffer::FrameBuffer() |
: frame_id_(0), |
max_packet_id_(0), |
num_packets_received_(0), |
- is_key_frame_(false), |
total_data_size_(0), |
last_referenced_frame_id_(0), |
packets_() {} |
@@ -27,8 +26,12 @@ void FrameBuffer::InsertPacket(const uint8* payload_data, |
if (packets_.empty()) { |
frame_id_ = rtp_header.frame_id; |
max_packet_id_ = rtp_header.max_packet_id; |
- is_key_frame_ = rtp_header.is_key_frame; |
- last_referenced_frame_id_ = rtp_header.reference_frame_id; |
+ if (rtp_header.is_key_frame) { |
+ DCHECK_EQ(rtp_header.frame_id, rtp_header.reference_frame_id); |
+ last_referenced_frame_id_ = rtp_header.frame_id; |
+ } else { |
+ last_referenced_frame_id_ = rtp_header.reference_frame_id; |
+ } |
rtp_timestamp_ = rtp_header.rtp_timestamp; |
} |
// Is this the correct frame? |
@@ -57,44 +60,21 @@ bool FrameBuffer::Complete() const { |
return num_packets_received_ - 1 == max_packet_id_; |
} |
-bool FrameBuffer::GetEncodedAudioFrame( |
- transport::EncodedAudioFrame* audio_frame) const { |
+bool FrameBuffer::AssembleEncodedFrame(transport::EncodedFrame* frame) const { |
if (!Complete()) |
return false; |
// Frame is complete -> construct. |
- audio_frame->frame_id = frame_id_; |
- audio_frame->rtp_timestamp = rtp_timestamp_; |
+ frame->frame_id = frame_id_; |
+ frame->base_frame_id = last_referenced_frame_id_; |
+ frame->rtp_timestamp = rtp_timestamp_; |
// Build the data vector. |
- audio_frame->data.clear(); |
- audio_frame->data.reserve(total_data_size_); |
+ frame->data.clear(); |
+ frame->data.reserve(total_data_size_); |
PacketMap::const_iterator it; |
- for (it = packets_.begin(); it != packets_.end(); ++it) { |
- audio_frame->data.insert( |
- audio_frame->data.end(), it->second.begin(), it->second.end()); |
- } |
- return true; |
-} |
- |
-bool FrameBuffer::GetEncodedVideoFrame( |
- transport::EncodedVideoFrame* video_frame) const { |
- if (!Complete()) |
- return false; |
- // Frame is complete -> construct. |
- video_frame->key_frame = is_key_frame_; |
- video_frame->frame_id = frame_id_; |
- video_frame->last_referenced_frame_id = last_referenced_frame_id_; |
- video_frame->rtp_timestamp = rtp_timestamp_; |
- |
- // Build the data vector. |
- video_frame->data.clear(); |
- video_frame->data.reserve(total_data_size_); |
- PacketMap::const_iterator it; |
- for (it = packets_.begin(); it != packets_.end(); ++it) { |
- video_frame->data.insert( |
- video_frame->data.end(), it->second.begin(), it->second.end()); |
- } |
+ for (it = packets_.begin(); it != packets_.end(); ++it) |
+ frame->data.insert(frame->data.end(), it->second.begin(), it->second.end()); |
return true; |
} |