xref: /aosp_15_r20/external/protobuf/objectivec/GPBUnknownFieldSet.h (revision 1b3f573f81763fcece89efc2b6a5209149e44ab8)
1*1b3f573fSAndroid Build Coastguard Worker // Protocol Buffers - Google's data interchange format
2*1b3f573fSAndroid Build Coastguard Worker // Copyright 2008 Google Inc.  All rights reserved.
3*1b3f573fSAndroid Build Coastguard Worker // https://developers.google.com/protocol-buffers/
4*1b3f573fSAndroid Build Coastguard Worker //
5*1b3f573fSAndroid Build Coastguard Worker // Redistribution and use in source and binary forms, with or without
6*1b3f573fSAndroid Build Coastguard Worker // modification, are permitted provided that the following conditions are
7*1b3f573fSAndroid Build Coastguard Worker // met:
8*1b3f573fSAndroid Build Coastguard Worker //
9*1b3f573fSAndroid Build Coastguard Worker //     * Redistributions of source code must retain the above copyright
10*1b3f573fSAndroid Build Coastguard Worker // notice, this list of conditions and the following disclaimer.
11*1b3f573fSAndroid Build Coastguard Worker //     * Redistributions in binary form must reproduce the above
12*1b3f573fSAndroid Build Coastguard Worker // copyright notice, this list of conditions and the following disclaimer
13*1b3f573fSAndroid Build Coastguard Worker // in the documentation and/or other materials provided with the
14*1b3f573fSAndroid Build Coastguard Worker // distribution.
15*1b3f573fSAndroid Build Coastguard Worker //     * Neither the name of Google Inc. nor the names of its
16*1b3f573fSAndroid Build Coastguard Worker // contributors may be used to endorse or promote products derived from
17*1b3f573fSAndroid Build Coastguard Worker // this software without specific prior written permission.
18*1b3f573fSAndroid Build Coastguard Worker //
19*1b3f573fSAndroid Build Coastguard Worker // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20*1b3f573fSAndroid Build Coastguard Worker // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21*1b3f573fSAndroid Build Coastguard Worker // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22*1b3f573fSAndroid Build Coastguard Worker // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23*1b3f573fSAndroid Build Coastguard Worker // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24*1b3f573fSAndroid Build Coastguard Worker // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25*1b3f573fSAndroid Build Coastguard Worker // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26*1b3f573fSAndroid Build Coastguard Worker // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27*1b3f573fSAndroid Build Coastguard Worker // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28*1b3f573fSAndroid Build Coastguard Worker // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29*1b3f573fSAndroid Build Coastguard Worker // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30*1b3f573fSAndroid Build Coastguard Worker 
31*1b3f573fSAndroid Build Coastguard Worker #import <Foundation/Foundation.h>
32*1b3f573fSAndroid Build Coastguard Worker 
33*1b3f573fSAndroid Build Coastguard Worker @class GPBUnknownField;
34*1b3f573fSAndroid Build Coastguard Worker 
35*1b3f573fSAndroid Build Coastguard Worker NS_ASSUME_NONNULL_BEGIN
36*1b3f573fSAndroid Build Coastguard Worker 
37*1b3f573fSAndroid Build Coastguard Worker /**
38*1b3f573fSAndroid Build Coastguard Worker  * A collection of unknown fields. Fields parsed from the binary representation
39*1b3f573fSAndroid Build Coastguard Worker  * of a message that are unknown end up in an instance of this set. This only
40*1b3f573fSAndroid Build Coastguard Worker  * applies for files declared with the "proto2" syntax. Files declared with the
41*1b3f573fSAndroid Build Coastguard Worker  * "proto3" syntax discard the unknown values.
42*1b3f573fSAndroid Build Coastguard Worker  **/
43*1b3f573fSAndroid Build Coastguard Worker @interface GPBUnknownFieldSet : NSObject<NSCopying>
44*1b3f573fSAndroid Build Coastguard Worker 
45*1b3f573fSAndroid Build Coastguard Worker /**
46*1b3f573fSAndroid Build Coastguard Worker  * Tests to see if the given field number has a value.
47*1b3f573fSAndroid Build Coastguard Worker  *
48*1b3f573fSAndroid Build Coastguard Worker  * @param number The field number to check.
49*1b3f573fSAndroid Build Coastguard Worker  *
50*1b3f573fSAndroid Build Coastguard Worker  * @return YES if there is an unknown field for the given field number.
51*1b3f573fSAndroid Build Coastguard Worker  **/
52*1b3f573fSAndroid Build Coastguard Worker - (BOOL)hasField:(int32_t)number;
53*1b3f573fSAndroid Build Coastguard Worker 
54*1b3f573fSAndroid Build Coastguard Worker /**
55*1b3f573fSAndroid Build Coastguard Worker  * Fetches the GPBUnknownField for the given field number.
56*1b3f573fSAndroid Build Coastguard Worker  *
57*1b3f573fSAndroid Build Coastguard Worker  * @param number The field number to look up.
58*1b3f573fSAndroid Build Coastguard Worker  *
59*1b3f573fSAndroid Build Coastguard Worker  * @return The GPBUnknownField or nil if none found.
60*1b3f573fSAndroid Build Coastguard Worker  **/
61*1b3f573fSAndroid Build Coastguard Worker - (nullable GPBUnknownField *)getField:(int32_t)number;
62*1b3f573fSAndroid Build Coastguard Worker 
63*1b3f573fSAndroid Build Coastguard Worker /**
64*1b3f573fSAndroid Build Coastguard Worker  * @return The number of fields in this set.
65*1b3f573fSAndroid Build Coastguard Worker  **/
66*1b3f573fSAndroid Build Coastguard Worker - (NSUInteger)countOfFields;
67*1b3f573fSAndroid Build Coastguard Worker 
68*1b3f573fSAndroid Build Coastguard Worker /**
69*1b3f573fSAndroid Build Coastguard Worker  * Adds the given field to the set.
70*1b3f573fSAndroid Build Coastguard Worker  *
71*1b3f573fSAndroid Build Coastguard Worker  * @param field The field to add to the set.
72*1b3f573fSAndroid Build Coastguard Worker  **/
73*1b3f573fSAndroid Build Coastguard Worker - (void)addField:(GPBUnknownField *)field;
74*1b3f573fSAndroid Build Coastguard Worker 
75*1b3f573fSAndroid Build Coastguard Worker /**
76*1b3f573fSAndroid Build Coastguard Worker  * @return An array of the GPBUnknownFields sorted by the field numbers.
77*1b3f573fSAndroid Build Coastguard Worker  **/
78*1b3f573fSAndroid Build Coastguard Worker - (NSArray<GPBUnknownField *> *)sortedFields;
79*1b3f573fSAndroid Build Coastguard Worker 
80*1b3f573fSAndroid Build Coastguard Worker @end
81*1b3f573fSAndroid Build Coastguard Worker 
82*1b3f573fSAndroid Build Coastguard Worker NS_ASSUME_NONNULL_END
83