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