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 GPBUnknownField; 34ffe3c632Sopenharmony_ci 35ffe3c632Sopenharmony_ciNS_ASSUME_NONNULL_BEGIN 36ffe3c632Sopenharmony_ci 37ffe3c632Sopenharmony_ci/** 38ffe3c632Sopenharmony_ci * A collection of unknown fields. Fields parsed from the binary representation 39ffe3c632Sopenharmony_ci * of a message that are unknown end up in an instance of this set. This only 40ffe3c632Sopenharmony_ci * applies for files declared with the "proto2" syntax. Files declared with the 41ffe3c632Sopenharmony_ci * "proto3" syntax discard the unknown values. 42ffe3c632Sopenharmony_ci **/ 43ffe3c632Sopenharmony_ci@interface GPBUnknownFieldSet : NSObject<NSCopying> 44ffe3c632Sopenharmony_ci 45ffe3c632Sopenharmony_ci/** 46ffe3c632Sopenharmony_ci * Tests to see if the given field number has a value. 47ffe3c632Sopenharmony_ci * 48ffe3c632Sopenharmony_ci * @param number The field number to check. 49ffe3c632Sopenharmony_ci * 50ffe3c632Sopenharmony_ci * @return YES if there is an unknown field for the given field number. 51ffe3c632Sopenharmony_ci **/ 52ffe3c632Sopenharmony_ci- (BOOL)hasField:(int32_t)number; 53ffe3c632Sopenharmony_ci 54ffe3c632Sopenharmony_ci/** 55ffe3c632Sopenharmony_ci * Fetches the GPBUnknownField for the given field number. 56ffe3c632Sopenharmony_ci * 57ffe3c632Sopenharmony_ci * @param number The field number to look up. 58ffe3c632Sopenharmony_ci * 59ffe3c632Sopenharmony_ci * @return The GPBUnknownField or nil if none found. 60ffe3c632Sopenharmony_ci **/ 61ffe3c632Sopenharmony_ci- (nullable GPBUnknownField *)getField:(int32_t)number; 62ffe3c632Sopenharmony_ci 63ffe3c632Sopenharmony_ci/** 64ffe3c632Sopenharmony_ci * @return The number of fields in this set. 65ffe3c632Sopenharmony_ci **/ 66ffe3c632Sopenharmony_ci- (NSUInteger)countOfFields; 67ffe3c632Sopenharmony_ci 68ffe3c632Sopenharmony_ci/** 69ffe3c632Sopenharmony_ci * Adds the given field to the set. 70ffe3c632Sopenharmony_ci * 71ffe3c632Sopenharmony_ci * @param field The field to add to the set. 72ffe3c632Sopenharmony_ci **/ 73ffe3c632Sopenharmony_ci- (void)addField:(GPBUnknownField *)field; 74ffe3c632Sopenharmony_ci 75ffe3c632Sopenharmony_ci/** 76ffe3c632Sopenharmony_ci * @return An array of the GPBUnknownFields sorted by the field numbers. 77ffe3c632Sopenharmony_ci **/ 78ffe3c632Sopenharmony_ci- (NSArray<GPBUnknownField *> *)sortedFields; 79ffe3c632Sopenharmony_ci 80ffe3c632Sopenharmony_ci@end 81ffe3c632Sopenharmony_ci 82ffe3c632Sopenharmony_ciNS_ASSUME_NONNULL_END 83