Index: media/webm/webm_stream_parser.cc |
diff --git a/media/webm/webm_stream_parser.cc b/media/webm/webm_stream_parser.cc |
index 828d3181ac9724c1ffc8a2c0762b8702ff349f85..7fb71556025aa87a94e52ba3cf3144c2d7399956 100644 |
--- a/media/webm/webm_stream_parser.cc |
+++ b/media/webm/webm_stream_parser.cc |
@@ -29,8 +29,7 @@ WebMStreamParser::~WebMStreamParser() { |
void WebMStreamParser::Init(const InitCB& init_cb, |
const NewConfigCB& config_cb, |
- const NewBuffersCB& audio_cb, |
- const NewBuffersCB& video_cb, |
+ const NewBuffersCB& new_buffers_cb, |
const NewTextBuffersCB& text_cb, |
const NeedKeyCB& need_key_cb, |
const AddTextTrackCB& add_text_track_cb, |
@@ -41,7 +40,7 @@ void WebMStreamParser::Init(const InitCB& init_cb, |
DCHECK(init_cb_.is_null()); |
DCHECK(!init_cb.is_null()); |
DCHECK(!config_cb.is_null()); |
- DCHECK(!audio_cb.is_null() || !video_cb.is_null()); |
+ DCHECK(!new_buffers_cb.is_null()); |
DCHECK(!text_cb.is_null()); |
DCHECK(!need_key_cb.is_null()); |
DCHECK(!new_segment_cb.is_null()); |
@@ -50,8 +49,7 @@ void WebMStreamParser::Init(const InitCB& init_cb, |
ChangeState(kParsingHeaders); |
init_cb_ = init_cb; |
config_cb_ = config_cb; |
- audio_cb_ = audio_cb; |
- video_cb_ = video_cb; |
+ new_buffers_cb_ = new_buffers_cb; |
text_cb_ = text_cb; |
need_key_cb_ = need_key_cb; |
add_text_track_cb_ = add_text_track_cb; |
@@ -291,11 +289,10 @@ int WebMStreamParser::ParseCluster(const uint8* data, int size) { |
waiting_for_buffers_ = false; |
} |
- if (!audio_buffers.empty() && !audio_cb_.Run(audio_buffers)) |
- return -1; |
- |
- if (!video_buffers.empty() && !video_cb_.Run(video_buffers)) |
+ if ((!audio_buffers.empty() || !video_buffers.empty()) && |
+ !new_buffers_cb_.Run(audio_buffers, video_buffers)) { |
return -1; |
+ } |
WebMClusterParser::TextTrackIterator text_track_iter = |
cluster_parser_->CreateTextTrackIterator(); |