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

Side by Side Diff: mojo/public/tools/bindings/generators/java_templates/struct_definition.tmpl

Issue 648683003: mojo: Add maps to java bindings. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Follow review Created 6 years, 2 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 unified diff | Download patch
OLDNEW
1 {% from "constant_definition.tmpl" import constant_def %} 1 {% from "constant_definition.tmpl" import constant_def %}
2 {% from "enum_definition.tmpl" import enum_def %} 2 {% from "enum_definition.tmpl" import enum_def %}
3 3
4 {%- macro array_expected_length(kind) -%}
5 {%- if kind|is_fixed_array_kind -%}
6 {{kind.length}}
7 {%- else -%}
8 org.chromium.mojo.bindings.BindingsHelper.UNSPECIFIED_ARRAY_LENGTH
9 {%- endif -%}
10 {%- endmacro -%}
11
12 {% macro encode(variable, kind, offset, bit, level=0) %} 4 {% macro encode(variable, kind, offset, bit, level=0) %}
13 {% if kind|is_pointer_array_kind %} 5 {% if kind|is_pointer_array_kind %}
14 {% set sub_kind = kind.kind %} 6 {% set sub_kind = kind.kind %}
15 if ({{variable}} == null) { 7 if ({{variable}} == null) {
16 encoder{{level}}.encodeNullPointer({{offset}}, {{kind|is_nullable_kind|java_ true_false}}); 8 encoder{{level}}.encodeNullPointer({{offset}}, {{kind|is_nullable_kind|java_ true_false}});
17 } else { 9 } else {
18 org.chromium.mojo.bindings.Encoder encoder{{level + 1}} = encoder{{level}}.e ncodePointerArray({{variable}}.length, {{offset}}, {{array_expected_length(kind) }}); 10 org.chromium.mojo.bindings.Encoder encoder{{level + 1}} = encoder{{level}}.e ncodePointerArray({{variable}}.length, {{offset}}, {{kind|array_expected_length} });
19 for (int i{{level}} = 0; i{{level}} < {{variable}}.length; ++i{{level}}) { 11 for (int i{{level}} = 0; i{{level}} < {{variable}}.length; ++i{{level}}) {
20 {{encode(variable~'[i'~level~']', sub_kind, 'DataHeader.HEADER_SIZE + or g.chromium.mojo.bindings.BindingsHelper.POINTER_SIZE * i'~level, 0, level+1)|ind ent(8)}} 12 {{encode(variable~'[i'~level~']', sub_kind, 'DataHeader.HEADER_SIZE + or g.chromium.mojo.bindings.BindingsHelper.POINTER_SIZE * i'~level, 0, level+1)|ind ent(8)}}
21 } 13 }
22 } 14 }
15 {% elif kind|is_map_kind %}
16 if ({{variable}} == null) {
17 encoder{{level}}.encodeNullPointer({{offset}}, {{kind|is_nullable_kind|java_ true_false}});
18 } else {
19 org.chromium.mojo.bindings.Encoder encoder{{level + 1}} = encoder{{level}}.e ncoderForMap({{offset}});
20 int size{{level}} = {{variable}}.size();
21 {{kind.key_kind|java_type}}[] keys{{level}} = {{kind.key_kind|array|new_arra y('size'~level)}};
22 {{kind.value_kind|java_type}}[] values{{level}} = {{kind.value_kind|array|ne w_array('size'~level)}};
23 int index{{level}} = 0;
24 for (java.util.Map.Entry<{{kind.key_kind|java_type(true)}}, {{kind.value_kin d|java_type(true)}}> entry{{level}} : {{variable}}.entrySet()) {
25 keys{{level}}[index{{level}}] = entry{{level}}.getKey();
26 values{{level}}[index{{level}}] = entry{{level}}.getValue();
27 }
28 {{encode('keys'~level, kind.key_kind|array, 'DataHeader.HEADER_SIZE', 0, lev el+1)|indent(4)}}
29 {{encode('values'~level, kind.value_kind|array, 'DataHeader.HEADER_SIZE + or g.chromium.mojo.bindings.BindingsHelper.POINTER_SIZE', 0, level+1)|indent(4)}}
30 }
23 {% else %} 31 {% else %}
24 encoder{{level}}.{{kind|encode_method(variable, offset, bit)}}; 32 encoder{{level}}.{{kind|encode_method(variable, offset, bit)}};
25 {% endif %} 33 {% endif %}
26 {% endmacro %} 34 {% endmacro %}
27 35
28 {% macro decode(variable, kind, offset, bit, level=0) %} 36 {% macro decode(variable, kind, offset, bit, level=0) %}
29 {% if kind|is_struct_kind or kind|is_pointer_array_kind %} 37 {% if kind|is_struct_kind or kind|is_pointer_array_kind or kind|is_map_kind %}
30 org.chromium.mojo.bindings.Decoder decoder{{level+1}} = decoder{{level}}.readPoi nter({{offset}}, {{kind|is_nullable_kind|java_true_false}}); 38 org.chromium.mojo.bindings.Decoder decoder{{level+1}} = decoder{{level}}.readPoi nter({{offset}}, {{kind|is_nullable_kind|java_true_false}});
31 {% if kind|is_struct_kind %} 39 {% if kind|is_struct_kind %}
32 {{variable}} = {{kind|java_type}}.decode(decoder{{level+1}}); 40 {{variable}} = {{kind|java_type}}.decode(decoder{{level+1}});
33 {% else %}{# kind|is_pointer_array_kind #} 41 {% else %}{# kind|is_pointer_array_kind or is_map_kind #}
34 if (decoder{{level+1}} == null) { 42 if (decoder{{level+1}} == null) {
35 {{variable}} = null; 43 {{variable}} = null;
36 } else { 44 } else {
37 DataHeader si{{level+1}} = decoder{{level+1}}.readDataHeaderForPointerArray( {{array_expected_length(kind)}}); 45 {% if kind|is_map_kind %}
46 decoder{{level+1}}.readDataHeaderForMap();
47 {{kind.key_kind|java_type}}[] keys{{level}};
48 {{kind.value_kind|java_type}}[] values{{level}};
49 {
50 {{decode('keys'~level, kind.key_kind|array, 'DataHeader.HEADER_SIZE', 0, level+1)|indent(8)}}
51 }
52 {
53 {{decode('values'~level, kind.value_kind|array('keys'~level~'.length'), 'DataHeader.HEADER_SIZE + org.chromium.mojo.bindings.BindingsHelper.POINTER_SIZE ', 0, level+1)|indent(8)}}
54 }
55 {{variable}} = new java.util.HashMap<{{kind.key_kind|java_type(true)}}, {{ki nd.value_kind|java_type(true)}}>();
56 for (int index{{level}} = 0; index{{level}} < keys{{level}}.length; ++index{ {level}}) {
57 {{variable}}.put(keys{{level}}[index{{level}}], values{{level}}[index{{ level}}]);
58 }
59 {% else %}
60 DataHeader si{{level+1}} = decoder{{level+1}}.readDataHeaderForPointerArray( {{kind|array_expected_length}});
38 {{variable}} = {{kind|new_array('si'~(level+1)~'.numFields')}}; 61 {{variable}} = {{kind|new_array('si'~(level+1)~'.numFields')}};
39 for (int i{{level+1}} = 0; i{{level+1}} < si{{level+1}}.numFields; ++i{{leve l+1}}) { 62 for (int i{{level+1}} = 0; i{{level+1}} < si{{level+1}}.numFields; ++i{{leve l+1}}) {
40 {{decode(variable~'[i'~(level+1)~']', kind.kind, 'DataHeader.HEADER_SIZE + org.chromium.mojo.bindings.BindingsHelper.POINTER_SIZE * i'~(level+1), 0, lev el+1)|indent(8)}} 63 {{decode(variable~'[i'~(level+1)~']', kind.kind, 'DataHeader.HEADER_SIZE + org.chromium.mojo.bindings.BindingsHelper.POINTER_SIZE * i'~(level+1), 0, lev el+1)|indent(8)}}
41 } 64 }
65 {% endif %}
42 } 66 }
43 {% endif %} 67 {% endif %}
44 {% else %} 68 {% else %}
45 {{variable}} = decoder{{level}}.{{kind|decode_method(offset, bit)}}; 69 {{variable}} = decoder{{level}}.{{kind|decode_method(offset, bit)}};
46 {% endif %} 70 {% endif %}
47 {% endmacro %} 71 {% endmacro %}
48 72
49 {% macro struct_def(struct, inner_class=False) %} 73 {% macro struct_def(struct, inner_class=False) %}
50 {{'static' if inner_class else 'public'}} final class {{struct|name}} extends or g.chromium.mojo.bindings.Struct { 74 {{'static' if inner_class else 'public'}} final class {{struct|name}} extends or g.chromium.mojo.bindings.Struct {
51 75
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after
109 org.chromium.mojo.bindings.Encoder encoder0 = encoder.getEncoderAtDataOf fset(DEFAULT_STRUCT_INFO); 133 org.chromium.mojo.bindings.Encoder encoder0 = encoder.getEncoderAtDataOf fset(DEFAULT_STRUCT_INFO);
110 {% endif %} 134 {% endif %}
111 {% for byte in struct.bytes %} 135 {% for byte in struct.bytes %}
112 {% for packed_field in byte.packed_fields %} 136 {% for packed_field in byte.packed_fields %}
113 {{encode(packed_field.field|name, packed_field.field.kind, 8+packed_fiel d.offset, packed_field.bit)|indent(8)}} 137 {{encode(packed_field.field|name, packed_field.field.kind, 8+packed_fiel d.offset, packed_field.bit)|indent(8)}}
114 {% endfor %} 138 {% endfor %}
115 {% endfor %} 139 {% endfor %}
116 } 140 }
117 } 141 }
118 {% endmacro %} 142 {% endmacro %}
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698