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

Unified Diff: mojo/public/tools/bindings/generators/dart_templates/struct_definition.tmpl

Issue 830593003: Update mojo sdk to rev 9fbbc4f0fef1187312316c0ed992342474e139f1 (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: cherry-pick mojo 9d3b8dd17f12d20035a14737fdc38dd926890ff8 Created 5 years, 11 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 side-by-side diff with in-line comments
Download patch
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 %}

Powered by Google App Engine
This is Rietveld 408576698