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

Side by Side Diff: mojo/public/tools/bindings/generators/cpp_templates/union_serialization_definition.tmpl

Issue 923033003: Implement unions as members of structs. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 years, 9 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 size_t GetSerializedSize_(const {{union.name}}Ptr& input) { 1 size_t GetSerializedSize_(const {{union.name}}Ptr& input) {
2 size_t size = sizeof(internal::{{union.name}}_Data);
2 if (!input) 3 if (!input)
3 return 0; 4 return size;
yzshen1 2015/02/25 21:07:00 For non-inlined union, this is incorrect. :/
azani 2015/03/03 00:44:16 This only applies if we have a pointer to a union
4 5
5 size_t size = sizeof(internal::{{union.name}}_Data);
6 switch (input->which()) { 6 switch (input->which()) {
7 {% for field in union.fields %} 7 {% for field in union.fields %}
8 {% if field.kind|is_string_kind %} 8 {% if field.kind|is_string_kind %}
9 case {{union.name}}::Tag::{{field.name|upper}}: 9 case {{union.name}}::Tag::{{field.name|upper}}:
10 size += GetSerializedSize_(input->get_{{field.name}}()); 10 size += GetSerializedSize_(input->get_{{field.name}}());
11 break; 11 break;
12 {%- endif %} 12 {%- endif %}
13 {%- endfor %} 13 {%- endfor %}
14 default: 14 default:
15 break; 15 break;
16 } 16 }
17 return size; 17 return size;
18 } 18 }
19 19
20 20
21 void Serialize_({{union.name}}Ptr input, mojo::internal::Buffer* buf, 21 void Serialize_({{union.name}}Ptr input, mojo::internal::Buffer* buf,
22 internal::{{union.name}}_Data** output) { 22 internal::{{union.name}}_Data** output) {
23 internal::{{union.name}}_Data* result = nullptr;
24 if (*output) {
yzshen1 2015/02/25 21:07:00 Please consider the change that we discussed offli
azani 2015/03/03 00:44:16 Done.
25 result = *output;
26 } else {
27 result = internal::{{union.name}}_Data::New(buf);
28 }
23 if (input) { 29 if (input) {
yzshen1 2015/02/25 21:07:00 if input is null, we need to either set |output| t
azani 2015/03/03 00:44:16 It's not an inlined vs not inlined issue. It's "po
yzshen1 2015/03/26 07:30:14 I am not sure I understand your comment. Let's sa
azani 2015/03/26 22:27:39 Done.
24 mojo::internal::UnionAccessor<{{union.name}}> input_acc(input.get()); 30 mojo::internal::UnionAccessor<{{union.name}}> input_acc(input.get());
25 internal::{{union.name}}_Data* result =
26 internal::{{union.name}}_Data::New(buf);
27 // TODO(azani): Handle unknown and objects. 31 // TODO(azani): Handle unknown and objects.
32 // Set the not-null flag.
33 result->size = 16;
28 result->tag = input->which(); 34 result->tag = input->which();
29 switch (input->which()) { 35 switch (input->which()) {
30 {% for field in union.fields %} 36 {% for field in union.fields %}
31 case {{union.name}}::Tag::{{field.name|upper}}: 37 case {{union.name}}::Tag::{{field.name|upper}}:
32 {% if field.kind|is_string_kind %} 38 {% if field.kind|is_string_kind %}
33 {{field.kind|cpp_field_type}}* {{field.name}}_ptr = reinterpret_cast<{{f ield.kind|cpp_field_type}}*>(&result->data.f_{{field.name}}); 39 {{field.kind|cpp_field_type}}* {{field.name}}_ptr = reinterpret_cast<{{f ield.kind|cpp_field_type}}*>(&result->data.f_{{field.name}});
34 Serialize_(*(input_acc.data()->{{field.name}}), buf, &{{field.name}}_ptr ->ptr); 40 Serialize_(*(input_acc.data()->{{field.name}}), buf, &{{field.name}}_ptr ->ptr);
35 {% else %} 41 {% else %}
36 result->data.f_{{field.name}} = input_acc.data()->{{field.name}}; 42 result->data.f_{{field.name}} = input_acc.data()->{{field.name}};
37 {%- endif %} 43 {%- endif %}
38 break; 44 break;
39 {%- endfor %} 45 {%- endfor %}
40 } 46 }
41 *output = result;
42 } else {
43 *output = nullptr;
44 } 47 }
48 *output = result;
45 } 49 }
46 50
47 void Deserialize_(internal::{{union.name}}_Data* input, 51 void Deserialize_(internal::{{union.name}}_Data* input,
48 {{union.name}}Ptr* output) { 52 {{union.name}}Ptr* output) {
49 if (input) { 53 if (input && !input->is_null()) {
50 {{union.name}}Ptr result({{union.name}}::New()); 54 {{union.name}}Ptr result({{union.name}}::New());
51 mojo::internal::UnionAccessor<{{union.name}}> result_acc(result.get()); 55 mojo::internal::UnionAccessor<{{union.name}}> result_acc(result.get());
52 switch (input->tag) { 56 switch (input->tag) {
53 {% for field in union.fields %} 57 {% for field in union.fields %}
54 case {{union.name}}::Tag::{{field.name|upper}}: 58 case {{union.name}}::Tag::{{field.name|upper}}:
55 {% if field.kind|is_string_kind %} 59 {% if field.kind|is_string_kind %}
56 result_acc.SwitchActive({{union.name}}::Tag::{{field.name|upper}}); 60 result_acc.SwitchActive({{union.name}}::Tag::{{field.name|upper}});
57 {{field.kind|cpp_field_type}}* {{field.name}}_ptr = reinterpret_cast<{{f ield.kind|cpp_field_type}}*>(&input->data.f_{{field.name}}); 61 {{field.kind|cpp_field_type}}* {{field.name}}_ptr = reinterpret_cast<{{f ield.kind|cpp_field_type}}*>(&input->data.f_{{field.name}});
58 Deserialize_({{field.name}}_ptr->ptr, result_acc.data()->{{field.name}}) ; 62 Deserialize_({{field.name}}_ptr->ptr, result_acc.data()->{{field.name}}) ;
59 {% else %} 63 {% else %}
60 result->set_{{field.name}}(input->data.f_{{field.name}}); 64 result->set_{{field.name}}(input->data.f_{{field.name}});
61 {%- endif %} 65 {%- endif %}
62 break; 66 break;
63 {%- endfor %} 67 {%- endfor %}
64 } 68 }
65 *output = result.Pass(); 69 *output = result.Pass();
66 } else { 70 } else {
67 output->reset(); 71 output->reset();
68 } 72 }
69 } 73 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698