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

Side by Side Diff: url/mojo/origin_struct_traits.h

Issue 1966933002: Mojo C++ bindings: switch the existing usage of StructTraits to use the new data view interface. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@26_reader
Patch Set: Created 4 years, 7 months 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 unified diff | Download patch
OLDNEW
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 URL_MOJO_ORIGIN_STRUCT_TRAITS_H_ 5 #ifndef URL_MOJO_ORIGIN_STRUCT_TRAITS_H_
6 #define URL_MOJO_ORIGIN_STRUCT_TRAITS_H_ 6 #define URL_MOJO_ORIGIN_STRUCT_TRAITS_H_
7 7
8 #include "base/strings/string_piece.h" 8 #include "base/strings/string_piece.h"
9 #include "url/mojo/origin.mojom.h" 9 #include "url/mojo/origin.mojom.h"
10 #include "url/origin.h" 10 #include "url/origin.h"
11 11
12 namespace mojo { 12 namespace mojo {
13 13
14 template <> 14 template <>
15 struct StructTraits<url::mojom::Origin, url::Origin> { 15 struct StructTraits<url::mojom::Origin, url::Origin> {
16 static base::StringPiece scheme(const url::Origin& r) { 16 static base::StringPiece scheme(const url::Origin& r) {
17 return base::StringPiece(r.scheme()); 17 return base::StringPiece(r.scheme());
18 } 18 }
19 static base::StringPiece host(const url::Origin& r) { 19 static base::StringPiece host(const url::Origin& r) {
20 return base::StringPiece(r.host()); 20 return base::StringPiece(r.host());
21 } 21 }
22 static uint16_t port(const url::Origin& r) { 22 static uint16_t port(const url::Origin& r) {
23 return r.port(); 23 return r.port();
24 } 24 }
25 static bool unique(const url::Origin& r) { 25 static bool unique(const url::Origin& r) {
26 return r.unique(); 26 return r.unique();
27 } 27 }
28 static bool Read(url::mojom::Origin::Reader r, url::Origin* out) { 28 static bool Read(url::mojom::OriginDataView data, url::Origin* out) {
29 *out = r.unique() ? url::Origin() 29 if (data.is_null()) {
dcheng 2016/05/11 18:04:22 Why/when would data be null? Why do we consider th
yzshen1 2016/05/11 18:18:25 Imagine we have a mojo interface like this: inter
30 : url::Origin::UnsafelyCreateOriginWithoutNormalization( 30 *out = url::Origin();
31 r.scheme(), r.host(), r.port()); 31 return true;
32 }
33
34 if (data.unique()) {
35 *out = url::Origin();
36 } else {
37 base::StringPiece scheme, host;
38 if (!data.ReadScheme(&scheme) || !data.ReadHost(&host))
39 return false;
40
41 *out = url::Origin::UnsafelyCreateOriginWithoutNormalization(scheme, host,
42 data.port());
43 }
32 44
33 // If a unique origin was created, but the unique flag wasn't set, then 45 // If a unique origin was created, but the unique flag wasn't set, then
34 // the values provided to 'UnsafelyCreateOriginWithoutNormalization' were 46 // the values provided to 'UnsafelyCreateOriginWithoutNormalization' were
35 // invalid. 47 // invalid.
36 if (!r.unique() && out->unique()) 48 if (!data.unique() && out->unique())
37 return false; 49 return false;
38 50
39 return true; 51 return true;
40 } 52 }
41 }; 53 };
42 54
43 } 55 }
44 56
45 #endif // URL_MOJO_ORIGIN_STRUCT_TRAITS_H_ 57 #endif // URL_MOJO_ORIGIN_STRUCT_TRAITS_H_
OLDNEW
« no previous file with comments | « mojo/public/tools/bindings/generators/cpp_templates/wrapper_class_definition.tmpl ('k') | url/mojo/url_gurl_struct_traits.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698