xref: /aosp_15_r20/external/protobuf/objectivec/GPBCodedOutputStream.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 #import "GPBRuntimeTypes.h"
34*1b3f573fSAndroid Build Coastguard Worker #import "GPBWireFormat.h"
35*1b3f573fSAndroid Build Coastguard Worker 
36*1b3f573fSAndroid Build Coastguard Worker @class GPBBoolArray;
37*1b3f573fSAndroid Build Coastguard Worker @class GPBDoubleArray;
38*1b3f573fSAndroid Build Coastguard Worker @class GPBEnumArray;
39*1b3f573fSAndroid Build Coastguard Worker @class GPBFloatArray;
40*1b3f573fSAndroid Build Coastguard Worker @class GPBMessage;
41*1b3f573fSAndroid Build Coastguard Worker @class GPBInt32Array;
42*1b3f573fSAndroid Build Coastguard Worker @class GPBInt64Array;
43*1b3f573fSAndroid Build Coastguard Worker @class GPBUInt32Array;
44*1b3f573fSAndroid Build Coastguard Worker @class GPBUInt64Array;
45*1b3f573fSAndroid Build Coastguard Worker @class GPBUnknownFieldSet;
46*1b3f573fSAndroid Build Coastguard Worker 
47*1b3f573fSAndroid Build Coastguard Worker NS_ASSUME_NONNULL_BEGIN
48*1b3f573fSAndroid Build Coastguard Worker 
49*1b3f573fSAndroid Build Coastguard Worker /**
50*1b3f573fSAndroid Build Coastguard Worker  * @c GPBCodedOutputStream exception names.
51*1b3f573fSAndroid Build Coastguard Worker  **/
52*1b3f573fSAndroid Build Coastguard Worker extern NSString *const GPBCodedOutputStreamException_OutOfSpace;
53*1b3f573fSAndroid Build Coastguard Worker extern NSString *const GPBCodedOutputStreamException_WriteFailed;
54*1b3f573fSAndroid Build Coastguard Worker 
55*1b3f573fSAndroid Build Coastguard Worker /**
56*1b3f573fSAndroid Build Coastguard Worker  * Writes out protocol message fields.
57*1b3f573fSAndroid Build Coastguard Worker  *
58*1b3f573fSAndroid Build Coastguard Worker  * The common uses of protocol buffers shouldn't need to use this class.
59*1b3f573fSAndroid Build Coastguard Worker  * GPBMessage's provide a -data method that will serialize the message for you.
60*1b3f573fSAndroid Build Coastguard Worker  *
61*1b3f573fSAndroid Build Coastguard Worker  * @note Any -write* api can raise the GPBCodedOutputStreamException_*
62*1b3f573fSAndroid Build Coastguard Worker  *       exceptions.
63*1b3f573fSAndroid Build Coastguard Worker  *
64*1b3f573fSAndroid Build Coastguard Worker  * @note Subclassing of GPBCodedOutputStream is NOT supported.
65*1b3f573fSAndroid Build Coastguard Worker  **/
66*1b3f573fSAndroid Build Coastguard Worker @interface GPBCodedOutputStream : NSObject
67*1b3f573fSAndroid Build Coastguard Worker 
68*1b3f573fSAndroid Build Coastguard Worker /**
69*1b3f573fSAndroid Build Coastguard Worker  * Creates a stream to fill in the given data. Data must be sized to fit or
70*1b3f573fSAndroid Build Coastguard Worker  * an error will be raised when out of space.
71*1b3f573fSAndroid Build Coastguard Worker  *
72*1b3f573fSAndroid Build Coastguard Worker  * @param data The data where the stream will be written to.
73*1b3f573fSAndroid Build Coastguard Worker  *
74*1b3f573fSAndroid Build Coastguard Worker  * @return A newly instanced GPBCodedOutputStream.
75*1b3f573fSAndroid Build Coastguard Worker  **/
76*1b3f573fSAndroid Build Coastguard Worker + (instancetype)streamWithData:(NSMutableData *)data;
77*1b3f573fSAndroid Build Coastguard Worker 
78*1b3f573fSAndroid Build Coastguard Worker /**
79*1b3f573fSAndroid Build Coastguard Worker  * Creates a stream to write into the given NSOutputStream.
80*1b3f573fSAndroid Build Coastguard Worker  *
81*1b3f573fSAndroid Build Coastguard Worker  * @param output The output stream where the stream will be written to.
82*1b3f573fSAndroid Build Coastguard Worker  *
83*1b3f573fSAndroid Build Coastguard Worker  * @return A newly instanced GPBCodedOutputStream.
84*1b3f573fSAndroid Build Coastguard Worker  **/
85*1b3f573fSAndroid Build Coastguard Worker + (instancetype)streamWithOutputStream:(NSOutputStream *)output;
86*1b3f573fSAndroid Build Coastguard Worker 
87*1b3f573fSAndroid Build Coastguard Worker /**
88*1b3f573fSAndroid Build Coastguard Worker  * Initializes a stream to fill in the given data. Data must be sized to fit
89*1b3f573fSAndroid Build Coastguard Worker  * or an error will be raised when out of space.
90*1b3f573fSAndroid Build Coastguard Worker  *
91*1b3f573fSAndroid Build Coastguard Worker  * @param data The data where the stream will be written to.
92*1b3f573fSAndroid Build Coastguard Worker  *
93*1b3f573fSAndroid Build Coastguard Worker  * @return A newly initialized GPBCodedOutputStream.
94*1b3f573fSAndroid Build Coastguard Worker  **/
95*1b3f573fSAndroid Build Coastguard Worker - (instancetype)initWithData:(NSMutableData *)data;
96*1b3f573fSAndroid Build Coastguard Worker 
97*1b3f573fSAndroid Build Coastguard Worker /**
98*1b3f573fSAndroid Build Coastguard Worker  * Initializes a stream to write into the given @c NSOutputStream.
99*1b3f573fSAndroid Build Coastguard Worker  *
100*1b3f573fSAndroid Build Coastguard Worker  * @param output The output stream where the stream will be written to.
101*1b3f573fSAndroid Build Coastguard Worker  *
102*1b3f573fSAndroid Build Coastguard Worker  * @return A newly initialized GPBCodedOutputStream.
103*1b3f573fSAndroid Build Coastguard Worker  **/
104*1b3f573fSAndroid Build Coastguard Worker - (instancetype)initWithOutputStream:(NSOutputStream *)output;
105*1b3f573fSAndroid Build Coastguard Worker 
106*1b3f573fSAndroid Build Coastguard Worker /**
107*1b3f573fSAndroid Build Coastguard Worker  * Flush any buffered data out.
108*1b3f573fSAndroid Build Coastguard Worker  **/
109*1b3f573fSAndroid Build Coastguard Worker - (void)flush;
110*1b3f573fSAndroid Build Coastguard Worker 
111*1b3f573fSAndroid Build Coastguard Worker /**
112*1b3f573fSAndroid Build Coastguard Worker  * Write the raw byte out.
113*1b3f573fSAndroid Build Coastguard Worker  *
114*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
115*1b3f573fSAndroid Build Coastguard Worker  **/
116*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawByte:(uint8_t)value;
117*1b3f573fSAndroid Build Coastguard Worker 
118*1b3f573fSAndroid Build Coastguard Worker /**
119*1b3f573fSAndroid Build Coastguard Worker  * Write the tag for the given field number and wire format.
120*1b3f573fSAndroid Build Coastguard Worker  *
121*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number.
122*1b3f573fSAndroid Build Coastguard Worker  * @param format      The wire format the data for the field will be in.
123*1b3f573fSAndroid Build Coastguard Worker  **/
124*1b3f573fSAndroid Build Coastguard Worker - (void)writeTag:(uint32_t)fieldNumber format:(GPBWireFormat)format;
125*1b3f573fSAndroid Build Coastguard Worker 
126*1b3f573fSAndroid Build Coastguard Worker /**
127*1b3f573fSAndroid Build Coastguard Worker  * Write a 32bit value out in little endian format.
128*1b3f573fSAndroid Build Coastguard Worker  *
129*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
130*1b3f573fSAndroid Build Coastguard Worker  **/
131*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawLittleEndian32:(int32_t)value;
132*1b3f573fSAndroid Build Coastguard Worker /**
133*1b3f573fSAndroid Build Coastguard Worker  * Write a 64bit value out in little endian format.
134*1b3f573fSAndroid Build Coastguard Worker  *
135*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
136*1b3f573fSAndroid Build Coastguard Worker  **/
137*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawLittleEndian64:(int64_t)value;
138*1b3f573fSAndroid Build Coastguard Worker 
139*1b3f573fSAndroid Build Coastguard Worker /**
140*1b3f573fSAndroid Build Coastguard Worker  * Write a 32bit value out in varint format.
141*1b3f573fSAndroid Build Coastguard Worker  *
142*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
143*1b3f573fSAndroid Build Coastguard Worker  **/
144*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawVarint32:(int32_t)value;
145*1b3f573fSAndroid Build Coastguard Worker /**
146*1b3f573fSAndroid Build Coastguard Worker  * Write a 64bit value out in varint format.
147*1b3f573fSAndroid Build Coastguard Worker  *
148*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
149*1b3f573fSAndroid Build Coastguard Worker  **/
150*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawVarint64:(int64_t)value;
151*1b3f573fSAndroid Build Coastguard Worker 
152*1b3f573fSAndroid Build Coastguard Worker /**
153*1b3f573fSAndroid Build Coastguard Worker  * Write a size_t out as a 32bit varint value.
154*1b3f573fSAndroid Build Coastguard Worker  *
155*1b3f573fSAndroid Build Coastguard Worker  * @note This will truncate 64 bit values to 32.
156*1b3f573fSAndroid Build Coastguard Worker  *
157*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
158*1b3f573fSAndroid Build Coastguard Worker  **/
159*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawVarintSizeTAs32:(size_t)value;
160*1b3f573fSAndroid Build Coastguard Worker 
161*1b3f573fSAndroid Build Coastguard Worker /**
162*1b3f573fSAndroid Build Coastguard Worker  * Writes the contents of an NSData out.
163*1b3f573fSAndroid Build Coastguard Worker  *
164*1b3f573fSAndroid Build Coastguard Worker  * @param data The data to write out.
165*1b3f573fSAndroid Build Coastguard Worker  **/
166*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawData:(NSData *)data;
167*1b3f573fSAndroid Build Coastguard Worker /**
168*1b3f573fSAndroid Build Coastguard Worker  * Writes out the given data.
169*1b3f573fSAndroid Build Coastguard Worker  *
170*1b3f573fSAndroid Build Coastguard Worker  * @param data   The data blob to write out.
171*1b3f573fSAndroid Build Coastguard Worker  * @param offset The offset into the blob to start writing out.
172*1b3f573fSAndroid Build Coastguard Worker  * @param length The number of bytes from the blob to write out.
173*1b3f573fSAndroid Build Coastguard Worker  **/
174*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawPtr:(const void *)data
175*1b3f573fSAndroid Build Coastguard Worker              offset:(size_t)offset
176*1b3f573fSAndroid Build Coastguard Worker              length:(size_t)length;
177*1b3f573fSAndroid Build Coastguard Worker 
178*1b3f573fSAndroid Build Coastguard Worker //%PDDM-EXPAND _WRITE_DECLS()
179*1b3f573fSAndroid Build Coastguard Worker // This block of code is generated, do not edit it directly.
180*1b3f573fSAndroid Build Coastguard Worker // clang-format off
181*1b3f573fSAndroid Build Coastguard Worker 
182*1b3f573fSAndroid Build Coastguard Worker /**
183*1b3f573fSAndroid Build Coastguard Worker  * Write a double for the given field number.
184*1b3f573fSAndroid Build Coastguard Worker  *
185*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
186*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
187*1b3f573fSAndroid Build Coastguard Worker  **/
188*1b3f573fSAndroid Build Coastguard Worker - (void)writeDouble:(int32_t)fieldNumber value:(double)value;
189*1b3f573fSAndroid Build Coastguard Worker /**
190*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of double for the given field number.
191*1b3f573fSAndroid Build Coastguard Worker  *
192*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
193*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
194*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
195*1b3f573fSAndroid Build Coastguard Worker  **/
196*1b3f573fSAndroid Build Coastguard Worker - (void)writeDoubleArray:(int32_t)fieldNumber
197*1b3f573fSAndroid Build Coastguard Worker                   values:(GPBDoubleArray *)values
198*1b3f573fSAndroid Build Coastguard Worker                      tag:(uint32_t)tag;
199*1b3f573fSAndroid Build Coastguard Worker /**
200*1b3f573fSAndroid Build Coastguard Worker  * Write a double without any tag.
201*1b3f573fSAndroid Build Coastguard Worker  *
202*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
203*1b3f573fSAndroid Build Coastguard Worker  **/
204*1b3f573fSAndroid Build Coastguard Worker - (void)writeDoubleNoTag:(double)value;
205*1b3f573fSAndroid Build Coastguard Worker 
206*1b3f573fSAndroid Build Coastguard Worker /**
207*1b3f573fSAndroid Build Coastguard Worker  * Write a float for the given field number.
208*1b3f573fSAndroid Build Coastguard Worker  *
209*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
210*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
211*1b3f573fSAndroid Build Coastguard Worker  **/
212*1b3f573fSAndroid Build Coastguard Worker - (void)writeFloat:(int32_t)fieldNumber value:(float)value;
213*1b3f573fSAndroid Build Coastguard Worker /**
214*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of float for the given field number.
215*1b3f573fSAndroid Build Coastguard Worker  *
216*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
217*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
218*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
219*1b3f573fSAndroid Build Coastguard Worker  **/
220*1b3f573fSAndroid Build Coastguard Worker - (void)writeFloatArray:(int32_t)fieldNumber
221*1b3f573fSAndroid Build Coastguard Worker                  values:(GPBFloatArray *)values
222*1b3f573fSAndroid Build Coastguard Worker                     tag:(uint32_t)tag;
223*1b3f573fSAndroid Build Coastguard Worker /**
224*1b3f573fSAndroid Build Coastguard Worker  * Write a float without any tag.
225*1b3f573fSAndroid Build Coastguard Worker  *
226*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
227*1b3f573fSAndroid Build Coastguard Worker  **/
228*1b3f573fSAndroid Build Coastguard Worker - (void)writeFloatNoTag:(float)value;
229*1b3f573fSAndroid Build Coastguard Worker 
230*1b3f573fSAndroid Build Coastguard Worker /**
231*1b3f573fSAndroid Build Coastguard Worker  * Write a uint64_t for the given field number.
232*1b3f573fSAndroid Build Coastguard Worker  *
233*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
234*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
235*1b3f573fSAndroid Build Coastguard Worker  **/
236*1b3f573fSAndroid Build Coastguard Worker - (void)writeUInt64:(int32_t)fieldNumber value:(uint64_t)value;
237*1b3f573fSAndroid Build Coastguard Worker /**
238*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of uint64_t for the given field number.
239*1b3f573fSAndroid Build Coastguard Worker  *
240*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
241*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
242*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
243*1b3f573fSAndroid Build Coastguard Worker  **/
244*1b3f573fSAndroid Build Coastguard Worker - (void)writeUInt64Array:(int32_t)fieldNumber
245*1b3f573fSAndroid Build Coastguard Worker                   values:(GPBUInt64Array *)values
246*1b3f573fSAndroid Build Coastguard Worker                      tag:(uint32_t)tag;
247*1b3f573fSAndroid Build Coastguard Worker /**
248*1b3f573fSAndroid Build Coastguard Worker  * Write a uint64_t without any tag.
249*1b3f573fSAndroid Build Coastguard Worker  *
250*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
251*1b3f573fSAndroid Build Coastguard Worker  **/
252*1b3f573fSAndroid Build Coastguard Worker - (void)writeUInt64NoTag:(uint64_t)value;
253*1b3f573fSAndroid Build Coastguard Worker 
254*1b3f573fSAndroid Build Coastguard Worker /**
255*1b3f573fSAndroid Build Coastguard Worker  * Write a int64_t for the given field number.
256*1b3f573fSAndroid Build Coastguard Worker  *
257*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
258*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
259*1b3f573fSAndroid Build Coastguard Worker  **/
260*1b3f573fSAndroid Build Coastguard Worker - (void)writeInt64:(int32_t)fieldNumber value:(int64_t)value;
261*1b3f573fSAndroid Build Coastguard Worker /**
262*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of int64_t for the given field number.
263*1b3f573fSAndroid Build Coastguard Worker  *
264*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
265*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
266*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
267*1b3f573fSAndroid Build Coastguard Worker  **/
268*1b3f573fSAndroid Build Coastguard Worker - (void)writeInt64Array:(int32_t)fieldNumber
269*1b3f573fSAndroid Build Coastguard Worker                  values:(GPBInt64Array *)values
270*1b3f573fSAndroid Build Coastguard Worker                     tag:(uint32_t)tag;
271*1b3f573fSAndroid Build Coastguard Worker /**
272*1b3f573fSAndroid Build Coastguard Worker  * Write a int64_t without any tag.
273*1b3f573fSAndroid Build Coastguard Worker  *
274*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
275*1b3f573fSAndroid Build Coastguard Worker  **/
276*1b3f573fSAndroid Build Coastguard Worker - (void)writeInt64NoTag:(int64_t)value;
277*1b3f573fSAndroid Build Coastguard Worker 
278*1b3f573fSAndroid Build Coastguard Worker /**
279*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t for the given field number.
280*1b3f573fSAndroid Build Coastguard Worker  *
281*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
282*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
283*1b3f573fSAndroid Build Coastguard Worker  **/
284*1b3f573fSAndroid Build Coastguard Worker - (void)writeInt32:(int32_t)fieldNumber value:(int32_t)value;
285*1b3f573fSAndroid Build Coastguard Worker /**
286*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of int32_t for the given field number.
287*1b3f573fSAndroid Build Coastguard Worker  *
288*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
289*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
290*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
291*1b3f573fSAndroid Build Coastguard Worker  **/
292*1b3f573fSAndroid Build Coastguard Worker - (void)writeInt32Array:(int32_t)fieldNumber
293*1b3f573fSAndroid Build Coastguard Worker                  values:(GPBInt32Array *)values
294*1b3f573fSAndroid Build Coastguard Worker                     tag:(uint32_t)tag;
295*1b3f573fSAndroid Build Coastguard Worker /**
296*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t without any tag.
297*1b3f573fSAndroid Build Coastguard Worker  *
298*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
299*1b3f573fSAndroid Build Coastguard Worker  **/
300*1b3f573fSAndroid Build Coastguard Worker - (void)writeInt32NoTag:(int32_t)value;
301*1b3f573fSAndroid Build Coastguard Worker 
302*1b3f573fSAndroid Build Coastguard Worker /**
303*1b3f573fSAndroid Build Coastguard Worker  * Write a uint32_t for the given field number.
304*1b3f573fSAndroid Build Coastguard Worker  *
305*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
306*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
307*1b3f573fSAndroid Build Coastguard Worker  **/
308*1b3f573fSAndroid Build Coastguard Worker - (void)writeUInt32:(int32_t)fieldNumber value:(uint32_t)value;
309*1b3f573fSAndroid Build Coastguard Worker /**
310*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of uint32_t for the given field number.
311*1b3f573fSAndroid Build Coastguard Worker  *
312*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
313*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
314*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
315*1b3f573fSAndroid Build Coastguard Worker  **/
316*1b3f573fSAndroid Build Coastguard Worker - (void)writeUInt32Array:(int32_t)fieldNumber
317*1b3f573fSAndroid Build Coastguard Worker                   values:(GPBUInt32Array *)values
318*1b3f573fSAndroid Build Coastguard Worker                      tag:(uint32_t)tag;
319*1b3f573fSAndroid Build Coastguard Worker /**
320*1b3f573fSAndroid Build Coastguard Worker  * Write a uint32_t without any tag.
321*1b3f573fSAndroid Build Coastguard Worker  *
322*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
323*1b3f573fSAndroid Build Coastguard Worker  **/
324*1b3f573fSAndroid Build Coastguard Worker - (void)writeUInt32NoTag:(uint32_t)value;
325*1b3f573fSAndroid Build Coastguard Worker 
326*1b3f573fSAndroid Build Coastguard Worker /**
327*1b3f573fSAndroid Build Coastguard Worker  * Write a uint64_t for the given field number.
328*1b3f573fSAndroid Build Coastguard Worker  *
329*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
330*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
331*1b3f573fSAndroid Build Coastguard Worker  **/
332*1b3f573fSAndroid Build Coastguard Worker - (void)writeFixed64:(int32_t)fieldNumber value:(uint64_t)value;
333*1b3f573fSAndroid Build Coastguard Worker /**
334*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of uint64_t for the given field number.
335*1b3f573fSAndroid Build Coastguard Worker  *
336*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
337*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
338*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
339*1b3f573fSAndroid Build Coastguard Worker  **/
340*1b3f573fSAndroid Build Coastguard Worker - (void)writeFixed64Array:(int32_t)fieldNumber
341*1b3f573fSAndroid Build Coastguard Worker                    values:(GPBUInt64Array *)values
342*1b3f573fSAndroid Build Coastguard Worker                       tag:(uint32_t)tag;
343*1b3f573fSAndroid Build Coastguard Worker /**
344*1b3f573fSAndroid Build Coastguard Worker  * Write a uint64_t without any tag.
345*1b3f573fSAndroid Build Coastguard Worker  *
346*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
347*1b3f573fSAndroid Build Coastguard Worker  **/
348*1b3f573fSAndroid Build Coastguard Worker - (void)writeFixed64NoTag:(uint64_t)value;
349*1b3f573fSAndroid Build Coastguard Worker 
350*1b3f573fSAndroid Build Coastguard Worker /**
351*1b3f573fSAndroid Build Coastguard Worker  * Write a uint32_t for the given field number.
352*1b3f573fSAndroid Build Coastguard Worker  *
353*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
354*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
355*1b3f573fSAndroid Build Coastguard Worker  **/
356*1b3f573fSAndroid Build Coastguard Worker - (void)writeFixed32:(int32_t)fieldNumber value:(uint32_t)value;
357*1b3f573fSAndroid Build Coastguard Worker /**
358*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of uint32_t for the given field number.
359*1b3f573fSAndroid Build Coastguard Worker  *
360*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
361*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
362*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
363*1b3f573fSAndroid Build Coastguard Worker  **/
364*1b3f573fSAndroid Build Coastguard Worker - (void)writeFixed32Array:(int32_t)fieldNumber
365*1b3f573fSAndroid Build Coastguard Worker                    values:(GPBUInt32Array *)values
366*1b3f573fSAndroid Build Coastguard Worker                       tag:(uint32_t)tag;
367*1b3f573fSAndroid Build Coastguard Worker /**
368*1b3f573fSAndroid Build Coastguard Worker  * Write a uint32_t without any tag.
369*1b3f573fSAndroid Build Coastguard Worker  *
370*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
371*1b3f573fSAndroid Build Coastguard Worker  **/
372*1b3f573fSAndroid Build Coastguard Worker - (void)writeFixed32NoTag:(uint32_t)value;
373*1b3f573fSAndroid Build Coastguard Worker 
374*1b3f573fSAndroid Build Coastguard Worker /**
375*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t for the given field number.
376*1b3f573fSAndroid Build Coastguard Worker  *
377*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
378*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
379*1b3f573fSAndroid Build Coastguard Worker  **/
380*1b3f573fSAndroid Build Coastguard Worker - (void)writeSInt32:(int32_t)fieldNumber value:(int32_t)value;
381*1b3f573fSAndroid Build Coastguard Worker /**
382*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of int32_t for the given field number.
383*1b3f573fSAndroid Build Coastguard Worker  *
384*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
385*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
386*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
387*1b3f573fSAndroid Build Coastguard Worker  **/
388*1b3f573fSAndroid Build Coastguard Worker - (void)writeSInt32Array:(int32_t)fieldNumber
389*1b3f573fSAndroid Build Coastguard Worker                   values:(GPBInt32Array *)values
390*1b3f573fSAndroid Build Coastguard Worker                      tag:(uint32_t)tag;
391*1b3f573fSAndroid Build Coastguard Worker /**
392*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t without any tag.
393*1b3f573fSAndroid Build Coastguard Worker  *
394*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
395*1b3f573fSAndroid Build Coastguard Worker  **/
396*1b3f573fSAndroid Build Coastguard Worker - (void)writeSInt32NoTag:(int32_t)value;
397*1b3f573fSAndroid Build Coastguard Worker 
398*1b3f573fSAndroid Build Coastguard Worker /**
399*1b3f573fSAndroid Build Coastguard Worker  * Write a int64_t for the given field number.
400*1b3f573fSAndroid Build Coastguard Worker  *
401*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
402*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
403*1b3f573fSAndroid Build Coastguard Worker  **/
404*1b3f573fSAndroid Build Coastguard Worker - (void)writeSInt64:(int32_t)fieldNumber value:(int64_t)value;
405*1b3f573fSAndroid Build Coastguard Worker /**
406*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of int64_t for the given field number.
407*1b3f573fSAndroid Build Coastguard Worker  *
408*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
409*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
410*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
411*1b3f573fSAndroid Build Coastguard Worker  **/
412*1b3f573fSAndroid Build Coastguard Worker - (void)writeSInt64Array:(int32_t)fieldNumber
413*1b3f573fSAndroid Build Coastguard Worker                   values:(GPBInt64Array *)values
414*1b3f573fSAndroid Build Coastguard Worker                      tag:(uint32_t)tag;
415*1b3f573fSAndroid Build Coastguard Worker /**
416*1b3f573fSAndroid Build Coastguard Worker  * Write a int64_t without any tag.
417*1b3f573fSAndroid Build Coastguard Worker  *
418*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
419*1b3f573fSAndroid Build Coastguard Worker  **/
420*1b3f573fSAndroid Build Coastguard Worker - (void)writeSInt64NoTag:(int64_t)value;
421*1b3f573fSAndroid Build Coastguard Worker 
422*1b3f573fSAndroid Build Coastguard Worker /**
423*1b3f573fSAndroid Build Coastguard Worker  * Write a int64_t for the given field number.
424*1b3f573fSAndroid Build Coastguard Worker  *
425*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
426*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
427*1b3f573fSAndroid Build Coastguard Worker  **/
428*1b3f573fSAndroid Build Coastguard Worker - (void)writeSFixed64:(int32_t)fieldNumber value:(int64_t)value;
429*1b3f573fSAndroid Build Coastguard Worker /**
430*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of int64_t for the given field number.
431*1b3f573fSAndroid Build Coastguard Worker  *
432*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
433*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
434*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
435*1b3f573fSAndroid Build Coastguard Worker  **/
436*1b3f573fSAndroid Build Coastguard Worker - (void)writeSFixed64Array:(int32_t)fieldNumber
437*1b3f573fSAndroid Build Coastguard Worker                     values:(GPBInt64Array *)values
438*1b3f573fSAndroid Build Coastguard Worker                        tag:(uint32_t)tag;
439*1b3f573fSAndroid Build Coastguard Worker /**
440*1b3f573fSAndroid Build Coastguard Worker  * Write a int64_t without any tag.
441*1b3f573fSAndroid Build Coastguard Worker  *
442*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
443*1b3f573fSAndroid Build Coastguard Worker  **/
444*1b3f573fSAndroid Build Coastguard Worker - (void)writeSFixed64NoTag:(int64_t)value;
445*1b3f573fSAndroid Build Coastguard Worker 
446*1b3f573fSAndroid Build Coastguard Worker /**
447*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t for the given field number.
448*1b3f573fSAndroid Build Coastguard Worker  *
449*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
450*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
451*1b3f573fSAndroid Build Coastguard Worker  **/
452*1b3f573fSAndroid Build Coastguard Worker - (void)writeSFixed32:(int32_t)fieldNumber value:(int32_t)value;
453*1b3f573fSAndroid Build Coastguard Worker /**
454*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of int32_t for the given field number.
455*1b3f573fSAndroid Build Coastguard Worker  *
456*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
457*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
458*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
459*1b3f573fSAndroid Build Coastguard Worker  **/
460*1b3f573fSAndroid Build Coastguard Worker - (void)writeSFixed32Array:(int32_t)fieldNumber
461*1b3f573fSAndroid Build Coastguard Worker                     values:(GPBInt32Array *)values
462*1b3f573fSAndroid Build Coastguard Worker                        tag:(uint32_t)tag;
463*1b3f573fSAndroid Build Coastguard Worker /**
464*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t without any tag.
465*1b3f573fSAndroid Build Coastguard Worker  *
466*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
467*1b3f573fSAndroid Build Coastguard Worker  **/
468*1b3f573fSAndroid Build Coastguard Worker - (void)writeSFixed32NoTag:(int32_t)value;
469*1b3f573fSAndroid Build Coastguard Worker 
470*1b3f573fSAndroid Build Coastguard Worker /**
471*1b3f573fSAndroid Build Coastguard Worker  * Write a BOOL for the given field number.
472*1b3f573fSAndroid Build Coastguard Worker  *
473*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
474*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
475*1b3f573fSAndroid Build Coastguard Worker  **/
476*1b3f573fSAndroid Build Coastguard Worker - (void)writeBool:(int32_t)fieldNumber value:(BOOL)value;
477*1b3f573fSAndroid Build Coastguard Worker /**
478*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of BOOL for the given field number.
479*1b3f573fSAndroid Build Coastguard Worker  *
480*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
481*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
482*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
483*1b3f573fSAndroid Build Coastguard Worker  **/
484*1b3f573fSAndroid Build Coastguard Worker - (void)writeBoolArray:(int32_t)fieldNumber
485*1b3f573fSAndroid Build Coastguard Worker                 values:(GPBBoolArray *)values
486*1b3f573fSAndroid Build Coastguard Worker                    tag:(uint32_t)tag;
487*1b3f573fSAndroid Build Coastguard Worker /**
488*1b3f573fSAndroid Build Coastguard Worker  * Write a BOOL without any tag.
489*1b3f573fSAndroid Build Coastguard Worker  *
490*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
491*1b3f573fSAndroid Build Coastguard Worker  **/
492*1b3f573fSAndroid Build Coastguard Worker - (void)writeBoolNoTag:(BOOL)value;
493*1b3f573fSAndroid Build Coastguard Worker 
494*1b3f573fSAndroid Build Coastguard Worker /**
495*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t for the given field number.
496*1b3f573fSAndroid Build Coastguard Worker  *
497*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
498*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
499*1b3f573fSAndroid Build Coastguard Worker  **/
500*1b3f573fSAndroid Build Coastguard Worker - (void)writeEnum:(int32_t)fieldNumber value:(int32_t)value;
501*1b3f573fSAndroid Build Coastguard Worker /**
502*1b3f573fSAndroid Build Coastguard Worker  * Write a packed array of int32_t for the given field number.
503*1b3f573fSAndroid Build Coastguard Worker  *
504*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
505*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
506*1b3f573fSAndroid Build Coastguard Worker  * @param tag         The tag assigned to the values.
507*1b3f573fSAndroid Build Coastguard Worker  **/
508*1b3f573fSAndroid Build Coastguard Worker - (void)writeEnumArray:(int32_t)fieldNumber
509*1b3f573fSAndroid Build Coastguard Worker                 values:(GPBEnumArray *)values
510*1b3f573fSAndroid Build Coastguard Worker                    tag:(uint32_t)tag;
511*1b3f573fSAndroid Build Coastguard Worker /**
512*1b3f573fSAndroid Build Coastguard Worker  * Write a int32_t without any tag.
513*1b3f573fSAndroid Build Coastguard Worker  *
514*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
515*1b3f573fSAndroid Build Coastguard Worker  **/
516*1b3f573fSAndroid Build Coastguard Worker - (void)writeEnumNoTag:(int32_t)value;
517*1b3f573fSAndroid Build Coastguard Worker 
518*1b3f573fSAndroid Build Coastguard Worker /**
519*1b3f573fSAndroid Build Coastguard Worker  * Write a NSString for the given field number.
520*1b3f573fSAndroid Build Coastguard Worker  *
521*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
522*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
523*1b3f573fSAndroid Build Coastguard Worker  **/
524*1b3f573fSAndroid Build Coastguard Worker - (void)writeString:(int32_t)fieldNumber value:(NSString *)value;
525*1b3f573fSAndroid Build Coastguard Worker /**
526*1b3f573fSAndroid Build Coastguard Worker  * Write an array of NSString for the given field number.
527*1b3f573fSAndroid Build Coastguard Worker  *
528*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
529*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
530*1b3f573fSAndroid Build Coastguard Worker  **/
531*1b3f573fSAndroid Build Coastguard Worker - (void)writeStringArray:(int32_t)fieldNumber
532*1b3f573fSAndroid Build Coastguard Worker                   values:(NSArray<NSString*> *)values;
533*1b3f573fSAndroid Build Coastguard Worker /**
534*1b3f573fSAndroid Build Coastguard Worker  * Write a NSString without any tag.
535*1b3f573fSAndroid Build Coastguard Worker  *
536*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
537*1b3f573fSAndroid Build Coastguard Worker  **/
538*1b3f573fSAndroid Build Coastguard Worker - (void)writeStringNoTag:(NSString *)value;
539*1b3f573fSAndroid Build Coastguard Worker 
540*1b3f573fSAndroid Build Coastguard Worker /**
541*1b3f573fSAndroid Build Coastguard Worker  * Write a GPBMessage for the given field number.
542*1b3f573fSAndroid Build Coastguard Worker  *
543*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
544*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
545*1b3f573fSAndroid Build Coastguard Worker  **/
546*1b3f573fSAndroid Build Coastguard Worker - (void)writeMessage:(int32_t)fieldNumber value:(GPBMessage *)value;
547*1b3f573fSAndroid Build Coastguard Worker /**
548*1b3f573fSAndroid Build Coastguard Worker  * Write an array of GPBMessage for the given field number.
549*1b3f573fSAndroid Build Coastguard Worker  *
550*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
551*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
552*1b3f573fSAndroid Build Coastguard Worker  **/
553*1b3f573fSAndroid Build Coastguard Worker - (void)writeMessageArray:(int32_t)fieldNumber
554*1b3f573fSAndroid Build Coastguard Worker                    values:(NSArray<GPBMessage*> *)values;
555*1b3f573fSAndroid Build Coastguard Worker /**
556*1b3f573fSAndroid Build Coastguard Worker  * Write a GPBMessage without any tag.
557*1b3f573fSAndroid Build Coastguard Worker  *
558*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
559*1b3f573fSAndroid Build Coastguard Worker  **/
560*1b3f573fSAndroid Build Coastguard Worker - (void)writeMessageNoTag:(GPBMessage *)value;
561*1b3f573fSAndroid Build Coastguard Worker 
562*1b3f573fSAndroid Build Coastguard Worker /**
563*1b3f573fSAndroid Build Coastguard Worker  * Write a NSData for the given field number.
564*1b3f573fSAndroid Build Coastguard Worker  *
565*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
566*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
567*1b3f573fSAndroid Build Coastguard Worker  **/
568*1b3f573fSAndroid Build Coastguard Worker - (void)writeBytes:(int32_t)fieldNumber value:(NSData *)value;
569*1b3f573fSAndroid Build Coastguard Worker /**
570*1b3f573fSAndroid Build Coastguard Worker  * Write an array of NSData for the given field number.
571*1b3f573fSAndroid Build Coastguard Worker  *
572*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
573*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
574*1b3f573fSAndroid Build Coastguard Worker  **/
575*1b3f573fSAndroid Build Coastguard Worker - (void)writeBytesArray:(int32_t)fieldNumber
576*1b3f573fSAndroid Build Coastguard Worker                  values:(NSArray<NSData*> *)values;
577*1b3f573fSAndroid Build Coastguard Worker /**
578*1b3f573fSAndroid Build Coastguard Worker  * Write a NSData without any tag.
579*1b3f573fSAndroid Build Coastguard Worker  *
580*1b3f573fSAndroid Build Coastguard Worker  * @param value The value to write out.
581*1b3f573fSAndroid Build Coastguard Worker  **/
582*1b3f573fSAndroid Build Coastguard Worker - (void)writeBytesNoTag:(NSData *)value;
583*1b3f573fSAndroid Build Coastguard Worker 
584*1b3f573fSAndroid Build Coastguard Worker /**
585*1b3f573fSAndroid Build Coastguard Worker  * Write a GPBMessage for the given field number.
586*1b3f573fSAndroid Build Coastguard Worker  *
587*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
588*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
589*1b3f573fSAndroid Build Coastguard Worker  **/
590*1b3f573fSAndroid Build Coastguard Worker - (void)writeGroup:(int32_t)fieldNumber
591*1b3f573fSAndroid Build Coastguard Worker              value:(GPBMessage *)value;
592*1b3f573fSAndroid Build Coastguard Worker /**
593*1b3f573fSAndroid Build Coastguard Worker  * Write an array of GPBMessage for the given field number.
594*1b3f573fSAndroid Build Coastguard Worker  *
595*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
596*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
597*1b3f573fSAndroid Build Coastguard Worker  **/
598*1b3f573fSAndroid Build Coastguard Worker - (void)writeGroupArray:(int32_t)fieldNumber
599*1b3f573fSAndroid Build Coastguard Worker                  values:(NSArray<GPBMessage*> *)values;
600*1b3f573fSAndroid Build Coastguard Worker /**
601*1b3f573fSAndroid Build Coastguard Worker  * Write a GPBMessage without any tag (but does write the endGroup tag).
602*1b3f573fSAndroid Build Coastguard Worker  *
603*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
604*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
605*1b3f573fSAndroid Build Coastguard Worker  **/
606*1b3f573fSAndroid Build Coastguard Worker - (void)writeGroupNoTag:(int32_t)fieldNumber
607*1b3f573fSAndroid Build Coastguard Worker                   value:(GPBMessage *)value;
608*1b3f573fSAndroid Build Coastguard Worker 
609*1b3f573fSAndroid Build Coastguard Worker /**
610*1b3f573fSAndroid Build Coastguard Worker  * Write a GPBUnknownFieldSet for the given field number.
611*1b3f573fSAndroid Build Coastguard Worker  *
612*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
613*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
614*1b3f573fSAndroid Build Coastguard Worker  **/
615*1b3f573fSAndroid Build Coastguard Worker - (void)writeUnknownGroup:(int32_t)fieldNumber
616*1b3f573fSAndroid Build Coastguard Worker                     value:(GPBUnknownFieldSet *)value;
617*1b3f573fSAndroid Build Coastguard Worker /**
618*1b3f573fSAndroid Build Coastguard Worker  * Write an array of GPBUnknownFieldSet for the given field number.
619*1b3f573fSAndroid Build Coastguard Worker  *
620*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the values.
621*1b3f573fSAndroid Build Coastguard Worker  * @param values      The values to write out.
622*1b3f573fSAndroid Build Coastguard Worker  **/
623*1b3f573fSAndroid Build Coastguard Worker - (void)writeUnknownGroupArray:(int32_t)fieldNumber
624*1b3f573fSAndroid Build Coastguard Worker                         values:(NSArray<GPBUnknownFieldSet*> *)values;
625*1b3f573fSAndroid Build Coastguard Worker /**
626*1b3f573fSAndroid Build Coastguard Worker  * Write a GPBUnknownFieldSet without any tag (but does write the endGroup tag).
627*1b3f573fSAndroid Build Coastguard Worker  *
628*1b3f573fSAndroid Build Coastguard Worker  * @param fieldNumber The field number assigned to the value.
629*1b3f573fSAndroid Build Coastguard Worker  * @param value       The value to write out.
630*1b3f573fSAndroid Build Coastguard Worker  **/
631*1b3f573fSAndroid Build Coastguard Worker - (void)writeUnknownGroupNoTag:(int32_t)fieldNumber
632*1b3f573fSAndroid Build Coastguard Worker                          value:(GPBUnknownFieldSet *)value;
633*1b3f573fSAndroid Build Coastguard Worker 
634*1b3f573fSAndroid Build Coastguard Worker // clang-format on
635*1b3f573fSAndroid Build Coastguard Worker //%PDDM-EXPAND-END _WRITE_DECLS()
636*1b3f573fSAndroid Build Coastguard Worker 
637*1b3f573fSAndroid Build Coastguard Worker /**
638*1b3f573fSAndroid Build Coastguard Worker Write a MessageSet extension field to the stream. For historical reasons,
639*1b3f573fSAndroid Build Coastguard Worker the wire format differs from normal fields.
640*1b3f573fSAndroid Build Coastguard Worker 
641*1b3f573fSAndroid Build Coastguard Worker @param fieldNumber The extension field number to write out.
642*1b3f573fSAndroid Build Coastguard Worker @param value       The message from where to get the extension.
643*1b3f573fSAndroid Build Coastguard Worker */
644*1b3f573fSAndroid Build Coastguard Worker - (void)writeMessageSetExtension:(int32_t)fieldNumber value:(GPBMessage *)value;
645*1b3f573fSAndroid Build Coastguard Worker 
646*1b3f573fSAndroid Build Coastguard Worker /**
647*1b3f573fSAndroid Build Coastguard Worker Write an unparsed MessageSet extension field to the stream. For historical
648*1b3f573fSAndroid Build Coastguard Worker reasons, the wire format differs from normal fields.
649*1b3f573fSAndroid Build Coastguard Worker 
650*1b3f573fSAndroid Build Coastguard Worker @param fieldNumber The extension field number to write out.
651*1b3f573fSAndroid Build Coastguard Worker @param value       The raw message from where to get the extension.
652*1b3f573fSAndroid Build Coastguard Worker */
653*1b3f573fSAndroid Build Coastguard Worker - (void)writeRawMessageSetExtension:(int32_t)fieldNumber value:(NSData *)value;
654*1b3f573fSAndroid Build Coastguard Worker 
655*1b3f573fSAndroid Build Coastguard Worker @end
656*1b3f573fSAndroid Build Coastguard Worker 
657*1b3f573fSAndroid Build Coastguard Worker NS_ASSUME_NONNULL_END
658*1b3f573fSAndroid Build Coastguard Worker 
659*1b3f573fSAndroid Build Coastguard Worker // Write methods for types that can be in packed arrays.
660*1b3f573fSAndroid Build Coastguard Worker //%PDDM-DEFINE _WRITE_PACKABLE_DECLS(NAME, ARRAY_TYPE, TYPE)
661*1b3f573fSAndroid Build Coastguard Worker //%/**
662*1b3f573fSAndroid Build Coastguard Worker //% * Write a TYPE for the given field number.
663*1b3f573fSAndroid Build Coastguard Worker //% *
664*1b3f573fSAndroid Build Coastguard Worker //% * @param fieldNumber The field number assigned to the value.
665*1b3f573fSAndroid Build Coastguard Worker //% * @param value       The value to write out.
666*1b3f573fSAndroid Build Coastguard Worker //% **/
667*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME:(int32_t)fieldNumber value:(TYPE)value;
668*1b3f573fSAndroid Build Coastguard Worker //%/**
669*1b3f573fSAndroid Build Coastguard Worker //% * Write a packed array of TYPE for the given field number.
670*1b3f573fSAndroid Build Coastguard Worker //% *
671*1b3f573fSAndroid Build Coastguard Worker //% * @param fieldNumber The field number assigned to the values.
672*1b3f573fSAndroid Build Coastguard Worker //% * @param values      The values to write out.
673*1b3f573fSAndroid Build Coastguard Worker //% * @param tag         The tag assigned to the values.
674*1b3f573fSAndroid Build Coastguard Worker //% **/
675*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME##Array:(int32_t)fieldNumber
676*1b3f573fSAndroid Build Coastguard Worker //%       NAME$S     values:(GPB##ARRAY_TYPE##Array *)values
677*1b3f573fSAndroid Build Coastguard Worker //%       NAME$S        tag:(uint32_t)tag;
678*1b3f573fSAndroid Build Coastguard Worker //%/**
679*1b3f573fSAndroid Build Coastguard Worker //% * Write a TYPE without any tag.
680*1b3f573fSAndroid Build Coastguard Worker //% *
681*1b3f573fSAndroid Build Coastguard Worker //% * @param value The value to write out.
682*1b3f573fSAndroid Build Coastguard Worker //% **/
683*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME##NoTag:(TYPE)value;
684*1b3f573fSAndroid Build Coastguard Worker //%
685*1b3f573fSAndroid Build Coastguard Worker // Write methods for types that aren't in packed arrays.
686*1b3f573fSAndroid Build Coastguard Worker //%PDDM-DEFINE _WRITE_UNPACKABLE_DECLS(NAME, TYPE)
687*1b3f573fSAndroid Build Coastguard Worker //%/**
688*1b3f573fSAndroid Build Coastguard Worker //% * Write a TYPE for the given field number.
689*1b3f573fSAndroid Build Coastguard Worker //% *
690*1b3f573fSAndroid Build Coastguard Worker //% * @param fieldNumber The field number assigned to the value.
691*1b3f573fSAndroid Build Coastguard Worker //% * @param value       The value to write out.
692*1b3f573fSAndroid Build Coastguard Worker //% **/
693*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME:(int32_t)fieldNumber value:(TYPE *)value;
694*1b3f573fSAndroid Build Coastguard Worker //%/**
695*1b3f573fSAndroid Build Coastguard Worker //% * Write an array of TYPE for the given field number.
696*1b3f573fSAndroid Build Coastguard Worker //% *
697*1b3f573fSAndroid Build Coastguard Worker //% * @param fieldNumber The field number assigned to the values.
698*1b3f573fSAndroid Build Coastguard Worker //% * @param values      The values to write out.
699*1b3f573fSAndroid Build Coastguard Worker //% **/
700*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME##Array:(int32_t)fieldNumber
701*1b3f573fSAndroid Build Coastguard Worker //%           NAME$S values:(NSArray<##TYPE##*> *)values;
702*1b3f573fSAndroid Build Coastguard Worker //%/**
703*1b3f573fSAndroid Build Coastguard Worker //% * Write a TYPE without any tag.
704*1b3f573fSAndroid Build Coastguard Worker //% *
705*1b3f573fSAndroid Build Coastguard Worker //% * @param value The value to write out.
706*1b3f573fSAndroid Build Coastguard Worker //% **/
707*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME##NoTag:(TYPE *)value;
708*1b3f573fSAndroid Build Coastguard Worker //%
709*1b3f573fSAndroid Build Coastguard Worker // Special write methods for Groups.
710*1b3f573fSAndroid Build Coastguard Worker //%PDDM-DEFINE _WRITE_GROUP_DECLS(NAME, TYPE)
711*1b3f573fSAndroid Build Coastguard Worker //%/**
712*1b3f573fSAndroid Build Coastguard Worker //% * Write a TYPE for the given field number.
713*1b3f573fSAndroid Build Coastguard Worker //% *
714*1b3f573fSAndroid Build Coastguard Worker //% * @param fieldNumber The field number assigned to the value.
715*1b3f573fSAndroid Build Coastguard Worker //% * @param value       The value to write out.
716*1b3f573fSAndroid Build Coastguard Worker //% **/
717*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME:(int32_t)fieldNumber
718*1b3f573fSAndroid Build Coastguard Worker //%       NAME$S value:(TYPE *)value;
719*1b3f573fSAndroid Build Coastguard Worker //%/**
720*1b3f573fSAndroid Build Coastguard Worker //% * Write an array of TYPE for the given field number.
721*1b3f573fSAndroid Build Coastguard Worker //% *
722*1b3f573fSAndroid Build Coastguard Worker //% * @param fieldNumber The field number assigned to the values.
723*1b3f573fSAndroid Build Coastguard Worker //% * @param values      The values to write out.
724*1b3f573fSAndroid Build Coastguard Worker //% **/
725*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME##Array:(int32_t)fieldNumber
726*1b3f573fSAndroid Build Coastguard Worker //%           NAME$S values:(NSArray<##TYPE##*> *)values;
727*1b3f573fSAndroid Build Coastguard Worker //%/**
728*1b3f573fSAndroid Build Coastguard Worker //% * Write a TYPE without any tag (but does write the endGroup tag).
729*1b3f573fSAndroid Build Coastguard Worker //% *
730*1b3f573fSAndroid Build Coastguard Worker //% * @param fieldNumber The field number assigned to the value.
731*1b3f573fSAndroid Build Coastguard Worker //% * @param value       The value to write out.
732*1b3f573fSAndroid Build Coastguard Worker //% **/
733*1b3f573fSAndroid Build Coastguard Worker //%- (void)write##NAME##NoTag:(int32_t)fieldNumber
734*1b3f573fSAndroid Build Coastguard Worker //%            NAME$S value:(TYPE *)value;
735*1b3f573fSAndroid Build Coastguard Worker //%
736*1b3f573fSAndroid Build Coastguard Worker 
737*1b3f573fSAndroid Build Coastguard Worker // One macro to hide it all up above.
738*1b3f573fSAndroid Build Coastguard Worker //%PDDM-DEFINE _WRITE_DECLS()
739*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Double, Double, double)
740*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Float, Float, float)
741*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(UInt64, UInt64, uint64_t)
742*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Int64, Int64, int64_t)
743*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Int32, Int32, int32_t)
744*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(UInt32, UInt32, uint32_t)
745*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Fixed64, UInt64, uint64_t)
746*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Fixed32, UInt32, uint32_t)
747*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(SInt32, Int32, int32_t)
748*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(SInt64, Int64, int64_t)
749*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(SFixed64, Int64, int64_t)
750*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(SFixed32, Int32, int32_t)
751*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Bool, Bool, BOOL)
752*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_PACKABLE_DECLS(Enum, Enum, int32_t)
753*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_UNPACKABLE_DECLS(String, NSString)
754*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_UNPACKABLE_DECLS(Message, GPBMessage)
755*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_UNPACKABLE_DECLS(Bytes, NSData)
756*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_GROUP_DECLS(Group, GPBMessage)
757*1b3f573fSAndroid Build Coastguard Worker //%_WRITE_GROUP_DECLS(UnknownGroup, GPBUnknownFieldSet)
758