| OLD | NEW |
| 1 {%- set mojom_type = union|get_qualified_name_for_kind %} | 1 {%- set mojom_type = union|get_qualified_name_for_kind %} |
| 2 | 2 |
| 3 // static | 3 // static |
| 4 bool UnionTraits<{{mojom_type}}::DataView, {{mojom_type}}Ptr>::Read( | 4 bool UnionTraits<{{mojom_type}}::DataView, {{mojom_type}}Ptr>::Read( |
| 5 {{mojom_type}}::DataView input, | 5 {{mojom_type}}::DataView input, |
| 6 {{mojom_type}}Ptr* output) { | 6 {{mojom_type}}Ptr* output) { |
| 7 *output = {{mojom_type}}::New(); | 7 *output = {{mojom_type}}::New(); |
| 8 {{mojom_type}}Ptr& result = *output; | 8 {{mojom_type}}Ptr& result = *output; |
| 9 | 9 |
| 10 internal::UnionAccessor<{{mojom_type}}> result_acc(result.get()); | 10 internal::UnionAccessor<{{mojom_type}}> result_acc(result.get()); |
| 11 switch (input.tag()) { | 11 switch (input.tag()) { |
| 12 {%- for field in union.fields %} | 12 {%- for field in union.fields %} |
| 13 case {{mojom_type}}::Tag::{{field.name|upper}}: { | 13 case {{mojom_type}}::Tag::{{field.name|upper}}: { |
| 14 {%- set name = field.name %} | 14 {%- set name = field.name %} |
| 15 {%- set kind = field.kind %} | 15 {%- set kind = field.kind %} |
| 16 {%- set serializer_type = kind|unmapped_type_for_serializer %} | 16 {%- set serializer_type = kind|unmapped_type_for_serializer %} |
| 17 {%- if kind|is_object_kind %} | 17 {%- if kind|is_object_kind %} |
| 18 result_acc.SwitchActive({{mojom_type}}::Tag::{{name|upper}}); | 18 result_acc.SwitchActive({{mojom_type}}::Tag::{{name|upper}}); |
| 19 if (!input.Read{{name|under_to_camel}}(result_acc.data()->{{name}})) | 19 if (!input.Read{{name|under_to_camel}}(result_acc.data()->{{name}})) |
| 20 return false; | 20 return false; |
| 21 | 21 |
| 22 {%- elif kind|is_any_handle_or_interface_kind %} | 22 {%- elif kind|is_any_handle_kind %} |
| 23 auto result_{{name}} = input.Take{{name|under_to_camel}}(); | 23 auto result_{{name}} = input.Take{{name|under_to_camel}}(); |
| 24 result->set_{{name}}(std::move(result_{{name}})); | 24 result->set_{{name}}(std::move(result_{{name}})); |
| 25 | 25 |
| 26 {%- elif kind|is_any_interface_kind %} |
| 27 auto result_{{name}} = |
| 28 input.Take{{name|under_to_camel}}<typename std::remove_reference<declt
ype(result->get_{{name}}())>::type>(); |
| 29 result->set_{{name}}(std::move(result_{{name}})); |
| 30 |
| 26 {%- elif kind|is_enum_kind %} | 31 {%- elif kind|is_enum_kind %} |
| 27 decltype(result->get_{{name}}()) result_{{name}}; | 32 decltype(result->get_{{name}}()) result_{{name}}; |
| 28 if (!input.Read{{name|under_to_camel}}(&result_{{name}})) | 33 if (!input.Read{{name|under_to_camel}}(&result_{{name}})) |
| 29 return false; | 34 return false; |
| 30 result->set_{{name}}(result_{{name}}); | 35 result->set_{{name}}(result_{{name}}); |
| 31 | 36 |
| 32 {%- else %} | 37 {%- else %} |
| 33 result->set_{{name}}(input.{{name}}()); | 38 result->set_{{name}}(input.{{name}}()); |
| 34 {%- endif %} | 39 {%- endif %} |
| 35 break; | 40 break; |
| 36 } | 41 } |
| 37 {%- endfor %} | 42 {%- endfor %} |
| 38 default: | 43 default: |
| 39 return false; | 44 return false; |
| 40 } | 45 } |
| 41 return true; | 46 return true; |
| 42 } | 47 } |
| OLD | NEW |