Chromium Code Reviews| Index: chromecast/common/media/cma_param_traits.cc |
| diff --git a/chromecast/common/media/cma_param_traits.cc b/chromecast/common/media/cma_param_traits.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..9d00dc4dd4e4dd8c4cf09841e9945faeabce0455 |
| --- /dev/null |
| +++ b/chromecast/common/media/cma_param_traits.cc |
| @@ -0,0 +1,138 @@ |
| +// 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 "chromecast/common/media/cma_param_traits.h" |
| + |
| +#include <vector> |
| + |
| +#include "content/public/common/common_param_traits.h" |
| +#include "ipc/ipc_message_macros.h" |
| +#include "ipc/param_traits_macros.h" |
| +#include "media/base/audio_decoder_config.h" |
| +#include "media/base/video_decoder_config.h" |
| +#include "ui/gfx/ipc/gfx_param_traits.h" |
| + |
| +IPC_ENUM_TRAITS_MIN_MAX_VALUE(media::AudioCodec, |
| + media::AudioCodec::kUnknownAudioCodec, |
| + media::AudioCodec::kAudioCodecMax) |
| +IPC_ENUM_TRAITS_MIN_MAX_VALUE(media::SampleFormat, |
| + media::SampleFormat::kUnknownSampleFormat, |
| + media::SampleFormat::kSampleFormatMax) |
| +IPC_ENUM_TRAITS_MIN_MAX_VALUE(media::ChannelLayout, |
| + media::ChannelLayout::CHANNEL_LAYOUT_NONE, |
| + media::ChannelLayout::CHANNEL_LAYOUT_MAX) |
| +IPC_ENUM_TRAITS_MIN_MAX_VALUE(media::VideoCodec, |
| + media::VideoCodec::kUnknownVideoCodec, |
| + media::VideoCodec::kVideoCodecMax) |
| +IPC_ENUM_TRAITS_MIN_MAX_VALUE(media::VideoCodecProfile, |
| + media::VIDEO_CODEC_PROFILE_MIN, |
| + media::VIDEO_CODEC_PROFILE_MAX) |
| +IPC_ENUM_TRAITS_MAX_VALUE(media::VideoFrame::Format, |
| + media::VideoFrame::FORMAT_MAX) |
| + |
| +namespace IPC { |
| + |
| +void ParamTraits<media::AudioDecoderConfig>::Write( |
| + Message* m, const media::AudioDecoderConfig& p) { |
| + ParamTraits<media::AudioCodec>::Write(m, p.codec()); |
| + ParamTraits<media::SampleFormat>::Write(m, p.sample_format()); |
| + ParamTraits<media::ChannelLayout>::Write(m, p.channel_layout()); |
| + ParamTraits<int>::Write(m, p.samples_per_second()); |
| + ParamTraits<bool>::Write(m, p.is_encrypted()); |
| + std::vector<uint8> extra_data; |
| + if (p.extra_data_size() > 0) { |
| + extra_data = |
| + std::vector<uint8>(p.extra_data(), |
| + p.extra_data() + p.extra_data_size()); |
| + } |
| + ParamTraits<std::vector<uint8> >::Write(m, extra_data); |
| +} |
| + |
| +bool ParamTraits<media::AudioDecoderConfig>::Read( |
| + const Message* m, PickleIterator* iter, |
| + media::AudioDecoderConfig* r) { |
| + media::AudioCodec codec; |
| + media::SampleFormat sample_format; |
| + media::ChannelLayout channel_layout; |
| + int samples_per_second; |
| + bool is_encrypted; |
| + if (!ParamTraits<media::AudioCodec>::Read(m, iter, &codec) || |
| + !ParamTraits<media::SampleFormat>::Read(m, iter, &sample_format) || |
| + !ParamTraits<media::ChannelLayout>::Read(m, iter, &channel_layout) || |
| + !ParamTraits<int>::Read(m, iter, &samples_per_second) || |
| + !ParamTraits<bool>::Read(m, iter, &is_encrypted)) |
|
damienv1
2014/12/12 02:30:16
nit: Curly braces needed (multiple line if stateme
|
| + return false; |
| + std::vector<uint8> extra_data; |
| + if (!ParamTraits<std::vector<uint8> >::Read(m, iter, &extra_data)) |
| + return false; |
| + const uint8* extra_data_ptr = NULL; |
| + if (extra_data.size() > 0) |
| + extra_data_ptr = &extra_data[0]; |
| + *r = media::AudioDecoderConfig(codec, sample_format, channel_layout, |
| + samples_per_second, |
| + extra_data_ptr, extra_data.size(), |
| + is_encrypted); |
| + return true; |
| +} |
| + |
| +void ParamTraits<media::AudioDecoderConfig>::Log( |
| + const media::AudioDecoderConfig& p, std::string* l) { |
| + l->append(base::StringPrintf("<AudioDecoderConfig>")); |
| +} |
| + |
| +void ParamTraits<media::VideoDecoderConfig>::Write( |
| + Message* m, const media::VideoDecoderConfig& p) { |
| + ParamTraits<media::VideoCodec>::Write(m, p.codec()); |
| + ParamTraits<media::VideoCodecProfile>::Write(m, p.profile()); |
| + ParamTraits<media::VideoFrame::Format>::Write(m, p.format()); |
| + ParamTraits<gfx::Size>::Write(m, p.coded_size()); |
| + ParamTraits<gfx::Rect>::Write(m, p.visible_rect()); |
| + ParamTraits<gfx::Size>::Write(m, p.natural_size()); |
| + ParamTraits<bool>::Write(m, p.is_encrypted()); |
| + std::vector<uint8> extra_data; |
| + if (p.extra_data_size() > 0) { |
| + extra_data = |
| + std::vector<uint8>(p.extra_data(), |
| + p.extra_data() + p.extra_data_size()); |
| + } |
| + ParamTraits<std::vector<uint8> >::Write(m, extra_data); |
| +} |
| + |
| +bool ParamTraits<media::VideoDecoderConfig>::Read( |
| + const Message* m, PickleIterator* iter, |
| + media::VideoDecoderConfig* r) { |
| + media::VideoCodec codec; |
| + media::VideoCodecProfile profile; |
| + media::VideoFrame::Format format; |
| + gfx::Size coded_size; |
| + gfx::Rect visible_rect; |
| + gfx::Size natural_size; |
| + bool is_encrypted; |
| + if (!ParamTraits<media::VideoCodec>::Read(m, iter, &codec) || |
| + !ParamTraits<media::VideoCodecProfile>::Read(m, iter, &profile) || |
| + !ParamTraits<media::VideoFrame::Format>::Read(m, iter, &format) || |
| + !ParamTraits<gfx::Size>::Read(m, iter, &coded_size) || |
| + !ParamTraits<gfx::Rect>::Read(m, iter, &visible_rect) || |
| + !ParamTraits<gfx::Size>::Read(m, iter, &natural_size) || |
| + !ParamTraits<bool>::Read(m, iter, &is_encrypted)) |
|
damienv1
2014/12/12 02:30:16
ditto
gunsch
2014/12/12 22:40:53
Done.
gunsch
2014/12/12 22:40:53
Done.
|
| + return false; |
| + std::vector<uint8> extra_data; |
| + if (!ParamTraits<std::vector<uint8> >::Read(m, iter, &extra_data)) |
| + return false; |
| + const uint8* extra_data_ptr = NULL; |
| + if (extra_data.size() > 0) |
| + extra_data_ptr = &extra_data[0]; |
| + *r = media::VideoDecoderConfig(codec, profile, format, |
| + coded_size, visible_rect, natural_size, |
| + extra_data_ptr, extra_data.size(), |
| + is_encrypted); |
| + return true; |
| +} |
| + |
| +void ParamTraits<media::VideoDecoderConfig>::Log( |
| + const media::VideoDecoderConfig& p, std::string* l) { |
| + l->append(base::StringPrintf("<VideoDecoderConfig>")); |
| +} |
| + |
| +} // namespace IPC |