Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 } |
| OLD | NEW |