| Index: third_party/mojo/src/mojo/public/tools/bindings/generators/java_templates/struct_definition.tmpl
|
| diff --git a/third_party/mojo/src/mojo/public/tools/bindings/generators/java_templates/struct_definition.tmpl b/third_party/mojo/src/mojo/public/tools/bindings/generators/java_templates/struct_definition.tmpl
|
| index 333e0dab66680d3a5e507fb543a009ed31bf354d..f0cb98298c9f054176916254b406f246f987b7f2 100644
|
| --- a/third_party/mojo/src/mojo/public/tools/bindings/generators/java_templates/struct_definition.tmpl
|
| +++ b/third_party/mojo/src/mojo/public/tools/bindings/generators/java_templates/struct_definition.tmpl
|
| @@ -95,8 +95,8 @@ if (decoder{{level+1}} == null) {
|
| }
|
| {% else %}
|
| DataHeader si{{level+1}} = decoder{{level+1}}.readDataHeaderForPointerArray({{kind|array_expected_length}});
|
| - {{variable}} = {{kind|new_array('si'~(level+1)~'.numFields')}};
|
| - for (int i{{level+1}} = 0; i{{level+1}} < si{{level+1}}.numFields; ++i{{level+1}}) {
|
| + {{variable}} = {{kind|new_array('si'~(level+1)~'.elementsOrVersion')}};
|
| + for (int i{{level+1}} = 0; i{{level+1}} < si{{level+1}}.elementsOrVersion; ++i{{level+1}}) {
|
| {{decode(variable~'[i'~(level+1)~']', kind.kind, 'DataHeader.HEADER_SIZE + org.chromium.mojo.bindings.BindingsHelper.POINTER_SIZE * i'~(level+1), 0, level+1)|indent(8)}}
|
| }
|
| {% endif %}
|
| @@ -111,7 +111,12 @@ if (decoder{{level+1}} == null) {
|
| {{'static' if inner_class else 'public'}} final class {{struct|name}} extends org.chromium.mojo.bindings.Struct {
|
|
|
| private static final int STRUCT_SIZE = {{struct.versions[-1].num_bytes}};
|
| - private static final DataHeader DEFAULT_STRUCT_INFO = new DataHeader(STRUCT_SIZE, {{struct.packed.packed_fields|length}});
|
| + private static final DataHeader[] VERSION_ARRAY = new DataHeader[] {
|
| +{%- for version in struct.versions -%}
|
| + new DataHeader({{version.num_bytes}}, {{version.version}}){% if not loop.last %}, {% endif -%}
|
| +{%- endfor -%}
|
| + };
|
| + private static final DataHeader DEFAULT_STRUCT_INFO = VERSION_ARRAY[{{struct.versions|length - 1}}];
|
| {% for constant in struct.constants %}
|
|
|
| {{constant_def(constant)|indent(4)}}
|
| @@ -149,13 +154,13 @@ if (decoder{{level+1}} == null) {
|
| }
|
| {{struct|name}} result = new {{struct|name}}();
|
| {% if not struct.bytes %}
|
| - decoder0.readDataHeader();
|
| + decoder0.readAndValidateDataHeader(VERSION_ARRAY);
|
| {% else %}
|
| - DataHeader mainDataHeader = decoder0.readDataHeader();
|
| + DataHeader mainDataHeader = decoder0.readAndValidateDataHeader(VERSION_ARRAY);
|
| {% endif %}
|
| {% for byte in struct.bytes %}
|
| {% for packed_field in byte.packed_fields %}
|
| - if (mainDataHeader.numFields > {{packed_field.ordinal}}) {
|
| + if (mainDataHeader.elementsOrVersion >= {{packed_field.min_version}}) {
|
| {{decode('result.' ~ packed_field.field|name, packed_field.field.kind, 8+packed_field.offset, packed_field.bit)|indent(12)}}
|
| }
|
| {% endfor %}
|
|
|