| Index: mojo/public/tools/bindings/generators/dart_templates/struct_definition.tmpl
|
| diff --git a/mojo/public/tools/bindings/generators/dart_templates/struct_definition.tmpl b/mojo/public/tools/bindings/generators/dart_templates/struct_definition.tmpl
|
| index 6e18dc89f36b683b70f7703f681d7540ce77d805..f5b62a9eeb285e21a05f30faa3060d0cd72071e7 100644
|
| --- a/mojo/public/tools/bindings/generators/dart_templates/struct_definition.tmpl
|
| +++ b/mojo/public/tools/bindings/generators/dart_templates/struct_definition.tmpl
|
| @@ -1,73 +1,136 @@
|
| {#--- Begin #}
|
|
|
| -class {{struct.name}} {
|
| +{%- macro encode(variable, kind, offset, bit, level=0, check_for_null=True) %}
|
| +{%- if kind|is_pointer_array_kind %}
|
| +{%- set sub_kind = kind.kind %}
|
| +{%- if check_for_null %}
|
| +if ({{variable}} == null) {
|
| + encoder{{level}}.encodeNullPointer({{offset}}, {{kind|is_nullable_kind|dart_true_false}});
|
| +} else {
|
| +{%- else %}
|
| +{
|
| +{%- endif %}
|
| + var encoder{{level + 1}} = encoder{{level}}.encodePointerArray({{variable}}.length, {{offset}}, {{kind|array_expected_length}});
|
| + for (int i{{level}} = 0; i{{level}} < {{variable}}.length; ++i{{level}}) {
|
| + {{encode(variable~'[i'~level~']', sub_kind, 'bindings.DataHeader.kHeaderSize + bindings.kPointerSize * i'~level, 0, level+1)|indent(4)}}
|
| + }
|
| +}
|
| +{%- elif kind|is_map_kind %}
|
| +if ({{variable}} == null) {
|
| + encoder{{level}}.encodeNullPointer({{offset}}, {{kind|is_nullable_kind|dart_true_false}});
|
| +} else {
|
| + var encoder{{level + 1}} = encoder{{level}}.encoderForMap({{offset}});
|
| + int size{{level}} = {{variable}}.length;
|
| + var keys{{level}} = {{variable}}.keys.toList();
|
| + var values{{level}} = {{variable}}.values.toList();
|
| + {{encode('keys'~level, kind.key_kind|array, 'bindings.DataHeader.kHeaderSize', 0, level+1, False)|indent(2)}}
|
| + {{encode('values'~level, kind.value_kind|array, 'bindings.DataHeader.kHeaderSize + bindings.kPointerSize', 0, level+1, False)|indent(2)}}
|
| +}
|
| +{%- else %}
|
| +encoder{{level}}.{{kind|encode_method(variable, offset, bit)}};
|
| +{%- endif %}
|
| +{%- endmacro %}
|
| +
|
| +
|
| +{%- macro decode(variable, kind, offset, bit, level=0) %}
|
| +{%- if kind|is_struct_kind or kind|is_pointer_array_kind or kind|is_map_kind %}
|
| +var decoder{{level+1}} = decoder{{level}}.decodePointer({{offset}}, {{kind|is_nullable_kind|dart_true_false}});
|
| +{%- if kind|is_struct_kind %}
|
| +{{variable}} = {{kind|dart_type}}.decode(decoder{{level+1}});
|
| +{%- else %}{# kind|is_pointer_array_kind or is_map_kind #}
|
| +{%- if kind|is_nullable_kind %}
|
| +if (decoder{{level+1}} == null) {
|
| + {{variable}} = null;
|
| +} else {
|
| +{%- else %}
|
| +{
|
| +{%- endif %}
|
| +{%- if kind|is_map_kind %}
|
| + decoder{{level+1}}.decodeDataHeaderForMap();
|
| + List<{{kind.key_kind|dart_type}}> keys{{level}};
|
| + List<{{kind.value_kind|dart_type}}> values{{level}};
|
| + {
|
| + {{decode('keys'~level, kind.key_kind|array, 'DataHeader.HEADER_SIZE', 0, level+1)|indent(4)}}
|
| + }
|
| + {
|
| + {{decode('values'~level, kind.value_kind|array('keys'~level~'.length'), 'bindings.DataHeader.kHeaderSize + bindings.kPointerSize', 0, level+1)|indent(4)}}
|
| + }
|
| + {{variable}} = new Map<{{kind.key_kind|dart_type}}, {{kind.value_kind|dart_type}}>.fromIterables(keys, values);
|
| +{%- else %}
|
| + var si{{level+1}} = decoder{{level+1}}.decodeDataHeaderForPointerArray({{kind|array_expected_length}});
|
| + {{variable}} = new {{kind|dart_type}}(si{{level+1}}.numFields);
|
| + for (int i{{level+1}} = 0; i{{level+1}} < si{{level+1}}.numFields; ++i{{level+1}}) {
|
| + {{decode(variable~'[i'~(level+1)~']', kind.kind, 'bindings.DataHeader.kHeaderSize + bindings.kPointerSize * i'~(level+1), 0, level+1)|indent(4)}}
|
| + }
|
| +{%- endif %}
|
| +}
|
| +{%- endif %}
|
| +{%- else %}
|
| +{{variable}} = decoder{{level}}.{{kind|decode_method(offset, bit)}};
|
| +{%- endif %}
|
| +{%- endmacro %}
|
| +
|
| +
|
| +{%- macro struct_def(struct) %}
|
| +class {{struct|name}} extends bindings.Struct {
|
| + static const int kStructSize = {{struct.packed|struct_size}};
|
| + static const bindings.DataHeader kDefaultStructInfo =
|
| + const bindings.DataHeader(kStructSize, {{struct.packed.packed_fields|length}});
|
| +
|
| {#--- Enums #}
|
| {%- from "enum_definition.tmpl" import enum_def %}
|
| -{% for enum in struct.enums %}
|
| +{%- for enum in struct.enums %}
|
| {{enum_def(" static ", enum)}}
|
| {%- endfor %}
|
|
|
|
|
| {#--- Constants #}
|
| -{% for constant in struct.constants %}
|
| +{%- for constant in struct.constants %}
|
| static final {{constant.name}} = {{constant.value|expression_to_text}};
|
| {%- endfor %}
|
|
|
| -
|
| {#--- initDefaults() #}
|
| {%- for packed_field in struct.packed.packed_fields %}
|
| - {{packed_field.field.kind|dart_decl_type}} {{packed_field.field.name}} = {{packed_field.field|default_value}};
|
| + {{packed_field.field.kind|dart_type}} {{packed_field.field|name}} = {{packed_field.field|default_value}};
|
| {%- endfor %}
|
|
|
| - {{struct.name}}();
|
| -
|
| -{#--- Encoding and decoding #}
|
| + {{struct|name}}() : super(kStructSize);
|
|
|
| - static const int encodedSize =
|
| - bindings.kStructHeaderSize + {{struct.packed|payload_size}};
|
| + static {{struct|name}} deserialize(bindings.Message message) {
|
| + return decode(new bindings.Decoder(message));
|
| + }
|
|
|
| - static {{struct.name}} decode(bindings.MojoDecoder decoder) {
|
| - var packed;
|
| - var val = new {{struct.name}}();
|
| - var numberOfBytes = decoder.readUint32();
|
| - var numberOfFields = decoder.readUint32();
|
| + static {{struct|name}} decode(bindings.Decoder decoder0) {
|
| + if (decoder0 == null) {
|
| + return null;
|
| + }
|
| + {{struct|name}} result = new {{struct|name}}();
|
| +{%- if not struct.bytes %}
|
| + decoder0.decodeDataHeader();
|
| +{%- else %}
|
| + var mainDataHeader = decoder0.decodeDataHeader();
|
| +{%- endif %}
|
| {%- for byte in struct.bytes %}
|
| -{%- if byte.packed_fields|length > 1 %}
|
| - packed = decoder.readUint8();
|
| -{%- for packed_field in byte.packed_fields %}
|
| - val.{{packed_field.field.name}} = (((packed >> {{packed_field.bit}}) & 1) != 0) ? true : false;
|
| -{%- endfor %}
|
| -{%- else %}
|
| -{%- for packed_field in byte.packed_fields %}
|
| - val.{{packed_field.field.name}} = decoder.{{packed_field.field.kind|decode_snippet}};
|
| -{%- endfor %}
|
| -{%- endif %}
|
| -{%- if byte.is_padding %}
|
| - decoder.skip(1);
|
| -{%- endif %}
|
| +{%- for packed_field in byte.packed_fields %}
|
| + if (mainDataHeader.numFields > {{packed_field.ordinal}}) {
|
| + {{decode('result.' ~ packed_field.field|name, packed_field.field.kind, 8+packed_field.offset, packed_field.bit)|indent(6)}}
|
| + }
|
| +{%- endfor %}
|
| {%- endfor %}
|
| - return val;
|
| + return result;
|
| }
|
|
|
| - static void encode(bindings.MojoEncoder encoder, {{struct.name}} val) {
|
| - var packed;
|
| - encoder.writeUint32({{struct.name}}.encodedSize);
|
| - encoder.writeUint32({{struct.packed.packed_fields|length}});
|
| + void encode(bindings.Encoder encoder) {
|
| +{%- if not struct.bytes %}
|
| + encoder.getEncoderAtOffset(kDefaultStructInfo);
|
| +{%- else %}
|
| + var encoder0 = encoder.getEncoderAtOffset(kDefaultStructInfo);
|
| +{%- endif %}
|
| {%- for byte in struct.bytes %}
|
| -{%- if byte.packed_fields|length > 1 %}
|
| - packed = 0;
|
| -{%- for packed_field in byte.packed_fields %}
|
| - packed |= (val.{{packed_field.field.name}} & 1) << {{packed_field.bit}};
|
| -{%- endfor %}
|
| - encoder.writeUint8(packed);
|
| -{%- else %}
|
| -{%- for packed_field in byte.packed_fields %}
|
| - encoder.{{packed_field.field.kind|encode_snippet}}val.{{packed_field.field.name}});
|
| -{%- endfor %}
|
| -{%- endif %}
|
| -{%- if byte.is_padding %}
|
| - encoder.skip(1);
|
| -{%- endif %}
|
| +{%- for packed_field in byte.packed_fields %}
|
| + {{encode(packed_field.field|name, packed_field.field.kind, 8+packed_field.offset, packed_field.bit)|indent(4)}}
|
| +{%- endfor %}
|
| {%- endfor %}
|
| }
|
| }
|
| +{%- endmacro %}
|
|
|