Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CHROME_BROWSER_MEDIA_ROUTER_MOJO_MEDIA_ROUTER_STRUCT_TRAITS_H_ | 5 #ifndef CHROME_BROWSER_MEDIA_ROUTER_MOJO_MEDIA_ROUTER_STRUCT_TRAITS_H_ |
| 6 #define CHROME_BROWSER_MEDIA_ROUTER_MOJO_MEDIA_ROUTER_STRUCT_TRAITS_H_ | 6 #define CHROME_BROWSER_MEDIA_ROUTER_MOJO_MEDIA_ROUTER_STRUCT_TRAITS_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "chrome/browser/media/router/issue.h" | 10 #include "chrome/browser/media/router/issue.h" |
| 11 #include "chrome/browser/media/router/media_sink.h" | 11 #include "chrome/browser/media/router/media_sink_internal.h" |
| 12 #include "chrome/browser/media/router/mojo/media_router.mojom.h" | 12 #include "chrome/browser/media/router/mojo/media_router.mojom.h" |
| 13 #include "chrome/browser/media/router/route_request_result.h" | 13 #include "chrome/browser/media/router/route_request_result.h" |
| 14 #include "mojo/common/common_custom_types_struct_traits.h" | 14 #include "mojo/common/common_custom_types_struct_traits.h" |
| 15 | 15 |
| 16 namespace mojo { | 16 namespace mojo { |
| 17 | 17 |
| 18 // Issue | 18 // Issue |
| 19 | 19 |
| 20 template <> | 20 template <> |
| 21 struct EnumTraits<media_router::mojom::Issue::ActionType, | 21 struct EnumTraits<media_router::mojom::Issue::ActionType, |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 74 return true; | 74 return true; |
| 75 case media_router::mojom::Issue::Severity::NOTIFICATION: | 75 case media_router::mojom::Issue::Severity::NOTIFICATION: |
| 76 *output = media_router::IssueInfo::Severity::NOTIFICATION; | 76 *output = media_router::IssueInfo::Severity::NOTIFICATION; |
| 77 return true; | 77 return true; |
| 78 } | 78 } |
| 79 return false; | 79 return false; |
| 80 } | 80 } |
| 81 }; | 81 }; |
| 82 | 82 |
| 83 template <> | 83 template <> |
| 84 struct UnionTraits<media_router::mojom::MediaSinkExtraDataDataView, | |
| 85 media_router::MediaSinkInternal> { | |
| 86 static media_router::mojom::MediaSinkExtraDataDataView::Tag GetTag( | |
| 87 const media_router::MediaSinkInternal& sink) { | |
| 88 if (sink.is_dial_sink()) { | |
| 89 return media_router::mojom::MediaSinkExtraDataDataView::Tag:: | |
| 90 DIAL_MEDIA_SINK; | |
| 91 } else if (sink.is_cast_sink()) { | |
| 92 return media_router::mojom::MediaSinkExtraDataDataView::Tag:: | |
| 93 CAST_MEDIA_SINK; | |
| 94 } | |
| 95 NOTREACHED(); | |
| 96 return media_router::mojom::MediaSinkExtraDataDataView::Tag:: | |
| 97 CAST_MEDIA_SINK; | |
| 98 } | |
| 99 | |
| 100 static bool IsNull(const media_router::MediaSinkInternal& sink) { | |
|
mark a. foltz
2017/02/25 01:10:24
If we aren't passing any null sinks you don't need
zhaobin
2017/02/27 21:45:15
This is needed so Generic sink does not read extra
| |
| 101 return !sink.is_cast_sink() && !sink.is_dial_sink(); | |
| 102 } | |
| 103 | |
| 104 static const media_router::DialSinkExtraData& dial_media_sink( | |
| 105 const media_router::MediaSinkInternal& sink) { | |
| 106 return sink.dial_data(); | |
| 107 } | |
| 108 | |
| 109 static const media_router::CastSinkExtraData& cast_media_sink( | |
| 110 const media_router::MediaSinkInternal& sink) { | |
| 111 return sink.cast_data(); | |
| 112 } | |
| 113 }; | |
| 114 | |
| 115 template <> | |
| 116 struct StructTraits<media_router::mojom::DialMediaSinkDataView, | |
| 117 media_router::DialSinkExtraData> { | |
| 118 static base::Optional<std::string> model_name( | |
| 119 const media_router::DialSinkExtraData& extra_data) { | |
| 120 return extra_data.model_name; | |
| 121 } | |
| 122 | |
| 123 static const std::string& ip_address( | |
| 124 const media_router::DialSinkExtraData& extra_data) { | |
| 125 return extra_data.ip_address; | |
| 126 } | |
| 127 | |
| 128 static const GURL& app_url( | |
| 129 const media_router::DialSinkExtraData& extra_data) { | |
| 130 return extra_data.app_url; | |
| 131 } | |
| 132 | |
| 133 static bool Read(media_router::mojom::DialMediaSinkDataView data, | |
| 134 media_router::DialSinkExtraData* out); | |
| 135 }; | |
| 136 | |
| 137 template <> | |
| 138 struct StructTraits<media_router::mojom::CastMediaSinkDataView, | |
| 139 media_router::CastSinkExtraData> { | |
| 140 static base::Optional<std::string> model_name( | |
| 141 const media_router::CastSinkExtraData& extra_data) { | |
| 142 return extra_data.model_name; | |
| 143 } | |
| 144 | |
| 145 static const std::string& ip_address( | |
| 146 const media_router::CastSinkExtraData& extra_data) { | |
| 147 return extra_data.ip_address; | |
| 148 } | |
| 149 | |
| 150 static int32_t capabilities( | |
| 151 const media_router::CastSinkExtraData& extra_data) { | |
| 152 return extra_data.capabilities; | |
| 153 } | |
| 154 | |
| 155 static int32_t cast_channel_id( | |
| 156 const media_router::CastSinkExtraData& extra_data) { | |
| 157 return extra_data.cast_channel_id; | |
| 158 } | |
| 159 | |
| 160 static bool Read(media_router::mojom::CastMediaSinkDataView data, | |
| 161 media_router::CastSinkExtraData* out); | |
| 162 }; | |
| 163 | |
| 164 template <> | |
| 84 struct StructTraits<media_router::mojom::RouteMessageDataView, | 165 struct StructTraits<media_router::mojom::RouteMessageDataView, |
| 85 media_router::RouteMessage> { | 166 media_router::RouteMessage> { |
| 86 static media_router::mojom::RouteMessage::Type type( | 167 static media_router::mojom::RouteMessage::Type type( |
| 87 const media_router::RouteMessage& msg) { | 168 const media_router::RouteMessage& msg) { |
| 88 switch (msg.type) { | 169 switch (msg.type) { |
| 89 case media_router::RouteMessage::TEXT: | 170 case media_router::RouteMessage::TEXT: |
| 90 return media_router::mojom::RouteMessage::Type::TEXT; | 171 return media_router::mojom::RouteMessage::Type::TEXT; |
| 91 case media_router::RouteMessage::BINARY: | 172 case media_router::RouteMessage::BINARY: |
| 92 return media_router::mojom::RouteMessage::Type::BINARY; | 173 return media_router::mojom::RouteMessage::Type::BINARY; |
| 93 } | 174 } |
| (...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 221 case media_router::mojom::MediaSink::IconType::GENERIC: | 302 case media_router::mojom::MediaSink::IconType::GENERIC: |
| 222 *output = media_router::MediaSink::GENERIC; | 303 *output = media_router::MediaSink::GENERIC; |
| 223 return true; | 304 return true; |
| 224 } | 305 } |
| 225 return false; | 306 return false; |
| 226 } | 307 } |
| 227 }; | 308 }; |
| 228 | 309 |
| 229 template <> | 310 template <> |
| 230 struct StructTraits<media_router::mojom::MediaSinkDataView, | 311 struct StructTraits<media_router::mojom::MediaSinkDataView, |
| 231 media_router::MediaSink> { | 312 media_router::MediaSinkInternal> { |
| 232 static bool Read(media_router::mojom::MediaSinkDataView data, | 313 static bool Read(media_router::mojom::MediaSinkDataView data, |
| 233 media_router::MediaSink* out); | 314 media_router::MediaSinkInternal* out); |
| 234 | 315 |
| 235 static std::string sink_id(const media_router::MediaSink& sink) { | 316 static std::string sink_id( |
| 236 return sink.id(); | 317 const media_router::MediaSinkInternal& sink_internal) { |
| 318 return sink_internal.sink().id(); | |
| 237 } | 319 } |
| 238 | 320 |
| 239 static std::string name(const media_router::MediaSink& sink) { | 321 static std::string name( |
| 240 return sink.name(); | 322 const media_router::MediaSinkInternal& sink_internal) { |
| 323 return sink_internal.sink().name(); | |
| 241 } | 324 } |
| 242 | 325 |
| 243 static base::Optional<std::string> description( | 326 static base::Optional<std::string> description( |
| 244 const media_router::MediaSink& sink) { | 327 const media_router::MediaSinkInternal& sink_internal) { |
| 245 return sink.description(); | 328 return sink_internal.sink().description(); |
| 246 } | 329 } |
| 247 | 330 |
| 248 static base::Optional<std::string> domain( | 331 static base::Optional<std::string> domain( |
| 249 const media_router::MediaSink& sink) { | 332 const media_router::MediaSinkInternal& sink_internal) { |
| 250 return sink.domain(); | 333 return sink_internal.sink().domain(); |
| 251 } | 334 } |
| 252 | 335 |
| 253 static media_router::MediaSink::IconType icon_type( | 336 static media_router::MediaSink::IconType icon_type( |
| 254 const media_router::MediaSink& sink) { | 337 const media_router::MediaSinkInternal& sink_internal) { |
| 255 return sink.icon_type(); | 338 return sink_internal.sink().icon_type(); |
| 339 } | |
| 340 | |
| 341 static const media_router::MediaSinkInternal& extra_data( | |
| 342 const media_router::MediaSinkInternal& sink_internal) { | |
| 343 return sink_internal; | |
| 256 } | 344 } |
| 257 }; | 345 }; |
| 258 | 346 |
| 259 // MediaRoute | 347 // MediaRoute |
| 260 | 348 |
| 261 template <> | 349 template <> |
| 262 struct StructTraits<media_router::mojom::MediaRouteDataView, | 350 struct StructTraits<media_router::mojom::MediaRouteDataView, |
| 263 media_router::MediaRoute> { | 351 media_router::MediaRoute> { |
| 264 static bool Read(media_router::mojom::MediaRouteDataView data, | 352 static bool Read(media_router::mojom::MediaRouteDataView data, |
| 265 media_router::MediaRoute* out); | 353 media_router::MediaRoute* out); |
| (...skipping 208 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 474 *output = media_router::RouteRequestResult::CANCELLED; | 562 *output = media_router::RouteRequestResult::CANCELLED; |
| 475 return true; | 563 return true; |
| 476 } | 564 } |
| 477 return false; | 565 return false; |
| 478 } | 566 } |
| 479 }; | 567 }; |
| 480 | 568 |
| 481 } // namespace mojo | 569 } // namespace mojo |
| 482 | 570 |
| 483 #endif // CHROME_BROWSER_MEDIA_ROUTER_MOJO_MEDIA_ROUTER_STRUCT_TRAITS_H_ | 571 #endif // CHROME_BROWSER_MEDIA_ROUTER_MOJO_MEDIA_ROUTER_STRUCT_TRAITS_H_ |
| OLD | NEW |