blob: c86862f7fa4e4dd1ebf6f9fd9d68da5142e4debd [file] [log] [blame]
// Copyright 2014 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 "media/filters/decoder_stream_traits.h"
#include "base/logging.h"
#include "media/base/audio_buffer.h"
#include "media/base/audio_decoder.h"
#include "media/base/audio_decoder_config.h"
#include "media/base/video_decoder.h"
#include "media/base/video_decoder_config.h"
#include "media/base/video_frame.h"
namespace media {
std::string DecoderStreamTraits<DemuxerStream::AUDIO>::ToString() {
return "Audio";
}
void DecoderStreamTraits<DemuxerStream::AUDIO>::Initialize(
DecoderType* decoder,
const DecoderConfigType& config,
bool low_delay,
const PipelineStatusCB& status_cb,
const OutputCB& output_cb) {
decoder->Initialize(config, status_cb, output_cb);
}
bool DecoderStreamTraits<DemuxerStream::AUDIO>::FinishInitialization(
const StreamInitCB& init_cb,
DecoderType* decoder,
DemuxerStream* stream) {
DCHECK(stream);
if (!decoder) {
init_cb.Run(false);
return false;
}
init_cb.Run(true);
return true;
}
void DecoderStreamTraits<DemuxerStream::AUDIO>::ReportStatistics(
const StatisticsCB& statistics_cb,
int bytes_decoded) {
PipelineStatistics statistics;
statistics.audio_bytes_decoded = bytes_decoded;
statistics_cb.Run(statistics);
}
DecoderStreamTraits<DemuxerStream::AUDIO>::DecoderConfigType
DecoderStreamTraits<DemuxerStream::AUDIO>::GetDecoderConfig(
DemuxerStream& stream) {
return stream.audio_decoder_config();
}
scoped_refptr<DecoderStreamTraits<DemuxerStream::AUDIO>::OutputType>
DecoderStreamTraits<DemuxerStream::AUDIO>::CreateEOSOutput() {
return OutputType::CreateEOSBuffer();
}
std::string DecoderStreamTraits<DemuxerStream::VIDEO>::ToString() {
return "Video";
}
void DecoderStreamTraits<DemuxerStream::VIDEO>::Initialize(
DecoderType* decoder,
const DecoderConfigType& config,
bool low_delay,
const PipelineStatusCB& status_cb,
const OutputCB& output_cb) {
decoder->Initialize(config, low_delay, status_cb, output_cb);
}
bool DecoderStreamTraits<DemuxerStream::VIDEO>::FinishInitialization(
const StreamInitCB& init_cb,
DecoderType* decoder,
DemuxerStream* stream) {
DCHECK(stream);
if (!decoder) {
init_cb.Run(false);
return false;
}
if (decoder->NeedsBitstreamConversion())
stream->EnableBitstreamConverter();
init_cb.Run(true);
return true;
}
void DecoderStreamTraits<DemuxerStream::VIDEO>::ReportStatistics(
const StatisticsCB& statistics_cb,
int bytes_decoded) {
PipelineStatistics statistics;
statistics.video_bytes_decoded = bytes_decoded;
statistics_cb.Run(statistics);
}
DecoderStreamTraits<DemuxerStream::VIDEO>::DecoderConfigType
DecoderStreamTraits<DemuxerStream::VIDEO>::GetDecoderConfig(
DemuxerStream& stream) {
return stream.video_decoder_config();
}
scoped_refptr<DecoderStreamTraits<DemuxerStream::VIDEO>::OutputType>
DecoderStreamTraits<DemuxerStream::VIDEO>::CreateEOSOutput() {
return OutputType::CreateEOSFrame();
}
} // namespace media