Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(34)

Unified Diff: chromecast/common/media/cma_param_traits.cc

Issue 797793004: Chromecast: IPC messages for browser-based media pipeline. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address damien's comments Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chromecast/common/media/cma_param_traits.h ('k') | ipc/ipc_message_start.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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..bddf127486db0c1961b8341bc38b9bfca2216484
--- /dev/null
+++ b/chromecast/common/media/cma_param_traits.cc
@@ -0,0 +1,140 @@
+// 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,
Tom Sepez 2014/12/12 22:58:42 This should be in your messages .h file.
gunsch 2014/12/16 02:39:41 Done.
+ 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(
Tom Sepez 2014/12/12 22:58:42 Your life would be a lot easier if these were POD,
gunsch 2014/12/16 02:39:41 Agreed, but as media:: primitives we don't current
+ 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)) {
+ 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)) {
+ 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
« no previous file with comments | « chromecast/common/media/cma_param_traits.h ('k') | ipc/ipc_message_start.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698