1ffe3c632Sopenharmony_ci// Protocol Buffers - Google's data interchange format 2ffe3c632Sopenharmony_ci// Copyright 2008 Google Inc. All rights reserved. 3ffe3c632Sopenharmony_ci// https://developers.google.com/protocol-buffers/ 4ffe3c632Sopenharmony_ci// 5ffe3c632Sopenharmony_ci// Redistribution and use in source and binary forms, with or without 6ffe3c632Sopenharmony_ci// modification, are permitted provided that the following conditions are 7ffe3c632Sopenharmony_ci// met: 8ffe3c632Sopenharmony_ci// 9ffe3c632Sopenharmony_ci// * Redistributions of source code must retain the above copyright 10ffe3c632Sopenharmony_ci// notice, this list of conditions and the following disclaimer. 11ffe3c632Sopenharmony_ci// * Redistributions in binary form must reproduce the above 12ffe3c632Sopenharmony_ci// copyright notice, this list of conditions and the following disclaimer 13ffe3c632Sopenharmony_ci// in the documentation and/or other materials provided with the 14ffe3c632Sopenharmony_ci// distribution. 15ffe3c632Sopenharmony_ci// * Neither the name of Google Inc. nor the names of its 16ffe3c632Sopenharmony_ci// contributors may be used to endorse or promote products derived from 17ffe3c632Sopenharmony_ci// this software without specific prior written permission. 18ffe3c632Sopenharmony_ci// 19ffe3c632Sopenharmony_ci// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 20ffe3c632Sopenharmony_ci// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 21ffe3c632Sopenharmony_ci// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 22ffe3c632Sopenharmony_ci// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 23ffe3c632Sopenharmony_ci// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 24ffe3c632Sopenharmony_ci// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 25ffe3c632Sopenharmony_ci// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 26ffe3c632Sopenharmony_ci// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 27ffe3c632Sopenharmony_ci// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 28ffe3c632Sopenharmony_ci// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 29ffe3c632Sopenharmony_ci// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 30ffe3c632Sopenharmony_ci 31ffe3c632Sopenharmony_ci#import <Foundation/Foundation.h> 32ffe3c632Sopenharmony_ci 33ffe3c632Sopenharmony_ci@class GPBDescriptor; 34ffe3c632Sopenharmony_ci@class GPBExtensionDescriptor; 35ffe3c632Sopenharmony_ci 36ffe3c632Sopenharmony_ciNS_ASSUME_NONNULL_BEGIN 37ffe3c632Sopenharmony_ci 38ffe3c632Sopenharmony_ci/** 39ffe3c632Sopenharmony_ci * A table of known extensions, searchable by name or field number. When 40ffe3c632Sopenharmony_ci * parsing a protocol message that might have extensions, you must provide a 41ffe3c632Sopenharmony_ci * GPBExtensionRegistry in which you have registered any extensions that you 42ffe3c632Sopenharmony_ci * want to be able to parse. Otherwise, those extensions will just be treated 43ffe3c632Sopenharmony_ci * like unknown fields. 44ffe3c632Sopenharmony_ci * 45ffe3c632Sopenharmony_ci * The *Root classes provide `+extensionRegistry` for the extensions defined 46ffe3c632Sopenharmony_ci * in a given file *and* all files it imports. You can also create a 47ffe3c632Sopenharmony_ci * GPBExtensionRegistry, and merge those registries to handle parsing 48ffe3c632Sopenharmony_ci * extensions defined from non overlapping files. 49ffe3c632Sopenharmony_ci * 50ffe3c632Sopenharmony_ci * ``` 51ffe3c632Sopenharmony_ci * GPBExtensionRegistry *registry = [[MyProtoFileRoot extensionRegistry] copy]; 52ffe3c632Sopenharmony_ci * [registry addExtension:[OtherMessage neededExtension]]; // Not in MyProtoFile 53ffe3c632Sopenharmony_ci * NSError *parseError; 54ffe3c632Sopenharmony_ci * MyMessage *msg = [MyMessage parseData:data extensionRegistry:registry error:&parseError]; 55ffe3c632Sopenharmony_ci * ``` 56ffe3c632Sopenharmony_ci **/ 57ffe3c632Sopenharmony_ci@interface GPBExtensionRegistry : NSObject<NSCopying> 58ffe3c632Sopenharmony_ci 59ffe3c632Sopenharmony_ci/** 60ffe3c632Sopenharmony_ci * Adds the given GPBExtensionDescriptor to this registry. 61ffe3c632Sopenharmony_ci * 62ffe3c632Sopenharmony_ci * @param extension The extension description to add. 63ffe3c632Sopenharmony_ci **/ 64ffe3c632Sopenharmony_ci- (void)addExtension:(GPBExtensionDescriptor *)extension; 65ffe3c632Sopenharmony_ci 66ffe3c632Sopenharmony_ci/** 67ffe3c632Sopenharmony_ci * Adds all the extensions from another registry to this registry. 68ffe3c632Sopenharmony_ci * 69ffe3c632Sopenharmony_ci * @param registry The registry to merge into this registry. 70ffe3c632Sopenharmony_ci **/ 71ffe3c632Sopenharmony_ci- (void)addExtensions:(GPBExtensionRegistry *)registry; 72ffe3c632Sopenharmony_ci 73ffe3c632Sopenharmony_ci/** 74ffe3c632Sopenharmony_ci * Looks for the extension registered for the given field number on a given 75ffe3c632Sopenharmony_ci * GPBDescriptor. 76ffe3c632Sopenharmony_ci * 77ffe3c632Sopenharmony_ci * @param descriptor The descriptor to look for a registered extension on. 78ffe3c632Sopenharmony_ci * @param fieldNumber The field number of the extension to look for. 79ffe3c632Sopenharmony_ci * 80ffe3c632Sopenharmony_ci * @return The registered GPBExtensionDescriptor or nil if none was found. 81ffe3c632Sopenharmony_ci **/ 82ffe3c632Sopenharmony_ci- (nullable GPBExtensionDescriptor *)extensionForDescriptor:(GPBDescriptor *)descriptor 83ffe3c632Sopenharmony_ci fieldNumber:(NSInteger)fieldNumber; 84ffe3c632Sopenharmony_ci 85ffe3c632Sopenharmony_ci@end 86ffe3c632Sopenharmony_ci 87ffe3c632Sopenharmony_ciNS_ASSUME_NONNULL_END 88