1. 14 Jul, 2014 1 commit
  2. 15 Jul, 2014 1 commit
    • Max Cai's avatar
      Fix access around unknownFieldData. · d1a8a8f6
      Max Cai authored
      Instead of publishing its class I chose to encapsulate the troublesome
      references in equals()/hashCode() in the generated code into superclass
      methods in ExtendableMessageNano.
      
      Changed a couple of java packages in the test suite to catch this issue
      easier in the future.
      
      Change-Id: I43f88411f63bb6f3ffc8d63361f2f77bebf6220a
      d1a8a8f6
  3. 14 Jul, 2014 2 commits
    • Max Cai's avatar
      Merge "Keep pointers to extension values." · 30b1454d
      Max Cai authored
      30b1454d
    • Juan Silveira's avatar
      Keep pointers to extension values. · 79f19eb9
      Juan Silveira authored
      The current implementation of getExtension deserialises the field from bytes
      and returns a new object every time. This means that changes to those objects
      are reflected when the messages is serialised unless setExtension is called. It
      also means that every call to getExtension and setExtension is expensive.
      
      This change introduces a FieldData class that contains everything that's known
      about the field at the time. This can be all the tag/byte[] pairs associated
      with a given field or an Extension and a value object. This is so that two
      messages with a repeated extension can be compared even if the extension
      has been deserialised in one of them but not the other.
      
      This change also adds FieldArray class based on SparseArray from the Android
      compatibility library. This is used in ExtendableMessageNano to make lookup
      of FieldDatas by their field number faster.
      
      Implications:
      * calling getExtension multiple times deserialises the field only once and
        returns the same object.
      * calling setExtension doesn't cause the object to be serialised immediately,
        that only happens when the container message is serialised.
      * getExtension is no longer a read-only thread-safe operation. README.txt has
        been updated to relfect that.
      * comparison using equals and hashCode continues to work.
      
      Bug: 10863158
      
      Change-Id: I81c7cb0c73cc0611a1f7c1eabf5eed259738e8bc
      79f19eb9
  4. 02 May, 2014 3 commits
  5. 01 May, 2014 3 commits
  6. 29 Apr, 2014 1 commit
  7. 25 Apr, 2014 2 commits
    • Jeff Davidson's avatar
      a2724e7c
    • Jeff Davidson's avatar
      Support generation of Parcelable nano messages. · ec4b1ce0
      Jeff Davidson authored
      This CL adds the "parcelable_messages" option. When enabled, all
      generated message classes will conform to the Android Parcelable
      contract. This is achieved by introducing a new parent class for
      generated classes which implements the required functionality.
      
      Since the store_unknown_fields option also makes use of a superclass,
      ExtendableMessageNano, we have two versions of the new Parcelable
      superclass: one extending MessageNano, and one extending
      ExtendableMessageNano. These classes are otherwise identical.
      
      As these classes depend on Android framework jars, they are not
      included in the host .jar build of the nanoproto library.
      
      Finally, add a test suite for running tests of Android-specific
      functionality, as this cannot be done on a desktop JVM.
      
      Change-Id: Icc2a257f03317e947f7078dbb9857c3286857497
      ec4b1ce0
  8. 24 Apr, 2014 1 commit
  9. 23 Apr, 2014 1 commit
    • Jie Dai's avatar
      Adds --ignore_service nano proto compiler flag · d9425a62
      Jie Dai authored
      Nano proto compiler normally throws an error if any service is
      defined. If --ignore-services=true is set, no error is thrown and the
      service is simply skipped.
      
      Change-Id: Id82583555085cc55550d03a485d3f0189885240b
      d9425a62
  10. 14 Apr, 2014 1 commit
  11. 10 Apr, 2014 1 commit
  12. 22 Mar, 2014 3 commits
  13. 21 Mar, 2014 3 commits
  14. 08 Mar, 2014 1 commit
  15. 07 Mar, 2014 2 commits
  16. 17 Feb, 2014 1 commit
  17. 10 Feb, 2014 1 commit
  18. 16 Jan, 2014 2 commits
  19. 14 Jan, 2014 3 commits
  20. 13 Jan, 2014 4 commits
  21. 10 Jan, 2014 3 commits
    • Max Cai's avatar
      Correctness: floating point equality using bits instead of ==. · 79b311c1
      Max Cai authored
      Special values for float and double make it inaccurate to test the equality with ==.
      The main Java library uses the standard Object.equals() implementation for all fields,
      which for floating point fields means Float.equals() or Double.equals(). They define
      equality as bitwise equality, with all NaN representations normalized to the same bit
      sequence (and therefore equal to each other). This test checks that the nano
      implementation complies with Object.equals(), so NaN == NaN and +0.0 != -0.0.
      
      Change-Id: I97bb4a3687223d8a212c70cd736436b9dd80c1d7
      79b311c1
    • Max Cai's avatar
      Don't serialize required fields whose 'has' flags are unset. · 1b1735ce
      Max Cai authored
      Change-Id: Ibbe944fff83e44a8f2206e18ee9ec6f10661297a
      1b1735ce
    • Max Cai's avatar
      Extension overhaul. · e3714f00
      Max Cai authored
      - Get rid of TypeLiteral<T>. It was introduced to read the component
        type of a List<T> at runtime. But we use arrays everywhere else,
        and we can always read the component type of an array type at
        runtime.
      - Properly read/write "minor" types (e.g. sint32, sfixed32). The old
        implementation could only read/write data as the "typical" types
        (one per Java type), e.g. java.lang.Integer -> int32, java.lang.Long
        -> int64. So if e.g. an extension specifies sfixed32 as the type, it
        would be read/written in the totally incompatible int32 format.
      - Properly serialize repeated packed fields. The old implementation
        doesn't do packed serialization. As an added bonus, and to be more
        aligned with the rest of protobuf nano / main, repeated packable
        extensions can deserialize both packed and non-packed data.
      - Split Extension class into a hierarchy so under typical usage a
        large chunk of code dealing with primitive type extensions can be
        removed by ProGuard.
      
      Bug: https://code.google.com/p/android/issues/detail?id=62586
      Change-Id: I0d692f35cc2a8ad3a5a1cb3ce001282b2356b041
      e3714f00