diff options
author | Max Cai <maxtroy@google.com> | 2013-10-09 13:36:23 +0100 |
---|---|---|
committer | Max Cai <maxtroy@google.com> | 2013-12-10 16:46:22 +0000 |
commit | 5cc242074f189837b38e7768b57ccfb0bca258df (patch) | |
tree | 186c81cc5282eb6ae8056ad478692e3a24188e33 /src/google/protobuf/compiler/javanano/javanano_primitive_field.h | |
parent | cea499acf68b35921b956785c26c0e6f18c241c1 (diff) | |
download | external_protobuf-5cc242074f189837b38e7768b57ccfb0bca258df.zip external_protobuf-5cc242074f189837b38e7768b57ccfb0bca258df.tar.gz external_protobuf-5cc242074f189837b38e7768b57ccfb0bca258df.tar.bz2 |
Avoid class initializers to help ProGuard.
Class initializers prevent ProGuard from inlining any methods
because it thinks the class initializer may have side effects.
This is true for static methods, but instance methods can still
be inlined, because to have an instance you will have touched
the class and any class initializers would have run. But
ProGuard only starts inlining instance methods of classes with
class initializers from v4.11b6, and Android uses v4.4 now.
This change tries to avoid the class initializers as much as
possible, by delaying the initialization of the empty array and
some fields' saved defaults until when they're needed. However,
if the message hosts any extensions, they must be public static
final and therefore introducing the class initializer. In that
case we won't bother with lazy initialization.
Change-Id: I00d8296f6eb0023112b93ee135cdb28dbd52b0b8
Diffstat (limited to 'src/google/protobuf/compiler/javanano/javanano_primitive_field.h')
-rw-r--r-- | src/google/protobuf/compiler/javanano/javanano_primitive_field.h | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/src/google/protobuf/compiler/javanano/javanano_primitive_field.h b/src/google/protobuf/compiler/javanano/javanano_primitive_field.h index d207535..c04a19b 100644 --- a/src/google/protobuf/compiler/javanano/javanano_primitive_field.h +++ b/src/google/protobuf/compiler/javanano/javanano_primitive_field.h @@ -46,11 +46,14 @@ namespace javanano { class PrimitiveFieldGenerator : public FieldGenerator { public: - explicit PrimitiveFieldGenerator(const FieldDescriptor* descriptor, const Params ¶ms); + explicit PrimitiveFieldGenerator( + const FieldDescriptor* descriptor, const Params ¶ms); ~PrimitiveFieldGenerator(); // implements FieldGenerator --------------------------------------- - void GenerateMembers(io::Printer* printer) const; + bool SavedDefaultNeeded() const; + void GenerateInitSavedDefaultCode(io::Printer* printer) const; + void GenerateMembers(io::Printer* printer, bool lazy_init) const; void GenerateClearCode(io::Printer* printer) const; void GenerateMergingCode(io::Printer* printer) const; void GenerateSerializationCode(io::Printer* printer) const; @@ -69,12 +72,14 @@ class PrimitiveFieldGenerator : public FieldGenerator { class AccessorPrimitiveFieldGenerator : public FieldGenerator { public: - explicit AccessorPrimitiveFieldGenerator( const FieldDescriptor* descriptor, + explicit AccessorPrimitiveFieldGenerator(const FieldDescriptor* descriptor, const Params ¶ms, int has_bit_index); ~AccessorPrimitiveFieldGenerator(); // implements FieldGenerator --------------------------------------- - void GenerateMembers(io::Printer* printer) const; + bool SavedDefaultNeeded() const; + void GenerateInitSavedDefaultCode(io::Printer* printer) const; + void GenerateMembers(io::Printer* printer, bool lazy_init) const; void GenerateClearCode(io::Printer* printer) const; void GenerateMergingCode(io::Printer* printer) const; void GenerateSerializationCode(io::Printer* printer) const; @@ -95,7 +100,7 @@ class RepeatedPrimitiveFieldGenerator : public FieldGenerator { ~RepeatedPrimitiveFieldGenerator(); // implements FieldGenerator --------------------------------------- - void GenerateMembers(io::Printer* printer) const; + void GenerateMembers(io::Printer* printer, bool lazy_init) const; void GenerateClearCode(io::Printer* printer) const; void GenerateMergingCode(io::Printer* printer) const; void GenerateMergingCodeFromPacked(io::Printer* printer) const; |