summaryrefslogtreecommitdiffstats
path: root/media
diff options
context:
space:
mode:
authorscherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-26 23:49:24 +0000
committerscherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-26 23:49:24 +0000
commit92b0417bd59b83f6a4908a6bb19ef833852faf08 (patch)
tree928d80c5d866f659fe6977f7d8817eeea8319b25 /media
parent9e717c32ba0e9710d06d2f3fac3a291f3d4e4ec5 (diff)
downloadchromium_src-92b0417bd59b83f6a4908a6bb19ef833852faf08.zip
chromium_src-92b0417bd59b83f6a4908a6bb19ef833852faf08.tar.gz
chromium_src-92b0417bd59b83f6a4908a6bb19ef833852faf08.tar.bz2
Lots of files touched for a very simple change. Everywhere we used a const MediaFormat* we now
use a const MediaFormat&. This makes for simpler code and for better pointer reference safety. Review URL: http://codereview.chromium.org/42635 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@12623 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'media')
-rw-r--r--media/base/factory.h14
-rw-r--r--media/base/filters.h16
-rw-r--r--media/base/mock_media_filters.h24
-rw-r--r--media/base/pipeline_impl.cc11
-rw-r--r--media/base/pipeline_impl.h4
-rw-r--r--media/filters/audio_renderer_base.cc12
-rw-r--r--media/filters/audio_renderer_base.h6
-rw-r--r--media/filters/audio_renderer_impl.cc4
-rw-r--r--media/filters/audio_renderer_impl.h4
-rw-r--r--media/filters/decoder_base.h2
-rw-r--r--media/filters/ffmpeg_audio_decoder.cc2
-rw-r--r--media/filters/ffmpeg_audio_decoder.h2
-rw-r--r--media/filters/ffmpeg_demuxer.cc4
-rw-r--r--media/filters/ffmpeg_demuxer.h2
-rw-r--r--media/filters/ffmpeg_demuxer_unittest.cc44
-rw-r--r--media/filters/ffmpeg_video_decoder.cc2
-rw-r--r--media/filters/ffmpeg_video_decoder.h2
-rw-r--r--media/filters/file_data_source.cc4
-rw-r--r--media/filters/file_data_source.h2
-rw-r--r--media/filters/file_data_source_unittest.cc2
-rw-r--r--media/filters/null_audio_renderer.cc4
-rw-r--r--media/filters/null_audio_renderer.h4
-rw-r--r--media/filters/test_video_decoder.h12
-rw-r--r--media/filters/test_video_renderer.h2
-rw-r--r--media/filters/video_renderer_base.cc14
-rw-r--r--media/filters/video_renderer_base.h4
26 files changed, 104 insertions, 99 deletions
diff --git a/media/base/factory.h b/media/base/factory.h
index 66bc377..91e5bc4 100644
--- a/media/base/factory.h
+++ b/media/base/factory.h
@@ -24,7 +24,7 @@
//
// Returns true and assigns |filter_out| if the filter was created, false
// and assigns NULL otherwise.
-// static bool Create(MediaFormat* media_format, YourFilterType** filter_out);
+// static bool Create(MediaFormat& media_format, YourFilterType** filter_out);
//
#ifndef MEDIA_BASE_FACTORY_H_
@@ -47,7 +47,7 @@ class FilterFactory : public base::RefCountedThreadSafe<FilterFactory> {
// If the factory does not support the specific filter type or does not
// support the |media_format| then NULL is returned.
template <class Filter>
- Filter* Create(const MediaFormat* media_format) {
+ Filter* Create(const MediaFormat& media_format) {
return reinterpret_cast<Filter*>(Create(Filter::filter_type(),
media_format));
}
@@ -63,7 +63,7 @@ class FilterFactory : public base::RefCountedThreadSafe<FilterFactory> {
// It is assumed that the MediaFilter interface can be safely cast to the
// corresponding interface type (i.e., FILTER_AUDIO_DECODER -> AudioDecoder).
virtual MediaFilter* Create(FilterType filter_type,
- const MediaFormat* media_format) = 0;
+ const MediaFormat& media_format) = 0;
friend class base::RefCountedThreadSafe<FilterFactory>;
virtual ~FilterFactory() {}
@@ -82,7 +82,7 @@ class FilterFactoryCollection : public FilterFactory {
protected:
// Attempts to create a filter by walking down the list of filter factories.
- MediaFilter* Create(FilterType filter_type, const MediaFormat* media_format) {
+ MediaFilter* Create(FilterType filter_type, const MediaFormat& media_format) {
MediaFilter* filter = NULL;
for (FactoryVector::iterator factory = factories_.begin();
!filter && factory != factories_.end();
@@ -113,7 +113,7 @@ class FilterFactoryImpl0 : public FilterFactory {
protected:
virtual MediaFilter* Create(FilterType filter_type,
- const MediaFormat* media_format) {
+ const MediaFormat& media_format) {
Filter* filter = NULL;
if (Filter::filter_type() == filter_type &&
Filter::IsMediaFormatSupported(media_format)) {
@@ -142,7 +142,7 @@ class FilterFactoryImpl1 : public FilterFactory {
protected:
virtual MediaFilter* Create(FilterType filter_type,
- const MediaFormat* media_format) {
+ const MediaFormat& media_format) {
Filter* filter = NULL;
if (Filter::filter_type() == filter_type &&
Filter::IsMediaFormatSupported(media_format)) {
@@ -178,7 +178,7 @@ class InstanceFilterFactory : public FilterFactory {
protected:
virtual MediaFilter* Create(FilterType filter_type,
- const MediaFormat* media_format) {
+ const MediaFormat& media_format) {
if (Filter::filter_type() == filter_type &&
Filter::IsMediaFormatSupported(media_format)) {
if (!create_called_) {
diff --git a/media/base/filters.h b/media/base/filters.h
index 7ceb9e8..6290e28 100644
--- a/media/base/filters.h
+++ b/media/base/filters.h
@@ -97,9 +97,9 @@ class DataSource : public MediaFilter {
return FILTER_DATA_SOURCE;
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format) {
+ static bool IsMediaFormatSupported(const MediaFormat& media_format) {
std::string mime_type;
- return (media_format->GetAsString(MediaFormat::kMimeType, &mime_type) &&
+ return (media_format.GetAsString(MediaFormat::kMimeType, &mime_type) &&
mime_type == mime_type::kURL);
}
@@ -109,7 +109,7 @@ class DataSource : public MediaFilter {
virtual bool Initialize(const std::string& url) = 0;
// Returns the MediaFormat for this filter.
- virtual const MediaFormat* GetMediaFormat() = 0;
+ virtual const MediaFormat& media_format() = 0;
// Read the given amount of bytes into data, returns the number of bytes read
// if successful, kReadError otherwise.
@@ -134,9 +134,9 @@ class Demuxer : public MediaFilter {
return FILTER_DEMUXER;
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format) {
+ static bool IsMediaFormatSupported(const MediaFormat& media_format) {
std::string mime_type;
- return (media_format->GetAsString(MediaFormat::kMimeType, &mime_type) &&
+ return (media_format.GetAsString(MediaFormat::kMimeType, &mime_type) &&
mime_type == mime_type::kApplicationOctetStream);
}
@@ -154,7 +154,7 @@ class Demuxer : public MediaFilter {
class DemuxerStream : public base::RefCountedThreadSafe<DemuxerStream> {
public:
// Returns the MediaFormat for this filter.
- virtual const MediaFormat* GetMediaFormat() = 0;
+ virtual const MediaFormat& media_format() = 0;
// Schedules a read and takes ownership of the given buffer.
virtual void Read(Assignable<Buffer>* buffer) = 0;
@@ -198,7 +198,7 @@ class VideoDecoder : public MediaFilter {
virtual bool Initialize(DemuxerStream* demuxer_stream) = 0;
// Returns the MediaFormat for this filter.
- virtual const MediaFormat* GetMediaFormat() = 0;
+ virtual const MediaFormat& media_format() = 0;
// Schedules a read and takes ownership of the given buffer.
virtual void Read(Assignable<VideoFrame>* video_frame) = 0;
@@ -219,7 +219,7 @@ class AudioDecoder : public MediaFilter {
virtual bool Initialize(DemuxerStream* demuxer_stream) = 0;
// Returns the MediaFormat for this filter.
- virtual const MediaFormat* GetMediaFormat() = 0;
+ virtual const MediaFormat& media_format() = 0;
// Schedules a read and takes ownership of the given buffer.
virtual void Read(Assignable<Buffer>* buffer) = 0;
diff --git a/media/base/mock_media_filters.h b/media/base/mock_media_filters.h
index 4f12c00..4695a65 100644
--- a/media/base/mock_media_filters.h
+++ b/media/base/mock_media_filters.h
@@ -124,8 +124,8 @@ class MockDataSource : public DataSource {
}
}
- virtual const MediaFormat* GetMediaFormat() {
- return &media_format_;
+ virtual const MediaFormat& media_format() {
+ return media_format_;
}
virtual size_t Read(uint8* data, size_t size) {
@@ -210,8 +210,8 @@ class MockDemuxerStream : public DemuxerStream {
}
// Implementation of DemuxerStream.
- virtual const MediaFormat* GetMediaFormat() {
- return &media_format_;
+ virtual const MediaFormat& media_format() {
+ return media_format_;
}
virtual void Read(Assignable<Buffer>* buffer) {
@@ -299,7 +299,7 @@ class MockAudioDecoder : public AudioDecoder {
const MockFilterConfig*>(config);
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format) {
+ static bool IsMediaFormatSupported(const MediaFormat& media_format) {
return true; // TODO(ralphl): check for a supported format.
}
@@ -317,8 +317,8 @@ class MockAudioDecoder : public AudioDecoder {
return true;
}
- virtual const MediaFormat* GetMediaFormat() {
- return &media_format_;
+ virtual const MediaFormat& media_format() {
+ return media_format_;
}
virtual void Read(Assignable<Buffer>* buffer) {
@@ -343,7 +343,7 @@ class MockAudioRenderer : public AudioRenderer {
const MockFilterConfig*>(config);
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format) {
+ static bool IsMediaFormatSupported(const MediaFormat& media_format) {
return true; // TODO(ralphl): check for a supported format
}
@@ -375,7 +375,7 @@ class MockVideoDecoder : public VideoDecoder {
const MockFilterConfig*>(config);
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format) {
+ static bool IsMediaFormatSupported(const MediaFormat& media_format) {
return true; // TODO(ralphl): check for a supported format.
}
@@ -425,8 +425,8 @@ class MockVideoDecoder : public VideoDecoder {
return true;
}
- virtual const MediaFormat* GetMediaFormat() {
- return &media_format_;
+ virtual const MediaFormat& media_format() {
+ return media_format_;
}
virtual void Read(Assignable<VideoFrame>* buffer) {
@@ -482,7 +482,7 @@ class MockVideoRenderer : public VideoRenderer {
const MockFilterConfig*>(config);
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format) {
+ static bool IsMediaFormatSupported(const MediaFormat& media_format) {
return true; // TODO(ralphl): check for a supported format
}
diff --git a/media/base/pipeline_impl.cc b/media/base/pipeline_impl.cc
index 3e3a40d..a36da6c 100644
--- a/media/base/pipeline_impl.cc
+++ b/media/base/pipeline_impl.cc
@@ -418,13 +418,12 @@ void PipelineThread::Render(FilterFactory* filter_factory, Demuxer* demuxer) {
const std::string major_mime_type = Decoder::major_mime_type();
const int num_outputs = demuxer->GetNumberOfStreams();
for (int i = 0; i < num_outputs; ++i) {
- scoped_refptr<DemuxerStream> demuxer_stream = demuxer->GetStream(i);
- const MediaFormat* stream_format = demuxer_stream->GetMediaFormat();
+ scoped_refptr<DemuxerStream> stream = demuxer->GetStream(i);
std::string value;
- if (stream_format->GetAsString(MediaFormat::kMimeType, &value) &&
+ if (stream->media_format().GetAsString(MediaFormat::kMimeType, &value) &&
0 == value.compare(0, major_mime_type.length(), major_mime_type)) {
scoped_refptr<Decoder> decoder =
- CreateFilter<Decoder, DemuxerStream>(filter_factory, demuxer_stream);
+ CreateFilter<Decoder, DemuxerStream>(filter_factory, stream);
if (PipelineOk()) {
DCHECK(decoder);
CreateFilter<Renderer, Decoder>(filter_factory, decoder);
@@ -500,7 +499,7 @@ template <class Filter, class Source>
scoped_refptr<Filter> PipelineThread::CreateFilter(
FilterFactory* filter_factory,
Source source,
- const MediaFormat* media_format) {
+ const MediaFormat& media_format) {
DCHECK(PipelineOk());
scoped_refptr<Filter> filter = filter_factory->Create<Filter>(media_format);
if (!filter) {
@@ -549,7 +548,7 @@ scoped_refptr<DataSource> PipelineThread::CreateDataSource(
MediaFormat url_format;
url_format.SetAsString(MediaFormat::kMimeType, mime_type::kURL);
url_format.SetAsString(MediaFormat::kURL, url);
- return CreateFilter<DataSource>(filter_factory, url, &url_format);
+ return CreateFilter<DataSource>(filter_factory, url, url_format);
}
// Called as a result of destruction of the thread.
diff --git a/media/base/pipeline_impl.h b/media/base/pipeline_impl.h
index a5b8c0e..c4c4393 100644
--- a/media/base/pipeline_impl.h
+++ b/media/base/pipeline_impl.h
@@ -266,7 +266,7 @@ class PipelineThread : public base::RefCountedThreadSafe<PipelineThread>,
template <class Filter, class Source>
scoped_refptr<Filter> CreateFilter(FilterFactory* filter_factory,
Source source,
- const MediaFormat* source_media_format);
+ const MediaFormat& source_media_format);
// Creates a Filter and initilizes it with the given |source|. If a Filter
// could not be created or an error occurred, this metod returns NULL and the
@@ -278,7 +278,7 @@ class PipelineThread : public base::RefCountedThreadSafe<PipelineThread>,
Source* source) {
return CreateFilter<Filter, Source*>(filter_factory,
source,
- source->GetMediaFormat());
+ source->media_format());
}
// Creates a DataSource (the first filter in a pipeline), and initializes it
diff --git a/media/filters/audio_renderer_base.cc b/media/filters/audio_renderer_base.cc
index 880ca37..a444ba6 100644
--- a/media/filters/audio_renderer_base.cc
+++ b/media/filters/audio_renderer_base.cc
@@ -52,7 +52,7 @@ bool AudioRendererBase::Initialize(AudioDecoder* decoder) {
}
// Defer initialization until all scheduled reads have completed.
- return OnInitialize(decoder_->GetMediaFormat());
+ return OnInitialize(decoder_->media_format());
}
void AudioRendererBase::OnAssignment(Buffer* buffer_in) {
@@ -138,16 +138,16 @@ void AudioRendererBase::ScheduleRead() {
}
// static
-bool AudioRendererBase::ParseMediaFormat(const MediaFormat* media_format,
+bool AudioRendererBase::ParseMediaFormat(const MediaFormat& media_format,
int* channels_out,
int* sample_rate_out,
int* sample_bits_out) {
// TODO(scherkus): might be handy to support NULL parameters.
std::string mime_type;
- return media_format->GetAsString(MediaFormat::kMimeType, &mime_type) &&
- media_format->GetAsInteger(MediaFormat::kChannels, channels_out) &&
- media_format->GetAsInteger(MediaFormat::kSampleRate, sample_rate_out) &&
- media_format->GetAsInteger(MediaFormat::kSampleBits, sample_bits_out) &&
+ return media_format.GetAsString(MediaFormat::kMimeType, &mime_type) &&
+ media_format.GetAsInteger(MediaFormat::kChannels, channels_out) &&
+ media_format.GetAsInteger(MediaFormat::kSampleRate, sample_rate_out) &&
+ media_format.GetAsInteger(MediaFormat::kSampleBits, sample_bits_out) &&
mime_type.compare(mime_type::kUncompressedAudio) == 0;
}
diff --git a/media/filters/audio_renderer_base.h b/media/filters/audio_renderer_base.h
index fd371e6..6553b12 100644
--- a/media/filters/audio_renderer_base.h
+++ b/media/filters/audio_renderer_base.h
@@ -43,13 +43,13 @@ class AudioRendererBase : public AudioRenderer {
static const size_t kDefaultMaxQueueSize;
// Only allow a factory to create this class.
- AudioRendererBase(size_t max_queue_size);
+ explicit AudioRendererBase(size_t max_queue_size);
virtual ~AudioRendererBase();
// Called by Initialize(). |media_format| is the format of the AudioDecoder.
// Subclasses should return true if they were able to initialize, false
// otherwise.
- virtual bool OnInitialize(const MediaFormat* media_format) = 0;
+ virtual bool OnInitialize(const MediaFormat& media_format) = 0;
// Called by Stop(). Subclasses should perform any necessary cleanup during
// this time, such as stopping any running threads.
@@ -70,7 +70,7 @@ class AudioRendererBase : public AudioRenderer {
// Helper to parse a media format and return whether we were successful
// retrieving all the information we care about.
- static bool ParseMediaFormat(const MediaFormat* media_format,
+ static bool ParseMediaFormat(const MediaFormat& media_format,
int* channels_out, int* sample_rate_out,
int* sample_bits_out);
diff --git a/media/filters/audio_renderer_impl.cc b/media/filters/audio_renderer_impl.cc
index 7b66e14..55a1096 100644
--- a/media/filters/audio_renderer_impl.cc
+++ b/media/filters/audio_renderer_impl.cc
@@ -25,7 +25,7 @@ AudioRendererImpl::~AudioRendererImpl() {
}
bool AudioRendererImpl::IsMediaFormatSupported(
- const MediaFormat* media_format) {
+ const MediaFormat& media_format) {
int channels;
int sample_rate;
int sample_bits;
@@ -66,7 +66,7 @@ void AudioRendererImpl::OnError(AudioOutputStream* stream, int code) {
NOTIMPLEMENTED();
}
-bool AudioRendererImpl::OnInitialize(const MediaFormat* media_format) {
+bool AudioRendererImpl::OnInitialize(const MediaFormat& media_format) {
// Parse out audio parameters.
int channels;
int sample_rate;
diff --git a/media/filters/audio_renderer_impl.h b/media/filters/audio_renderer_impl.h
index 85ebca0..b7e551b 100644
--- a/media/filters/audio_renderer_impl.h
+++ b/media/filters/audio_renderer_impl.h
@@ -29,7 +29,7 @@ class AudioRendererImpl : public AudioRendererBase,
return new FilterFactoryImpl0<AudioRendererImpl>();
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format);
+ static bool IsMediaFormatSupported(const MediaFormat& media_format);
// MediaFilter implementation.
virtual void SetPlaybackRate(float playback_rate);
@@ -49,7 +49,7 @@ class AudioRendererImpl : public AudioRendererBase,
virtual ~AudioRendererImpl();
// AudioRendererBase implementation.
- virtual bool OnInitialize(const MediaFormat* media_format);
+ virtual bool OnInitialize(const MediaFormat& media_format);
virtual void OnStop();
private:
diff --git a/media/filters/decoder_base.h b/media/filters/decoder_base.h
index 685495d..adecbf2 100644
--- a/media/filters/decoder_base.h
+++ b/media/filters/decoder_base.h
@@ -58,7 +58,7 @@ class DecoderBase : public Decoder {
}
}
- virtual const MediaFormat* GetMediaFormat() { return &media_format_; }
+ virtual const MediaFormat& media_format() { return media_format_; }
// Audio or Video decoder.
virtual void Read(Assignable<Output>* output) {
diff --git a/media/filters/ffmpeg_audio_decoder.cc b/media/filters/ffmpeg_audio_decoder.cc
index 378d865..74559d3 100644
--- a/media/filters/ffmpeg_audio_decoder.cc
+++ b/media/filters/ffmpeg_audio_decoder.cc
@@ -16,7 +16,7 @@ FFmpegAudioDecoder::~FFmpegAudioDecoder() {
}
// static
-bool FFmpegAudioDecoder::IsMediaFormatSupported(const MediaFormat* format) {
+bool FFmpegAudioDecoder::IsMediaFormatSupported(const MediaFormat& format) {
NOTIMPLEMENTED();
return false;
}
diff --git a/media/filters/ffmpeg_audio_decoder.h b/media/filters/ffmpeg_audio_decoder.h
index 9df354b..52ffde9 100644
--- a/media/filters/ffmpeg_audio_decoder.h
+++ b/media/filters/ffmpeg_audio_decoder.h
@@ -19,7 +19,7 @@ class FFmpegAudioDecoder : public DecoderBase<AudioDecoder, Buffer> {
return new FilterFactoryImpl0<FFmpegAudioDecoder>();
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format);
+ static bool IsMediaFormatSupported(const MediaFormat& media_format);
virtual bool OnInitialize(DemuxerStream* demuxer_stream);
diff --git a/media/filters/ffmpeg_demuxer.cc b/media/filters/ffmpeg_demuxer.cc
index 5fce5a4..0446325 100644
--- a/media/filters/ffmpeg_demuxer.cc
+++ b/media/filters/ffmpeg_demuxer.cc
@@ -123,8 +123,8 @@ void FFmpegDemuxerStream::EnqueuePacket(AVPacket* packet) {
FulfillPendingReads();
}
-const MediaFormat* FFmpegDemuxerStream::GetMediaFormat() {
- return &media_format_;
+const MediaFormat& FFmpegDemuxerStream::media_format() {
+ return media_format_;
}
void FFmpegDemuxerStream::Read(Assignable<Buffer>* buffer) {
diff --git a/media/filters/ffmpeg_demuxer.h b/media/filters/ffmpeg_demuxer.h
index 317969d..dea349d 100644
--- a/media/filters/ffmpeg_demuxer.h
+++ b/media/filters/ffmpeg_demuxer.h
@@ -57,7 +57,7 @@ class FFmpegDemuxerStream : public DemuxerStream {
base::TimeDelta duration() { return duration_; }
// DemuxerStream implementation.
- virtual const MediaFormat* GetMediaFormat();
+ virtual const MediaFormat& media_format();
virtual void Read(Assignable<Buffer>* buffer);
AVStream* av_stream() {
diff --git a/media/filters/ffmpeg_demuxer_unittest.cc b/media/filters/ffmpeg_demuxer_unittest.cc
index b37196d..aeba6fe 100644
--- a/media/filters/ffmpeg_demuxer_unittest.cc
+++ b/media/filters/ffmpeg_demuxer_unittest.cc
@@ -148,12 +148,12 @@ TEST(FFmpegDemuxerTest, InitializeFailure) {
// Should only accept application/octet-stream type.
MediaFormat media_format;
media_format.SetAsString(MediaFormat::kMimeType, "foo/x-bar");
- scoped_refptr<Demuxer> demuxer(factory->Create<Demuxer>(&media_format));
+ scoped_refptr<Demuxer> demuxer(factory->Create<Demuxer>(media_format));
ASSERT_FALSE(demuxer);
media_format.Clear();
media_format.SetAsString(MediaFormat::kMimeType,
mime_type::kApplicationOctetStream);
- demuxer = factory->Create<Demuxer>(&media_format);
+ demuxer = factory->Create<Demuxer>(media_format);
ASSERT_TRUE(demuxer);
// Prepare a filter host and data source for the demuxer.
@@ -173,7 +173,7 @@ TEST(FFmpegDemuxerTest, InitializeFailure) {
// Simulate av_find_stream_info failing.
g_av_open_input_file = 0;
g_av_find_stream_info = AVERROR_IO;
- demuxer = factory->Create<Demuxer>(&media_format);
+ demuxer = factory->Create<Demuxer>(media_format);
filter_host.reset(new MockFilterHost<Demuxer>(&pipeline, demuxer));
EXPECT_FALSE(demuxer->Initialize(data_source));
EXPECT_FALSE(filter_host->IsInitialized());
@@ -181,7 +181,7 @@ TEST(FFmpegDemuxerTest, InitializeFailure) {
// Simulate media with no parseable streams.
InitializeFFmpegMocks();
- demuxer = factory->Create<Demuxer>(&media_format);
+ demuxer = factory->Create<Demuxer>(media_format);
filter_host.reset(new MockFilterHost<Demuxer>(&pipeline, demuxer));
EXPECT_FALSE(demuxer->Initialize(data_source));
EXPECT_FALSE(filter_host->IsInitialized());
@@ -192,7 +192,7 @@ TEST(FFmpegDemuxerTest, InitializeFailure) {
g_format.streams[0] = &g_streams[0];
g_streams[0].codec = &g_data_codec;
g_streams[0].duration = 10;
- demuxer = factory->Create<Demuxer>(&media_format);
+ demuxer = factory->Create<Demuxer>(media_format);
filter_host.reset(new MockFilterHost<Demuxer>(&pipeline, demuxer));
EXPECT_FALSE(demuxer->Initialize(data_source));
EXPECT_FALSE(filter_host->IsInitialized());
@@ -226,7 +226,7 @@ TEST(FFmpegDemuxerTest, InitializeStreams) {
// Create our demuxer.
scoped_refptr<FilterFactory> factory = FFmpegDemuxer::CreateFilterFactory();
scoped_refptr<Demuxer> demuxer
- = factory->Create<Demuxer>(data_source->GetMediaFormat());
+ = factory->Create<Demuxer>(data_source->media_format());
EXPECT_TRUE(demuxer);
MockFilterHost<Demuxer> filter_host_b(&pipeline, demuxer);
EXPECT_TRUE(demuxer->Initialize(data_source));
@@ -243,29 +243,35 @@ TEST(FFmpegDemuxerTest, InitializeStreams) {
// First stream should be video.
scoped_refptr<DemuxerStream> stream = demuxer->GetStream(0);
ASSERT_TRUE(stream);
- const MediaFormat* stream_format = stream->GetMediaFormat();
std::string mime_type;
int result;
- EXPECT_TRUE(stream_format->GetAsString(MediaFormat::kMimeType, &mime_type));
+ EXPECT_TRUE(
+ stream->media_format().GetAsString(MediaFormat::kMimeType, &mime_type));
EXPECT_STREQ(mime_type::kFFmpegVideo, mime_type.c_str());
- EXPECT_TRUE(stream_format->GetAsInteger(kFFmpegCodecID, &result));
+ EXPECT_TRUE(
+ stream->media_format().GetAsInteger(kFFmpegCodecID, &result));
EXPECT_EQ(CODEC_ID_THEORA, static_cast<CodecID>(result));
- EXPECT_TRUE(stream_format->GetAsInteger(MediaFormat::kHeight, &result));
+ EXPECT_TRUE(
+ stream->media_format().GetAsInteger(MediaFormat::kHeight, &result));
EXPECT_EQ(g_video_codec.height, result);
- EXPECT_TRUE(stream_format->GetAsInteger(MediaFormat::kWidth, &result));
+ EXPECT_TRUE(
+ stream->media_format().GetAsInteger(MediaFormat::kWidth, &result));
EXPECT_EQ(g_video_codec.width, result);
// Second stream should be audio.
stream = demuxer->GetStream(1);
ASSERT_TRUE(stream);
- stream_format = stream->GetMediaFormat();
- EXPECT_TRUE(stream_format->GetAsString(MediaFormat::kMimeType, &mime_type));
+ EXPECT_TRUE(
+ stream->media_format().GetAsString(MediaFormat::kMimeType, &mime_type));
EXPECT_STREQ(mime_type::kFFmpegAudio, mime_type.c_str());
- EXPECT_TRUE(stream_format->GetAsInteger(kFFmpegCodecID, &result));
+ EXPECT_TRUE(
+ stream->media_format().GetAsInteger(kFFmpegCodecID, &result));
EXPECT_EQ(CODEC_ID_VORBIS, static_cast<CodecID>(result));
- EXPECT_TRUE(stream_format->GetAsInteger(MediaFormat::kChannels, &result));
+ EXPECT_TRUE(
+ stream->media_format().GetAsInteger(MediaFormat::kChannels, &result));
EXPECT_EQ(g_audio_codec.channels, result);
- EXPECT_TRUE(stream_format->GetAsInteger(MediaFormat::kSampleRate, &result));
+ EXPECT_TRUE(
+ stream->media_format().GetAsInteger(MediaFormat::kSampleRate, &result));
EXPECT_EQ(g_audio_codec.sample_rate, result);
}
@@ -300,7 +306,7 @@ TEST(FFmpegDemuxerTest, Read) {
// Create our demuxer.
scoped_refptr<FilterFactory> factory = FFmpegDemuxer::CreateFilterFactory();
scoped_refptr<Demuxer> demuxer
- = factory->Create<Demuxer>(data_source->GetMediaFormat());
+ = factory->Create<Demuxer>(data_source->media_format());
EXPECT_TRUE(demuxer);
MockFilterHost<Demuxer> filter_host_b(&pipeline, demuxer);
EXPECT_TRUE(demuxer->Initialize(data_source));
@@ -335,7 +341,7 @@ TEST(FFmpegDemuxerTest, Read) {
pipeline.RunAllTasks();
EXPECT_TRUE(buffer->assigned());
EXPECT_TRUE(buffer->buffer());
- EXPECT_EQ(audio_data, (uint8*)buffer->buffer()->GetData());
+ EXPECT_EQ(audio_data, buffer->buffer()->GetData());
EXPECT_EQ(kDataSize, buffer->buffer()->GetDataSize());
// Prepare our test video packet.
@@ -349,7 +355,7 @@ TEST(FFmpegDemuxerTest, Read) {
pipeline.RunAllTasks();
EXPECT_TRUE(buffer->assigned());
EXPECT_TRUE(buffer->buffer());
- EXPECT_EQ(video_data, (uint8*)buffer->buffer()->GetData());
+ EXPECT_EQ(video_data, buffer->buffer()->GetData());
EXPECT_EQ(kDataSize, buffer->buffer()->GetDataSize());
// Simulate end of stream.
diff --git a/media/filters/ffmpeg_video_decoder.cc b/media/filters/ffmpeg_video_decoder.cc
index dad8b88..f429ea6 100644
--- a/media/filters/ffmpeg_video_decoder.cc
+++ b/media/filters/ffmpeg_video_decoder.cc
@@ -16,7 +16,7 @@ FFmpegVideoDecoder::~FFmpegVideoDecoder() {
}
// static
-bool FFmpegVideoDecoder::IsMediaFormatSupported(const MediaFormat* format) {
+bool FFmpegVideoDecoder::IsMediaFormatSupported(const MediaFormat& format) {
NOTIMPLEMENTED();
return false;
}
diff --git a/media/filters/ffmpeg_video_decoder.h b/media/filters/ffmpeg_video_decoder.h
index 7e9fb91..a047823 100644
--- a/media/filters/ffmpeg_video_decoder.h
+++ b/media/filters/ffmpeg_video_decoder.h
@@ -19,7 +19,7 @@ class FFmpegVideoDecoder : public DecoderBase<VideoDecoder, VideoFrame> {
return new FilterFactoryImpl0<FFmpegVideoDecoder>();
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format);
+ static bool IsMediaFormatSupported(const MediaFormat& media_format);
virtual bool OnInitialize(DemuxerStream* demuxer_stream);
diff --git a/media/filters/file_data_source.cc b/media/filters/file_data_source.cc
index 854fea2..c622c04 100644
--- a/media/filters/file_data_source.cc
+++ b/media/filters/file_data_source.cc
@@ -53,8 +53,8 @@ void FileDataSource::Stop() {
}
}
-const MediaFormat* FileDataSource::GetMediaFormat() {
- return &media_format_;
+const MediaFormat& FileDataSource::media_format() {
+ return media_format_;
}
size_t FileDataSource::Read(uint8* data, size_t size) {
diff --git a/media/filters/file_data_source.h b/media/filters/file_data_source.h
index 1c03cf0..c7bfdfd 100644
--- a/media/filters/file_data_source.h
+++ b/media/filters/file_data_source.h
@@ -29,7 +29,7 @@ class FileDataSource : public DataSource {
// Implementation of DataSource.
virtual bool Initialize(const std::string& url);
- virtual const MediaFormat* GetMediaFormat();
+ virtual const MediaFormat& media_format();
virtual size_t Read(uint8* data, size_t size);
virtual bool GetPosition(int64* position_out);
virtual bool SetPosition(int64 position);
diff --git a/media/filters/file_data_source_unittest.cc b/media/filters/file_data_source_unittest.cc
index 2545e7c..8512300 100644
--- a/media/filters/file_data_source_unittest.cc
+++ b/media/filters/file_data_source_unittest.cc
@@ -88,7 +88,7 @@ TEST(FileDataSourceTest, ReadData) {
// Create our data source.
scoped_refptr<FilterFactory> factory = FileDataSource::CreateFactory();
- FileDataSource* filter = factory->Create<FileDataSource>(&url_format);
+ FileDataSource* filter = factory->Create<FileDataSource>(url_format);
EXPECT_TRUE(filter);
// Create our mock pipeline and filter host and initialize the data source.
diff --git a/media/filters/null_audio_renderer.cc b/media/filters/null_audio_renderer.cc
index f30ed59..1d50e69 100644
--- a/media/filters/null_audio_renderer.cc
+++ b/media/filters/null_audio_renderer.cc
@@ -29,7 +29,7 @@ NullAudioRenderer::~NullAudioRenderer() {
// static
bool NullAudioRenderer::IsMediaFormatSupported(
- const MediaFormat* media_format) {
+ const MediaFormat& media_format) {
int channels;
int sample_rate;
int sample_bits;
@@ -63,7 +63,7 @@ void NullAudioRenderer::ThreadMain() {
}
}
-bool NullAudioRenderer::OnInitialize(const MediaFormat* media_format) {
+bool NullAudioRenderer::OnInitialize(const MediaFormat& media_format) {
// Parse out audio parameters.
int channels;
int sample_rate;
diff --git a/media/filters/null_audio_renderer.h b/media/filters/null_audio_renderer.h
index cf66648..824e13d 100644
--- a/media/filters/null_audio_renderer.h
+++ b/media/filters/null_audio_renderer.h
@@ -37,7 +37,7 @@ class NullAudioRenderer : public AudioRendererBase, PlatformThread::Delegate {
}
// Compatible with any audio/x-uncompressed MediaFormat.
- static bool IsMediaFormatSupported(const MediaFormat* media_format);
+ static bool IsMediaFormatSupported(const MediaFormat& media_format);
// MediaFilter implementation.
virtual void SetPlaybackRate(float playback_rate);
@@ -55,7 +55,7 @@ class NullAudioRenderer : public AudioRendererBase, PlatformThread::Delegate {
virtual ~NullAudioRenderer();
// AudioRendererBase implementation.
- virtual bool OnInitialize(const MediaFormat* media_format);
+ virtual bool OnInitialize(const MediaFormat& media_format);
virtual void OnStop();
private:
diff --git a/media/filters/test_video_decoder.h b/media/filters/test_video_decoder.h
index 3ca6a3f..84d6e66 100644
--- a/media/filters/test_video_decoder.h
+++ b/media/filters/test_video_decoder.h
@@ -25,13 +25,13 @@ class TestVideoDecoder : public DecoderBase<VideoDecoder, VideoFrame> {
}
bool OnInitialize(DemuxerStream* demuxer_stream) {
- const MediaFormat* media_format = demuxer_stream->GetMediaFormat();
+ const MediaFormat& media_format = demuxer_stream->media_format();
std::string mime_type;
int width, height;
- if (media_format->GetAsString(MediaFormat::kMimeType, &mime_type) &&
+ if (media_format.GetAsString(MediaFormat::kMimeType, &mime_type) &&
mime_type.compare(mime_type::kH264AnnexB) == 0 &&
- media_format->GetAsInteger(MediaFormat::kWidth, &width) &&
- media_format->GetAsInteger(MediaFormat::kHeight, &height)) {
+ media_format.GetAsInteger(MediaFormat::kWidth, &width) &&
+ media_format.GetAsInteger(MediaFormat::kHeight, &height)) {
video_width_ = width;
video_height_ = height;
media_format_.SetAsString(MediaFormat::kMimeType,
@@ -59,9 +59,9 @@ class TestVideoDecoder : public DecoderBase<VideoDecoder, VideoFrame> {
}
}
- static bool IsMediaFormatSupported(const MediaFormat* media_format) {
+ static bool IsMediaFormatSupported(const MediaFormat& media_format) {
std::string mime_type;
- return (media_format->GetAsString(MediaFormat::kMimeType, &mime_type) &&
+ return (media_format.GetAsString(MediaFormat::kMimeType, &mime_type) &&
mime_type == mime_type::kH264AnnexB);
}
diff --git a/media/filters/test_video_renderer.h b/media/filters/test_video_renderer.h
index f6c3c22..f9535f2 100644
--- a/media/filters/test_video_renderer.h
+++ b/media/filters/test_video_renderer.h
@@ -46,7 +46,7 @@ class TestVideoRenderer : public VideoRendererBase {
size_t paint_called() { return paint_called_; }
base::TimeDelta last_timestamp() { return last_timestamp_; }
- static bool IsMediaFormatSupported(const MediaFormat* format) {
+ static bool IsMediaFormatSupported(const MediaFormat& format) {
return VideoRendererBase::IsMediaFormatSupported(format);
}
diff --git a/media/filters/video_renderer_base.cc b/media/filters/video_renderer_base.cc
index 57caf99..744942f 100644
--- a/media/filters/video_renderer_base.cc
+++ b/media/filters/video_renderer_base.cc
@@ -45,22 +45,22 @@ VideoRendererBase::~VideoRendererBase() {
// static
bool VideoRendererBase::IsMediaFormatSupported(
- const MediaFormat* media_format) {
+ const MediaFormat& media_format) {
int width;
int height;
return ParseMediaFormat(media_format, &width, &height);
}
// static
-bool VideoRendererBase::ParseMediaFormat(const MediaFormat* media_format,
+bool VideoRendererBase::ParseMediaFormat(const MediaFormat& media_format,
int* width_out,
int* height_out) {
- DCHECK(media_format && width_out && height_out);
+ DCHECK(width_out && height_out);
std::string mime_type;
- return (media_format->GetAsString(MediaFormat::kMimeType, &mime_type) &&
+ return (media_format.GetAsString(MediaFormat::kMimeType, &mime_type) &&
mime_type.compare(mime_type::kUncompressedVideo) == 0 &&
- media_format->GetAsInteger(MediaFormat::kWidth, width_out) &&
- media_format->GetAsInteger(MediaFormat::kHeight, height_out));
+ media_format.GetAsInteger(MediaFormat::kWidth, width_out) &&
+ media_format.GetAsInteger(MediaFormat::kHeight, height_out));
}
void VideoRendererBase::Stop() {
@@ -82,7 +82,7 @@ void VideoRendererBase::Stop() {
bool VideoRendererBase::Initialize(VideoDecoder* decoder) {
int width, height;
decoder_ = decoder;
- if (ParseMediaFormat(decoder_->GetMediaFormat(), &width, &height) &&
+ if (ParseMediaFormat(decoder_->media_format(), &width, &height) &&
OnInitialize(width, height)) {
host_->SetVideoSize(width, height);
host_->SetTimeUpdateCallback(
diff --git a/media/filters/video_renderer_base.h b/media/filters/video_renderer_base.h
index 16566fc..2c51895 100644
--- a/media/filters/video_renderer_base.h
+++ b/media/filters/video_renderer_base.h
@@ -85,12 +85,12 @@ class VideoRendererBase : public VideoRenderer {
void GetCurrentFrame(scoped_refptr<VideoFrame>* frame_out);
// Answers question from the factory to see if we accept |format|.
- static bool IsMediaFormatSupported(const MediaFormat* format);
+ static bool IsMediaFormatSupported(const MediaFormat& format);
// Used by the IsMediaFormatSupported and Initialize methods. Examines the
// |media_format| and returns true if the format is supported. Both output
// parameters, |width_out| and |height_out| are required and must not be NULL.
- static bool ParseMediaFormat(const MediaFormat* media_format,
+ static bool ParseMediaFormat(const MediaFormat& media_format,
int* width_out,
int* height_out);