Commit 12d8a514 authored by Jisi Liu's avatar Jisi Liu

Get the map factory per mergeFrom() call for JavaNano.

parent d9a6f27b
...@@ -30,6 +30,8 @@ ...@@ -30,6 +30,8 @@
package com.google.protobuf.nano; package com.google.protobuf.nano;
import com.google.protobuf.nano.MapFactories.MapFactory;
import java.io.IOException; import java.io.IOException;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import java.util.Arrays; import java.util.Arrays;
...@@ -406,12 +408,13 @@ public final class InternalNano { ...@@ -406,12 +408,13 @@ public final class InternalNano {
public static final <K, V> Map<K, V> mergeMapEntry( public static final <K, V> Map<K, V> mergeMapEntry(
CodedInputByteBufferNano input, CodedInputByteBufferNano input,
Map<K, V> map, Map<K, V> map,
MapFactory mapFactory,
int keyType, int keyType,
int valueType, int valueType,
V value, V value,
int keyTag, int keyTag,
int valueTag) throws IOException { int valueTag) throws IOException {
map = MapFactories.getMapFactory().forMap(map); map = mapFactory.forMap(map);
final int length = input.readRawVarint32(); final int length = input.readRawVarint32();
final int oldLimit = input.pushLimit(length); final int oldLimit = input.pushLimit(length);
K key = null; K key = null;
......
...@@ -560,6 +560,17 @@ void SetBitOperationVariables(const string name, ...@@ -560,6 +560,17 @@ void SetBitOperationVariables(const string name,
(*variables)["different_" + name] = GenerateDifferentBit(bitIndex); (*variables)["different_" + name] = GenerateDifferentBit(bitIndex);
} }
bool HasMapField(const Descriptor* descriptor) {
for (int i = 0; i < descriptor->field_count(); ++i) {
const FieldDescriptor* field = descriptor->field(i);
if (field->type() == FieldDescriptor::TYPE_MESSAGE &&
IsMapEntry(field->message_type())) {
return true;
}
}
return false;
}
} // namespace javanano } // namespace javanano
} // namespace compiler } // namespace compiler
} // namespace protobuf } // namespace protobuf
......
...@@ -187,6 +187,8 @@ inline bool IsMapEntry(const Descriptor* descriptor) { ...@@ -187,6 +187,8 @@ inline bool IsMapEntry(const Descriptor* descriptor) {
descriptor->file()->syntax() == FileDescriptor::SYNTAX_PROTO3; descriptor->file()->syntax() == FileDescriptor::SYNTAX_PROTO3;
} }
bool HasMapField(const Descriptor* descriptor);
} // namespace javanano } // namespace javanano
} // namespace compiler } // namespace compiler
} // namespace protobuf } // namespace protobuf
......
...@@ -134,7 +134,7 @@ void MapFieldGenerator:: ...@@ -134,7 +134,7 @@ void MapFieldGenerator::
GenerateMergingCode(io::Printer* printer) const { GenerateMergingCode(io::Printer* printer) const {
printer->Print(variables_, printer->Print(variables_,
"this.$name$ = com.google.protobuf.nano.InternalNano.mergeMapEntry(\n" "this.$name$ = com.google.protobuf.nano.InternalNano.mergeMapEntry(\n"
" input, this.$name$,\n" " input, this.$name$, mapFactory,\n"
" com.google.protobuf.nano.InternalNano.$key_desc_type$,\n" " com.google.protobuf.nano.InternalNano.$key_desc_type$,\n"
" com.google.protobuf.nano.InternalNano.$value_desc_type$,\n" " com.google.protobuf.nano.InternalNano.$value_desc_type$,\n"
" $value_default$,\n" " $value_default$,\n"
......
...@@ -345,6 +345,11 @@ void MessageGenerator::GenerateMergeFromMethods(io::Printer* printer) { ...@@ -345,6 +345,11 @@ void MessageGenerator::GenerateMergeFromMethods(io::Printer* printer) {
"classname", descriptor_->name()); "classname", descriptor_->name());
printer->Indent(); printer->Indent();
if (HasMapField(descriptor_)) {
printer->Print(
"com.google.protobuf.nano.MapFactories.MapFactory mapFactory =\n"
" com.google.protobuf.nano.MapFactories.getMapFactory();\n");
}
printer->Print( printer->Print(
"while (true) {\n"); "while (true) {\n");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment