aboutsummaryrefslogtreecommitdiff
path: root/objectivec/GPBMessage.m
Commit message (Collapse)AuthorAgeFilesLines
* Copy the value when setting message/data fields.Thomas Van Lenten2018-10-021-2/+10
| | | | | Follow ObjC conventions and how the generated header labels things by copying NSStrings/NSData fields when setting them.
* Remove stray 'return'.Thomas Van Lenten2018-10-021-1/+1
|
* Work around strange error with atomic and swift under Xcode 8.3.3.Thomas Van Lenten2018-01-311-0/+42
| | | | | | | | | | Haven't been able to make a repo case, but this should "fix" the problem by avoid it completely. - Move readOnlySemaphore_ into the .m file so it isn't exposed in any header. - Move GPBGetObjectIvarWithField() also to go with the new limited visibility on the readOnlySemaphore_.
* Work around the static analyzer false report.Thomas Van Lenten2018-01-311-0/+6
|
* Migrate away from deprecated OSAtomic APIs. (#4184)Jonathan Dierksen2018-01-221-2/+3
| | | | * Migrate away from deprecated OSAtomic APIs.
* Force a copy when saving the NSData that came from another.Thomas Van Lenten2018-01-031-1/+6
|
* Properly copy maps with string keys but pod values.Thomas Van Lenten2018-01-031-1/+2
| | | | | Add tests to cover all the common special casing in the runtime code to ensure things come out correctly.
* code review cleanupDave MacLachlan2017-11-151-5/+5
|
* Simplify getter/setter method implementationsDave MacLachlan2017-11-141-3/+8
| | | | | | | Remove unnecessary retain/releases for GPBFieldDescriptors when creating implementations with blocks. The descriptors do not need to be memory managed because they are essentially global constructs that are guaranteed to be around the lifetime of the app.
* When comparing message, require them to have the same descriptor.Thomas Van Lenten2017-11-031-3/+4
| | | | | This will cover someone subclassing the message, and also handles something crazy like someone comparing to a raw NSObject.
* If we fail to get a descriptor just super the method resolving.Thomas Van Lenten2017-06-221-1/+1
| | | | | | This should never happen, but if someone is swizzling or do other hooking of methods, anything is possible, so this seems slighty safer than they returning NO.
* ObjC: Preserve unknown fields in proto3 syntax files.Thomas Van Lenten2017-06-061-11/+5
| | | | | | As announced: https://groups.google.com/forum/#!topic/protobuf/VX5qEmTW3y0 The ObjC side of https://github.com/google/protobuf/issues/272
* Tighten up class usage/checks.Thomas Van Lenten2017-04-181-2/+2
| | | | | | | - Ensure extensions resolution/wiring is happening directly on the messageClass (incase someone is doing odd things our out classes). - Make the extension message check match the other class checks in for mergeFrom/isEqual/etc.
* Remove the use of dispatch_once that is heap backed.Thomas Van Lenten2017-03-291-0/+19
| | | | | | | | | Apple recently updated the docs on dispatch_once to point out that the storage for the dispatch_once_t must be static or global, but not something that was ever used before as the implementation doesn't use a memory barrier. So we drop the use and create the semaphore when needed and use an atomic swap deal with any threading races.
* Handing threading race resolving methods.Thomas Van Lenten2017-03-021-2/+11
| | | | | | | - Don't prune the extension registry as that can lead to failures when two threads are racing. - If adding the method fails, check and see if it already is bound to decide the return result. Deals with threading races binding the methods.
* Minor fix for autocreated object repeated fields and maps.Thomas Van Lenten2017-01-051-6/+10
| | | | | | | | | | | - If setting/clearing a repeated field/map that was objects, check the class before checking the autocreator. - Just to be paranoid, don’t mutate within copy/mutableCopy for the autocreated classes to ensure there is less chance of issues if someone does something really crazy threading wise. - Some more tests for the internal AutocreatedArray/AutocreatedDictionary classes to ensure things are working as expected. - Add Xcode 8.2 to the full_mac_build.sh supported list.
* Exposes the currently registered extensions for a message and removes the ↵Sergio Campamá2016-07-151-5/+0
| | | | internal sortedExtensionsInUse
* Validate the tag numbers when parsing. (#1725)Thomas Van Lenten2016-06-291-1/+4
| | | | | | | | | | | | | | | There was a twist code path (that some times showed up due to what happened to be in memory in failure cases), that would cast a bogus wire type into the enum, and then fall through switch statements. Resolve this by validating all wire types when parsing tags and throwing the error at that point so it can't enter the system. As added safety, stick in a few asserts for apis that get passed tags to ensure they also are only seeing valid data. Bonus: Tweak the parsing loop to skip some work when we get the end marker (zero tag) instead of still looping through all the fields.
* Fix GPBGetMessage{Repeated,Map}Field()Thomas Van Lenten2016-06-271-0/+30
| | | | | | | - Correct impl by using helpers the message wiring does. - Add unittests. Fixes https://github.com/google/protobuf/issues/1716
* Improving the granularity parsing errors (#1623)Sergio Campamá2016-06-021-12/+26
| | | | | | | | | Add more context to GPBCodedInputStream failures. Have GPBMessage parsing apis extract out the GPBCodedInputStream information and expose it. Update HeaderDocs with pointers to all error domains/codes. Expand the unittests to cover the full set of errors reported. Fixes https://github.com/google/protobuf/issues/1618
* Merge pull request #1620 from sergiocampama/cleanup1Thomas Van Lenten2016-05-301-5/+0
|\ | | | | Removing unused GPBExceptionMessageKey
| * Removing unused GPBExceptionMessageKeySergio Campama2016-05-271-5/+0
| | | | | | | | https://github.com/google/protobuf/issues/1618
* | Add -Woverriding-method-mismatch.Thomas Van Lenten2016-05-271-5/+6
|/ | | | | | | Fixes up the code to avoid some issues with isEqual: methods. Opened https://github.com/google/protobuf/issues/1616 to track the KVC collision.
* Add more warnings to for the ObjC runtime buildThomas Van Lenten2016-05-251-7/+15
| | | | | | | | | | | | | | Working on https://github.com/google/protobuf/issues/1599, specifically: - Turn on more warnings that the Xcode UI calls out with individual controls. - Manually add: -Wundef -Wswitch-enum - Manually add and then diable in the unittests because of XCTest's headers: -Wreserved-id-macro -Wdocumentation-unknown-command - Manually add -Wdirect-ivar-access, but disable it for the unittests and in the library code (via #pragmas to suppress it). This is done so proto users can enable the warning.
* Fix up -hash/-isEqual: for bool storage.Thomas Van Lenten2016-04-271-5/+13
| | | | | | | Both methods weren't checking the has_bits (where the bools are stored), so it resulted in invalid results. Add a test that should shake out something like this in the future also.
* The message was autoreleased, the -releases are an over release.Thomas Van Lenten2016-03-241-2/+0
|
* Only create the readonlySemaphore on demand.Thomas Van Lenten2016-03-211-3/+6
| | | | | | This will lower the amount of dispatch_semaphores created per Message when the full object tree isn't walked in a way that would require them to be created. Uses a dispatch_once_t for one time init of the dispatch_semaphore.
* Shrink ObjC overhead (generated size and some runtime sizes)Thomas Van Lenten2016-03-171-20/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | NOTE: This is a binary breaking change as structure sizes have changed size and/or order. - Drop capturing field options, no other options were captured and other mobile targeted languages don't try to capture this sort information (saved 8 bytes for every field defined (in static data and again in field descriptor instance size data). - No longer generate/compile in the messages/enums in descriptor.proto. If developers need it, they should generate it and compile it in. Reduced the overhead of the core library. - Compute the number of has_bits actually needs to avoid over reserving. - Let the boolean single fields store via a has_bit to avoid storage, makes the common cases of the instance size smaller. - Reorder some flags and down size the enums to contain the bits needed. - Reorder the items in the structures to manually ensure they are are packed better (especially when generating 64bit code - 8 bytes for every field, 16 bytes for every extension, instance sizes 8 bytes also). - Split off the structure initialization so when the default is zero, the generated static storage doesn't need to reserve the space. This is batched at the message level, so all the fields for the message have to have zero defaults to get the saves. By definition all proto3 syntax files fall into this case but it also saves space for the proto2 that use the standard defaults. (saves 8 bytes of static data for every field that had a zero default) - Don't track the enums defined by a message. Nothing in the runtime needs it and it was just generation and runtime overhead. (saves 8 bytes per enum) - Ensure EnumDescriptors are started up threadsafe in all cases. - Split some of the Descriptor initialization into multiple methods so the generated code isn't padded with lots of zero/nil args. - Change how oneof info is feed to the runtime enabling us to generate less static data (8 bytes saved per oneof for 64bit). - Change how enum value informat is capture to pack the data and only decode it if it ends up being needed. Avoids padding issues causing bloat of 64bit, and removes the needs for extra pointers in addition to the data (just the data and one pointer now).
* HeaderDoc support in the library and generated sourcesThomas Van Lenten2016-03-071-1/+1
| | | | | | | - Convert most of the core library headers over to HeaderDoc format. - Switch the generated comments over to HeaderDoc. - Create GPBCodedOutputStream_PackagePrivate and move some things into there that should be more internal.
* Release the semaphore in dealloc, fixing leak.Thomas Van Lenten2016-01-121-0/+1
|
* Drop all use of OSSpinLockThomas Van Lenten2015-12-171-7/+7
| | | | | | | | | | | | | Apple engineers have pointed out that OSSpinLocks are vulnerable to live locking on iOS in cases of priority inversion: . http://mjtsai.com/blog/2015/12/16/osspinlock-is-unsafe/ . https://lists.swift.org/pipermail/swift-dev/Week-of-Mon-20151214/000372.html - Use a dispatch_semaphore_t within the extension registry. - Use a dispatch_semaphore_t for protecting autocreation within messages. - Drop the custom/internal GPBString class since we don't have really good numbers to judge the locking replacements and it isn't required. We can always bring it back with real data in the future.
* Use compiler provided static assert and avoid tripping unused-local-typedef ↵Thomas Van Lenten2015-12-081-4/+9
| | | | warnings.
* Enable CLANG_WARN_NULLABLE_TO_NONNULL_CONVERSION for the projects.Thomas Van Lenten2015-12-071-2/+8
|
* Beta quality drop of Objective C Support.Thomas Van Lenten2015-06-081-2902/+1143
| | | | | | | | | | | | | | | - Add more to the ObjC dir readme. - Merge the ExtensionField and ExtensionDescriptor to reduce overhead. - Fix an initialization race. - Clean up the Xcode schemes. - Remove the class/enum filter. - Remove some forced inline that were bloating things without proof of performance wins. - Rename some internal types to avoid conflicts with the well know types protos. - Drop the use of ApplyFunctions to the compiler/optimizer can do what it wants. - Better document some possible future improvements. - Add missing support for parsing repeated primitive fields in packed or unpacked forms. - Improve -hash. - Add *Count for repeated and map<> fields to avoid auto create when checking for them being set.
* Objective C Second Alpha DropThomas Van Lenten2015-05-221-331/+536
| | | | | | | | | | - Style fixups in the code. - map<> serialization fixes and more tests. - Autocreation of map<> fields (to match repeated fields). - @@protoc_insertion_point(global_scope|imports). - Fixup proto2 syntax extension support. - Move all startup code to +initialize so it happen on class usage and not app startup. - Have generated headers use forward declarations and move imports into generated code, reduces what is need at compile time to speed up compiled and avoid pointless rippling of rebuilds.
* Alpha 1 drop of Google's Objective C plugin and runtime support for protobufs.Thomas Van Lenten2015-05-061-0/+4735