Chromium Code Reviews| Index: services/video_capture/public/interfaces/video_capture_format_traits.cc |
| diff --git a/services/video_capture/public/interfaces/video_capture_format_traits.cc b/services/video_capture/public/interfaces/video_capture_format_traits.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..f37f4689b11a6b0efabafad6af7058acc584560e |
| --- /dev/null |
| +++ b/services/video_capture/public/interfaces/video_capture_format_traits.cc |
| @@ -0,0 +1,87 @@ |
| +// Copyright 2016 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 "services/video_capture/public/interfaces/video_capture_format_traits.h" |
| + |
| +#include "ui/gfx/geometry/mojo/geometry.mojom.h" |
| +#include "ui/gfx/geometry/mojo/geometry_struct_traits.h" |
| + |
| +namespace mojo { |
| + |
| +// static |
| +const gfx::Size& StructTraits<video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>:: |
| + frame_size(const media::VideoCaptureFormat& format) { |
| + return format.frame_size; |
|
dcheng
2016/10/04 22:09:26
Inline, since we're just returning a member refere
mcasas
2016/10/04 22:16:56
Done.
|
| +} |
| + |
| +// static |
| +media::mojom::VideoFormat StructTraits< |
| + video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>::pixel_format(const media::VideoCaptureFormat& |
| + format) { |
| + return static_cast<media::mojom::VideoFormat>(format.pixel_format); |
|
dcheng
2016/10/04 22:09:26
Ditto, inline these as well.
mcasas
2016/10/04 22:16:56
Done.
|
| +} |
| + |
| +// static |
| +video_capture::mojom::VideoPixelStorage StructTraits< |
| + video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>::pixel_storage(const media::VideoCaptureFormat& |
| + format) { |
| + return static_cast<video_capture::mojom::VideoPixelStorage>( |
| + format.pixel_storage); |
| +} |
| + |
| +// static |
| +bool StructTraits<video_capture::mojom::VideoCaptureFormatDataView, |
| + media::VideoCaptureFormat>:: |
| + Read(video_capture::mojom::VideoCaptureFormatDataView data, |
| + media::VideoCaptureFormat* out) { |
| + if (!data.ReadFrameSize(&out->frame_size)) |
| + return false; |
| + out->frame_rate = data.frame_rate(); |
| + |
| + // Since there are static_asserts in place in |
| + // media/mojo/common/media_type_converters.cc to guarantee equality of the |
| + // underlying representations, we can simply static_cast to convert. |
| + // TODO(mcasas): Use EnumTraits for VideoPixelFormat, https://crbug.com/651897 |
| + out->pixel_format = |
| + static_cast<media::VideoPixelFormat>(data.pixel_format()); |
| + if (!data.ReadPixelStorage(&out->pixel_storage)) |
| + return false; |
| + return true; |
| +} |
| + |
| +// static |
| +video_capture::mojom::VideoPixelStorage |
| +EnumTraits<video_capture::mojom::VideoPixelStorage, media::VideoPixelStorage>:: |
| + ToMojom(media::VideoPixelStorage video_pixel_storage) { |
| + switch (video_pixel_storage) { |
| + case media::PIXEL_STORAGE_CPU: |
| + return video_capture::mojom::VideoPixelStorage::CPU; |
| + case media::PIXEL_STORAGE_GPUMEMORYBUFFER: |
| + return video_capture::mojom::VideoPixelStorage::GPUMEMORYBUFFER; |
| + } |
| + NOTREACHED(); |
| + return video_capture::mojom::VideoPixelStorage::CPU; |
| +} |
| + |
| +// static |
| +bool EnumTraits<video_capture::mojom::VideoPixelStorage, |
| + media::VideoPixelStorage>:: |
| + FromMojom(video_capture::mojom::VideoPixelStorage input, |
| + media::VideoPixelStorage* out) { |
| + switch (input) { |
| + case video_capture::mojom::VideoPixelStorage::CPU: |
| + *out = media::PIXEL_STORAGE_CPU; |
| + return true; |
| + case video_capture::mojom::VideoPixelStorage::GPUMEMORYBUFFER: |
| + *out = media::PIXEL_STORAGE_GPUMEMORYBUFFER; |
| + return true; |
| + } |
| + NOTREACHED(); |
| + return false; |
| +} |
| + |
| +} // namespace mojo |