forked from protocolbuffers/protobuf
-
Notifications
You must be signed in to change notification settings - Fork 0
/
GPBUnknownField.h
173 lines (151 loc) · 4.71 KB
/
GPBUnknownField.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
// Protocol Buffers - Google's data interchange format
// Copyright 2008 Google Inc. All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file or at
// https://developers.google.com/open-source/licenses/bsd
#import <Foundation/Foundation.h>
@class GPBCodedOutputStream;
@class GPBUInt32Array;
@class GPBUInt64Array;
@class GPBUnknownFieldSet;
@class GPBUnknownFields;
NS_ASSUME_NONNULL_BEGIN
typedef NS_ENUM(uint8_t, GPBUnknownFieldType) {
GPBUnknownFieldTypeVarint,
GPBUnknownFieldTypeFixed32,
GPBUnknownFieldTypeFixed64,
GPBUnknownFieldTypeLengthDelimited, // Length prefixed
GPBUnknownFieldTypeGroup, // Tag delimited
/**
* This type is only used with fields from `GPBUnknownFieldsSet`. Some methods
* only work with instances with this type and other apis require the other
* type(s). It is a programming error to use the wrong methods.
**/
GPBUnknownFieldTypeLegacy,
};
/**
* Store an unknown field. These are used in conjunction with
* GPBUnknownFieldSet.
**/
__attribute__((objc_subclassing_restricted))
@interface GPBUnknownField : NSObject<NSCopying>
/** Initialize a field with the given number. */
- (instancetype)initWithNumber:(int32_t)number;
/** The field number the data is stored under. */
@property(nonatomic, readonly, assign) int32_t number;
/** The type of the field. */
@property(nonatomic, readonly, assign) GPBUnknownFieldType type;
/**
* Fetch the varint value.
*
* It is a programming error to call this when the `type` is not a varint.
*/
@property(nonatomic, readonly, assign) uint64_t varint;
/**
* Fetch the fixed32 value.
*
* It is a programming error to call this when the `type` is not a fixed32.
*/
@property(nonatomic, readonly, assign) uint32_t fixed32;
/**
* Fetch the fixed64 value.
*
* It is a programming error to call this when the `type` is not a fixed64.
*/
@property(nonatomic, readonly, assign) uint64_t fixed64;
/**
* Fetch the length delimited (length prefixed) value.
*
* It is a programming error to call this when the `type` is not a length
* delimited.
*/
@property(nonatomic, readonly, strong, nonnull) NSData *lengthDelimited;
/**
* Fetch the group (tag delimited) value.
*
* It is a programming error to call this when the `type` is not a group.
*/
@property(nonatomic, readonly, strong, nonnull) GPBUnknownFields *group;
/**
* An array of varint values for this field.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*/
@property(nonatomic, readonly, strong) GPBUInt64Array *varintList;
/**
* An array of fixed32 values for this field.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*/
@property(nonatomic, readonly, strong) GPBUInt32Array *fixed32List;
/**
* An array of fixed64 values for this field.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*/
@property(nonatomic, readonly, strong) GPBUInt64Array *fixed64List;
/**
* An array of data values for this field.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*/
@property(nonatomic, readonly, strong) NSArray<NSData *> *lengthDelimitedList;
/**
* An array of groups of values for this field.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*/
@property(nonatomic, readonly, strong) NSArray<GPBUnknownFieldSet *> *groupList;
/**
* Add a value to the varintList.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*
* @param value The value to add.
**/
- (void)addVarint:(uint64_t)value;
/**
* Add a value to the fixed32List.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*
* @param value The value to add.
**/
- (void)addFixed32:(uint32_t)value;
/**
* Add a value to the fixed64List.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*
* @param value The value to add.
**/
- (void)addFixed64:(uint64_t)value;
/**
* Add a value to the lengthDelimitedList.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*
* @param value The value to add.
**/
- (void)addLengthDelimited:(NSData *)value;
/**
* Add a value to the groupList.
*
* Only valid for type == GPBUnknownFieldTypeLegacy, it is a programming error
* to use with any other type.
*
* @param value The value to add.
**/
- (void)addGroup:(GPBUnknownFieldSet *)value;
@end
NS_ASSUME_NONNULL_END