Properly strip /usr/lib and /usr/include for the merged build.
[amitay/samba.git] / librpc / ndr / ndr_spoolss_buf.c
1 /*
2    Unix SMB/CIFS implementation.
3
4    routines for marshalling/unmarshalling spoolss subcontext buffer structures
5
6    Copyright (C) Andrew Tridgell 2003
7    Copyright (C) Tim Potter 2003
8
9    This program is free software; you can redistribute it and/or modify
10    it under the terms of the GNU General Public License as published by
11    the Free Software Foundation; either version 3 of the License, or
12    (at your option) any later version.
13
14    This program is distributed in the hope that it will be useful,
15    but WITHOUT ANY WARRANTY; without even the implied warranty of
16    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17    GNU General Public License for more details.
18
19    You should have received a copy of the GNU General Public License
20    along with this program.  If not, see <http://www.gnu.org/licenses/>.
21 */
22
23
24 #include "includes.h"
25 #include "librpc/gen_ndr/ndr_spoolss.h"
26 #if (_SAMBA_BUILD_ >= 4)
27 #include "param/param.h"
28 #endif
29
30 #define NDR_SPOOLSS_PUSH_ENUM_IN(fn) do { \
31         if (!r->in.buffer && r->in.offered != 0) {\
32                 return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
33                         "SPOOLSS Buffer: r->in.offered[%u] but there's no buffer",\
34                         (unsigned)r->in.offered);\
35         } else if (r->in.buffer && r->in.buffer->length != r->in.offered) {\
36                 return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
37                         "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of r->in.buffer[%u]",\
38                         (unsigned)r->in.offered, (unsigned)r->in.buffer->length);\
39         }\
40         _r.in.level     = r->in.level;\
41         _r.in.buffer    = r->in.buffer;\
42         _r.in.offered   = r->in.offered;\
43         NDR_CHECK(ndr_push__##fn(ndr, flags, &_r));\
44 } while(0)
45
46 #define NDR_SPOOLSS_PUSH_ENUM_OUT(fn) do { \
47         struct ndr_push *_ndr_info;\
48         _r.in.level     = r->in.level;\
49         _r.in.buffer    = r->in.buffer;\
50         _r.in.offered   = r->in.offered;\
51         _r.out.info     = NULL;\
52         _r.out.needed   = r->out.needed;\
53         _r.out.count    = r->out.count;\
54         _r.out.result   = r->out.result;\
55         if (r->out.info && *r->out.info && !r->in.buffer) {\
56                 return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
57                         "SPOOLSS Buffer: *r->out.info but there's no r->in.buffer");\
58         }\
59         if (r->in.buffer) {\
60                 DATA_BLOB _data_blob_info;\
61                 _ndr_info = ndr_push_init_ctx(ndr, ndr->iconv_convenience);\
62                 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);\
63                 _ndr_info->flags= ndr->flags;\
64                 if (r->out.info) {\
65                         struct __##fn __r;\
66                         __r.in.level    = r->in.level;\
67                         __r.in.count    = *r->out.count;\
68                         __r.out.info    = *r->out.info;\
69                         NDR_CHECK(ndr_push___##fn(_ndr_info, flags, &__r)); \
70                 }\
71                 if (r->in.offered > _ndr_info->offset) {\
72                         uint32_t _padding_len = r->in.offered - _ndr_info->offset;\
73                         NDR_CHECK(ndr_push_zero(_ndr_info, _padding_len));\
74                 } else if (r->in.offered < _ndr_info->offset) {\
75                         return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
76                                 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of out buffer[%u]!",\
77                                 (unsigned)r->in.offered, (unsigned)_ndr_info->offset);\
78                 }\
79                 _data_blob_info = ndr_push_blob(_ndr_info);\
80                 _r.out.info     = &_data_blob_info;\
81         }\
82         NDR_CHECK(ndr_push__##fn(ndr, flags, &_r));\
83 } while(0)
84
85 #define NDR_SPOOLSS_PUSH_ENUM(fn,in,out) do { \
86         struct _##fn _r;\
87         if (flags & NDR_IN) {\
88                 in;\
89                 NDR_SPOOLSS_PUSH_ENUM_IN(fn);\
90         }\
91         if (flags & NDR_OUT) {\
92                 out;\
93                 NDR_SPOOLSS_PUSH_ENUM_OUT(fn);\
94         }\
95 } while(0)
96
97 #define NDR_SPOOLSS_PULL_ENUM_IN(fn) do { \
98         ZERO_STRUCT(r->out);\
99         NDR_CHECK(ndr_pull__##fn(ndr, flags, &_r));\
100         r->in.level     = _r.in.level;\
101         r->in.buffer    = _r.in.buffer;\
102         r->in.offered   = _r.in.offered;\
103         r->out.needed   = _r.out.needed;\
104         r->out.count    = _r.out.count;\
105         if (!r->in.buffer && r->in.offered != 0) {\
106                 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,\
107                         "SPOOLSS Buffer: r->in.offered[%u] but there's no buffer",\
108                         (unsigned)r->in.offered);\
109         } else if (r->in.buffer && r->in.buffer->length != r->in.offered) {\
110                 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,\
111                         "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of r->in.buffer[%u]",\
112                         (unsigned)r->in.offered, (unsigned)r->in.buffer->length);\
113         }\
114         NDR_PULL_ALLOC(ndr, r->out.info);\
115         ZERO_STRUCTP(r->out.info);\
116 } while(0)
117
118 #define NDR_SPOOLSS_PULL_ENUM_OUT(fn) do { \
119         _r.in.level     = r->in.level;\
120         _r.in.buffer    = r->in.buffer;\
121         _r.in.offered   = r->in.offered;\
122         _r.out.needed   = r->out.needed;\
123         _r.out.count    = r->out.count;\
124         NDR_CHECK(ndr_pull__##fn(ndr, flags, &_r));\
125         if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {\
126                 NDR_PULL_ALLOC(ndr, r->out.info);\
127         }\
128         *r->out.info = NULL;\
129         r->out.needed   = _r.out.needed;\
130         r->out.count    = _r.out.count;\
131         r->out.result   = _r.out.result;\
132         if (_r.out.info) {\
133                 struct ndr_pull *_ndr_info;\
134                 NDR_PULL_ALLOC(ndr, *r->out.info);\
135                 _ndr_info = ndr_pull_init_blob(_r.out.info, *r->out.info, ndr->iconv_convenience);\
136                 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);\
137                 _ndr_info->flags= ndr->flags;\
138                 if (r->in.offered != _ndr_info->data_size) {\
139                         return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,\
140                                 "SPOOLSS Buffer: offered[%u] doesn't match length of buffer[%u]",\
141                                 (unsigned)r->in.offered, (unsigned)_ndr_info->data_size);\
142                 }\
143                 if (*r->out.needed <= _ndr_info->data_size) {\
144                         struct __##fn __r;\
145                         __r.in.level    = r->in.level;\
146                         __r.in.count    = *r->out.count;\
147                         __r.out.info    = NULL;\
148                         NDR_CHECK(ndr_pull___##fn(_ndr_info, flags, &__r));\
149                         *r->out.info    = __r.out.info;\
150                 }\
151         }\
152 } while(0)
153
154 #define NDR_SPOOLSS_PULL_ENUM(fn,in,out) do { \
155         struct _##fn _r;\
156         if (flags & NDR_IN) {\
157                 out;\
158                 NDR_SPOOLSS_PULL_ENUM_IN(fn);\
159                 in;\
160         }\
161         if (flags & NDR_OUT) {\
162                 out;\
163                 NDR_SPOOLSS_PULL_ENUM_OUT(fn);\
164         }\
165 } while(0)
166
167 #define _NDR_CHECK_UINT32(call) do {\
168         enum ndr_err_code _ndr_err; \
169         _ndr_err = call; \
170         if (!NDR_ERR_CODE_IS_SUCCESS(_ndr_err)) { \
171                 return 0; \
172         }\
173 } while (0)
174
175 /* TODO: set _ndr_info->flags correct */
176 #define NDR_SPOOLSS_SIZE_ENUM(fn) do { \
177         struct __##fn __r;\
178         DATA_BLOB _data_blob_info;\
179         struct ndr_push *_ndr_info = ndr_push_init_ctx(mem_ctx, iconv_convenience);\
180         if (!_ndr_info) return 0;\
181         _ndr_info->flags|=0;\
182         __r.in.level    = level;\
183         __r.in.count    = count;\
184         __r.out.info    = info;\
185         _NDR_CHECK_UINT32(ndr_push___##fn(_ndr_info, NDR_OUT, &__r)); \
186         _data_blob_info = ndr_push_blob(_ndr_info);\
187         return _data_blob_info.length;\
188 } while(0)
189
190 /*
191   spoolss_EnumPrinters
192 */
193 enum ndr_err_code ndr_push_spoolss_EnumPrinters(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrinters *r)
194 {
195         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrinters,{
196                 _r.in.flags     = r->in.flags;
197                 _r.in.server    = r->in.server;
198         },{
199                 _r.in.flags     = r->in.flags;
200                 _r.in.server    = r->in.server;
201         });
202         return NDR_ERR_SUCCESS;
203 }
204
205 enum ndr_err_code ndr_pull_spoolss_EnumPrinters(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrinters *r)
206 {
207         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrinters,{
208                 r->in.flags     = _r.in.flags;
209                 r->in.server    = _r.in.server;
210         },{
211                 _r.in.flags     = r->in.flags;
212                 _r.in.server    = r->in.server;
213         });
214         return NDR_ERR_SUCCESS;
215 }
216
217 uint32_t ndr_size_spoolss_EnumPrinters_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_PrinterInfo *info)
218 {
219         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrinters);
220 }
221
222 /*
223   spoolss_EnumJobs
224 */
225 enum ndr_err_code ndr_push_spoolss_EnumJobs(struct ndr_push *ndr, int flags, const struct spoolss_EnumJobs *r)
226 {
227         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumJobs,{
228                 _r.in.handle    = r->in.handle;
229                 _r.in.firstjob  = r->in.firstjob;
230                 _r.in.numjobs   = r->in.numjobs;
231         },{
232                 _r.in.handle    = r->in.handle;
233                 _r.in.firstjob  = r->in.firstjob;
234                 _r.in.numjobs   = r->in.numjobs;
235         });
236         return NDR_ERR_SUCCESS;
237 }
238
239 enum ndr_err_code ndr_pull_spoolss_EnumJobs(struct ndr_pull *ndr, int flags, struct spoolss_EnumJobs *r)
240 {
241         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumJobs,{
242                 r->in.handle    = _r.in.handle;
243                 r->in.firstjob  = _r.in.firstjob;
244                 r->in.numjobs   = _r.in.numjobs;
245         },{
246                 _r.in.handle    = r->in.handle;
247                 _r.in.firstjob  = r->in.firstjob;
248                 _r.in.numjobs   = r->in.numjobs;
249         });
250         return NDR_ERR_SUCCESS;
251 }
252
253 uint32_t ndr_size_spoolss_EnumJobss_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_JobInfo *info)
254 {
255         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumJobs);
256 }
257
258 /*
259   spoolss_EnumPrinterDrivers
260 */
261 enum ndr_err_code ndr_push_spoolss_EnumPrinterDrivers(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrinterDrivers *r)
262 {
263         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrinterDrivers,{
264                 _r.in.server            = r->in.server;
265                 _r.in.environment       = r->in.environment;
266         },{
267                 _r.in.server            = r->in.server;
268                 _r.in.environment       = r->in.environment;
269         });
270         return NDR_ERR_SUCCESS;
271 }
272
273 enum ndr_err_code ndr_pull_spoolss_EnumPrinterDrivers(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrinterDrivers *r)
274 {
275         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrinterDrivers,{
276                 r->in.server            = _r.in.server;
277                 r->in.environment       = _r.in.environment;
278         },{
279                 _r.in.server            = r->in.server;
280                 _r.in.environment       = r->in.environment;
281         });
282         return NDR_ERR_SUCCESS;
283 }
284
285 uint32_t ndr_size_spoolss_EnumPrinterDrivers_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_DriverInfo *info)
286 {
287         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrinterDrivers);
288 }
289
290 /*
291   spoolss_EnumForms
292 */
293 enum ndr_err_code ndr_push_spoolss_EnumForms(struct ndr_push *ndr, int flags, const struct spoolss_EnumForms *r)
294 {
295         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumForms,{
296                 _r.in.handle    = r->in.handle;
297         },{
298                 _r.in.handle    = r->in.handle;
299         });
300         return NDR_ERR_SUCCESS;
301 }
302
303 enum ndr_err_code ndr_pull_spoolss_EnumForms(struct ndr_pull *ndr, int flags, struct spoolss_EnumForms *r)
304 {
305         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumForms,{
306                 r->in.handle    = _r.in.handle;
307         },{
308                 _r.in.handle    = r->in.handle;
309         });
310         return NDR_ERR_SUCCESS;
311 }
312
313 uint32_t ndr_size_spoolss_EnumForms_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_FormInfo *info)
314 {
315         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumForms);
316 }
317
318 /*
319   spoolss_EnumPorts
320 */
321 enum ndr_err_code ndr_push_spoolss_EnumPorts(struct ndr_push *ndr, int flags, const struct spoolss_EnumPorts *r)
322 {
323         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPorts,{
324                 _r.in.servername= r->in.servername;
325         },{
326                 _r.in.servername= r->in.servername;
327         });
328         return NDR_ERR_SUCCESS;
329 }
330
331 enum ndr_err_code ndr_pull_spoolss_EnumPorts(struct ndr_pull *ndr, int flags, struct spoolss_EnumPorts *r)
332 {
333         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPorts,{
334                 r->in.servername= _r.in.servername;
335         },{
336                 _r.in.servername= r->in.servername;
337         });
338         return NDR_ERR_SUCCESS;
339 }
340
341 uint32_t ndr_size_spoolss_EnumPorts_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_PortInfo *info)
342 {
343         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPorts);
344 }
345
346 /*
347   spoolss_EnumMonitors
348 */
349 enum ndr_err_code ndr_push_spoolss_EnumMonitors(struct ndr_push *ndr, int flags, const struct spoolss_EnumMonitors *r)
350 {
351         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumMonitors,{
352                 _r.in.servername= r->in.servername;
353         },{
354                 _r.in.servername= r->in.servername;
355         });
356         return NDR_ERR_SUCCESS;
357 }
358
359 enum ndr_err_code ndr_pull_spoolss_EnumMonitors(struct ndr_pull *ndr, int flags, struct spoolss_EnumMonitors *r)
360 {
361         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumMonitors,{
362                 r->in.servername= _r.in.servername;
363         },{
364                 _r.in.servername= r->in.servername;
365         });
366         return NDR_ERR_SUCCESS;
367 }
368
369 uint32_t ndr_size_spoolss_EnumMonitors_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_MonitorInfo *info)
370 {
371         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumMonitors);
372 }
373
374 /*
375   spoolss_EnumPrintProcessors
376 */
377 enum ndr_err_code ndr_push_spoolss_EnumPrintProcessors(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrintProcessors *r)
378 {
379         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrintProcessors,{
380                 _r.in.servername        = r->in.servername;
381                 _r.in.environment       = r->in.environment;
382         },{
383                 _r.in.servername        = r->in.servername;
384                 _r.in.environment       = r->in.environment;
385         });
386         return NDR_ERR_SUCCESS;
387 }
388
389 enum ndr_err_code ndr_pull_spoolss_EnumPrintProcessors(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrintProcessors *r)
390 {
391         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrintProcessors,{
392                 r->in.servername        = _r.in.servername;
393                 r->in.environment       = _r.in.environment;
394         },{
395                 _r.in.servername        = r->in.servername;
396                 _r.in.environment       = r->in.environment;
397         });
398         return NDR_ERR_SUCCESS;
399 }
400
401 uint32_t ndr_size_spoolss_EnumPrinterProcessors_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience,
402                                                                                                          uint32_t level, uint32_t count, union spoolss_PrintProcessorInfo *info)
403 {
404         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrintProcessors);
405 }
406
407 /*
408   spoolss_EnumPrintProcessors
409 */
410 enum ndr_err_code ndr_push_spoolss_EnumPrintProcDataTypes(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrintProcDataTypes *r)
411 {
412         NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrintProcDataTypes,{
413                 _r.in.servername                = r->in.servername;
414                 _r.in.print_processor_name      = r->in.print_processor_name;
415         },{
416                 _r.in.servername                = r->in.servername;
417                 _r.in.print_processor_name      = r->in.print_processor_name;
418         });
419         return NDR_ERR_SUCCESS;
420 }
421
422 enum ndr_err_code ndr_pull_spoolss_EnumPrintProcDataTypes(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrintProcDataTypes *r)
423 {
424         NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrintProcDataTypes,{
425                 r->in.servername                = _r.in.servername;
426                 r->in.print_processor_name      = _r.in.print_processor_name;
427         },{
428                 _r.in.servername                = r->in.servername;
429                 _r.in.print_processor_name      = r->in.print_processor_name;
430         });
431         return NDR_ERR_SUCCESS;
432 }
433
434 uint32_t ndr_size_spoolss_EnumPrintProcDataTypes_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience,
435                                                       uint32_t level, uint32_t count, union spoolss_PrintProcDataTypesInfo *info)
436 {
437         NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrintProcDataTypes);
438 }
439
440 /*
441   spoolss_GetPrinterData
442 */
443 enum ndr_err_code ndr_push_spoolss_GetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_GetPrinterData *r)
444 {
445         struct _spoolss_GetPrinterData _r;
446         if (flags & NDR_IN) {
447                 _r.in.handle    = r->in.handle;
448                 _r.in.value_name= r->in.value_name;
449                 _r.in.offered   = r->in.offered;
450                 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
451         }
452         if (flags & NDR_OUT) {
453                 struct ndr_push *_ndr_info;
454                 _r.in.handle    = r->in.handle;
455                 _r.in.value_name= r->in.value_name;
456                 _r.in.offered   = r->in.offered;
457                 _r.out.type     = r->out.type;
458                 _r.out.data     = data_blob(NULL, 0);
459                 _r.out.needed   = r->out.needed;
460                 _r.out.result   = r->out.result;
461                 {
462                         struct __spoolss_GetPrinterData __r;
463                         _ndr_info = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
464                         NDR_ERR_HAVE_NO_MEMORY(_ndr_info);
465                         _ndr_info->flags= ndr->flags;
466                         __r.in.type     = *r->out.type;
467                         __r.out.data    = r->out.data;
468                         NDR_CHECK(ndr_push___spoolss_GetPrinterData(_ndr_info, flags, &__r));
469                         if (r->in.offered > _ndr_info->offset) {
470                                 uint32_t _padding_len = r->in.offered - _ndr_info->offset;
471                                 NDR_CHECK(ndr_push_zero(_ndr_info, _padding_len));
472                         }
473                         _r.out.data = ndr_push_blob(_ndr_info);
474                 }
475                 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
476         }
477         return NDR_ERR_SUCCESS;
478 }
479
480 enum ndr_err_code ndr_pull_spoolss_GetPrinterData(struct ndr_pull *ndr, int flags, struct spoolss_GetPrinterData *r)
481 {
482         struct _spoolss_GetPrinterData _r;
483         if (flags & NDR_IN) {
484                 ZERO_STRUCT(r->out);
485
486                 _r.in.handle    = r->in.handle;
487                 _r.in.value_name= r->in.value_name;
488                 _r.in.offered   = r->in.offered;
489                 _r.out.type     = r->out.type;
490                 _r.out.data     = data_blob(NULL,0),
491                 _r.out.needed   = r->out.needed;
492                 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
493                 r->in.handle    = _r.in.handle;
494                 r->in.value_name= _r.in.value_name;
495                 r->in.offered   = _r.in.offered;
496                 r->out.needed   = _r.out.needed;
497         }
498         if (flags & NDR_OUT) {
499                 _r.in.handle    = r->in.handle;
500                 _r.in.value_name= r->in.value_name;
501                 _r.in.offered   = r->in.offered;
502                 _r.out.type     = r->out.type;
503                 _r.out.data     = data_blob(NULL,0),
504                 _r.out.needed   = r->out.needed;
505                 _r.out.result   = r->out.result;
506                 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
507                 r->out.type     = _r.out.type;
508                 ZERO_STRUCT(r->out.data);
509                 r->out.needed   = _r.out.needed;
510                 r->out.result   = _r.out.result;
511                 if (_r.out.data.length != r->in.offered) {
512                         return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,
513                                 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of out buffer[%u]",
514                                 (unsigned)r->in.offered, (unsigned)_r.out.data.length);
515                 }
516                 if (_r.out.data.length > 0 && *r->out.needed <= _r.out.data.length) {
517                         struct __spoolss_GetPrinterData __r;
518                         struct ndr_pull *_ndr_data = ndr_pull_init_blob(&_r.out.data, ndr, ndr->iconv_convenience);
519                         NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
520                         _ndr_data->flags= ndr->flags;
521                         __r.in.type     = *r->out.type;
522                         __r.out.data    = r->out.data;
523                         NDR_CHECK(ndr_pull___spoolss_GetPrinterData(_ndr_data, flags, &__r));
524                         r->out.data     = __r.out.data;
525                 } else {
526                         *r->out.type    = SPOOLSS_PRINTER_DATA_TYPE_NULL;
527                 }
528         }
529         return NDR_ERR_SUCCESS;
530 }
531
532 /*
533   spoolss_SetPrinterData
534 */
535 enum ndr_err_code ndr_push_spoolss_SetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_SetPrinterData *r)
536 {
537         struct _spoolss_SetPrinterData _r;
538         if (flags & NDR_IN) {
539                 struct ndr_push *_ndr_data;
540                 struct __spoolss_SetPrinterData __r;
541                 DATA_BLOB _data_blob_data;
542
543                 _ndr_data = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
544                 NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
545                 _ndr_data->flags= ndr->flags;
546
547                 __r.in.type     = r->in.type;
548                 __r.out.data    = r->in.data;
549                 NDR_CHECK(ndr_push___spoolss_SetPrinterData(_ndr_data, NDR_OUT, &__r));
550                 _data_blob_data = ndr_push_blob(_ndr_data);
551
552                 _r.in.handle    = r->in.handle;
553                 _r.in.value_name= r->in.value_name;
554                 _r.in.type      = r->in.type;
555                 _r.in.data      = _data_blob_data;
556                 _r.in._offered  = _data_blob_data.length;
557                 _r.out.result   = r->out.result;
558                 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
559         }
560         if (flags & NDR_OUT) {
561                 _r.in.handle    = r->in.handle;
562                 _r.in.value_name= r->in.value_name;
563                 _r.in.type      = r->in.type;
564                 _r.in.data      = data_blob(NULL,0),
565                 _r.in._offered  = r->in._offered;
566                 _r.out.result   = r->out.result;
567                 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
568         }
569         return NDR_ERR_SUCCESS;
570 }
571
572 uint32_t _ndr_size_spoolss_DeviceMode(struct spoolss_DeviceMode *devmode, struct smb_iconv_convenience *ic, uint32_t flags)
573 {
574         if (!devmode) return 0;
575         return ndr_size_spoolss_DeviceMode(devmode,ic,flags);
576 }
577
578 _PUBLIC_ size_t ndr_size_spoolss_StringArray(const struct spoolss_StringArray *r, struct smb_iconv_convenience *ic, int flags)
579 {
580         if (!r) {
581                 return 4;
582         }
583
584         return ndr_size_struct(r, flags, (ndr_push_flags_fn_t)ndr_push_spoolss_StringArray, ic);
585 }
586
587 /* hand marshall as pidl cannot (yet) generate a relative pointer to a fixed array of
588  * structs */
589
590 _PUBLIC_ enum ndr_err_code ndr_push_spoolss_DriverInfo101(struct ndr_push *ndr, int ndr_flags, const struct spoolss_DriverInfo101 *r)
591 {
592         uint32_t cntr_file_info_1;
593         if (ndr_flags & NDR_SCALARS) {
594                 NDR_CHECK(ndr_push_align(ndr, 8));
595                 NDR_CHECK(ndr_push_spoolss_DriverOSVersion(ndr, NDR_SCALARS, r->version));
596                 {
597                         uint32_t _flags_save_string = ndr->flags;
598                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
599                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->driver_name));
600                         ndr->flags = _flags_save_string;
601                 }
602                 {
603                         uint32_t _flags_save_string = ndr->flags;
604                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
605                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->architecture));
606                         ndr->flags = _flags_save_string;
607                 }
608                 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->file_info));
609                 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
610                 {
611                         uint32_t _flags_save_string = ndr->flags;
612                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
613                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->monitor_name));
614                         ndr->flags = _flags_save_string;
615                 }
616                 {
617                         uint32_t _flags_save_string = ndr->flags;
618                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
619                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->default_datatype));
620                         ndr->flags = _flags_save_string;
621                 }
622                 {
623                         uint32_t _flags_save_string_array = ndr->flags;
624                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
625                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->previous_names));
626                         ndr->flags = _flags_save_string_array;
627                 }
628                 NDR_CHECK(ndr_push_NTTIME(ndr, NDR_SCALARS, r->driver_date));
629                 NDR_CHECK(ndr_push_hyper(ndr, NDR_SCALARS, r->driver_version));
630                 {
631                         uint32_t _flags_save_string = ndr->flags;
632                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
633                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->manufacturer_name));
634                         ndr->flags = _flags_save_string;
635                 }
636                 {
637                         uint32_t _flags_save_string = ndr->flags;
638                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
639                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->manufacturer_url));
640                         ndr->flags = _flags_save_string;
641                 }
642                 {
643                         uint32_t _flags_save_string = ndr->flags;
644                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
645                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->hardware_id));
646                         ndr->flags = _flags_save_string;
647                 }
648                 {
649                         uint32_t _flags_save_string = ndr->flags;
650                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
651                         NDR_CHECK(ndr_push_relative_ptr1(ndr, r->provider));
652                         ndr->flags = _flags_save_string;
653                 }
654         }
655         if (ndr_flags & NDR_BUFFERS) {
656                 {
657                         uint32_t _flags_save_string = ndr->flags;
658                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
659                         if (r->driver_name) {
660                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->driver_name));
661                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->driver_name));
662                         }
663                         ndr->flags = _flags_save_string;
664                 }
665                 {
666                         uint32_t _flags_save_string = ndr->flags;
667                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
668                         if (r->architecture) {
669                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->architecture));
670                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->architecture));
671                         }
672                         ndr->flags = _flags_save_string;
673                 }
674                 if (r->file_info) {
675                         NDR_CHECK(ndr_push_relative_ptr2(ndr, r->file_info));
676 #if 0
677                         NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
678 #endif
679                         for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
680                                 NDR_CHECK(ndr_push_spoolss_DriverFileInfo(ndr, NDR_SCALARS, &r->file_info[cntr_file_info_1]));
681                         }
682                         for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
683                                 NDR_CHECK(ndr_push_spoolss_DriverFileInfo(ndr, NDR_BUFFERS, &r->file_info[cntr_file_info_1]));
684                         }
685                 }
686                 {
687                         uint32_t _flags_save_string = ndr->flags;
688                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
689                         if (r->monitor_name) {
690                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->monitor_name));
691                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->monitor_name));
692                         }
693                         ndr->flags = _flags_save_string;
694                 }
695                 {
696                         uint32_t _flags_save_string = ndr->flags;
697                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
698                         if (r->default_datatype) {
699                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->default_datatype));
700                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->default_datatype));
701                         }
702                         ndr->flags = _flags_save_string;
703                 }
704                 {
705                         uint32_t _flags_save_string_array = ndr->flags;
706                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
707                         if (r->previous_names) {
708                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->previous_names));
709                                 NDR_CHECK(ndr_push_string_array(ndr, NDR_SCALARS, r->previous_names));
710                         }
711                         ndr->flags = _flags_save_string_array;
712                 }
713                 {
714                         uint32_t _flags_save_string = ndr->flags;
715                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
716                         if (r->manufacturer_name) {
717                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->manufacturer_name));
718                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->manufacturer_name));
719                         }
720                         ndr->flags = _flags_save_string;
721                 }
722                 {
723                         uint32_t _flags_save_string = ndr->flags;
724                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
725                         if (r->manufacturer_url) {
726                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->manufacturer_url));
727                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->manufacturer_url));
728                         }
729                         ndr->flags = _flags_save_string;
730                 }
731                 {
732                         uint32_t _flags_save_string = ndr->flags;
733                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
734                         if (r->hardware_id) {
735                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->hardware_id));
736                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->hardware_id));
737                         }
738                         ndr->flags = _flags_save_string;
739                 }
740                 {
741                         uint32_t _flags_save_string = ndr->flags;
742                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
743                         if (r->provider) {
744                                 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->provider));
745                                 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->provider));
746                         }
747                         ndr->flags = _flags_save_string;
748                 }
749         }
750         return NDR_ERR_SUCCESS;
751 }
752
753 _PUBLIC_ enum ndr_err_code ndr_pull_spoolss_DriverInfo101(struct ndr_pull *ndr, int ndr_flags, struct spoolss_DriverInfo101 *r)
754 {
755         uint32_t _ptr_driver_name;
756         TALLOC_CTX *_mem_save_driver_name_0;
757         uint32_t _ptr_architecture;
758         TALLOC_CTX *_mem_save_architecture_0;
759         uint32_t _ptr_file_info;
760         uint32_t cntr_file_info_1;
761         TALLOC_CTX *_mem_save_file_info_0;
762         TALLOC_CTX *_mem_save_file_info_1;
763         uint32_t _ptr_monitor_name;
764         TALLOC_CTX *_mem_save_monitor_name_0;
765         uint32_t _ptr_default_datatype;
766         TALLOC_CTX *_mem_save_default_datatype_0;
767         uint32_t _ptr_previous_names;
768         TALLOC_CTX *_mem_save_previous_names_0;
769         uint32_t _ptr_manufacturer_name;
770         TALLOC_CTX *_mem_save_manufacturer_name_0;
771         uint32_t _ptr_manufacturer_url;
772         TALLOC_CTX *_mem_save_manufacturer_url_0;
773         uint32_t _ptr_hardware_id;
774         TALLOC_CTX *_mem_save_hardware_id_0;
775         uint32_t _ptr_provider;
776         TALLOC_CTX *_mem_save_provider_0;
777         if (ndr_flags & NDR_SCALARS) {
778                 NDR_CHECK(ndr_pull_align(ndr, 8));
779                 NDR_CHECK(ndr_pull_spoolss_DriverOSVersion(ndr, NDR_SCALARS, &r->version));
780                 {
781                         uint32_t _flags_save_string = ndr->flags;
782                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
783                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_driver_name));
784                         if (_ptr_driver_name) {
785                                 NDR_PULL_ALLOC(ndr, r->driver_name);
786                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->driver_name, _ptr_driver_name));
787                         } else {
788                                 r->driver_name = NULL;
789                         }
790                         ndr->flags = _flags_save_string;
791                 }
792                 {
793                         uint32_t _flags_save_string = ndr->flags;
794                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
795                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_architecture));
796                         if (_ptr_architecture) {
797                                 NDR_PULL_ALLOC(ndr, r->architecture);
798                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->architecture, _ptr_architecture));
799                         } else {
800                                 r->architecture = NULL;
801                         }
802                         ndr->flags = _flags_save_string;
803                 }
804                 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_file_info));
805                 if (_ptr_file_info) {
806                         NDR_PULL_ALLOC(ndr, r->file_info);
807                         NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->file_info, _ptr_file_info));
808                 } else {
809                         r->file_info = NULL;
810                 }
811                 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->file_count));
812                 {
813                         uint32_t _flags_save_string = ndr->flags;
814                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
815                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_monitor_name));
816                         if (_ptr_monitor_name) {
817                                 NDR_PULL_ALLOC(ndr, r->monitor_name);
818                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->monitor_name, _ptr_monitor_name));
819                         } else {
820                                 r->monitor_name = NULL;
821                         }
822                         ndr->flags = _flags_save_string;
823                 }
824                 {
825                         uint32_t _flags_save_string = ndr->flags;
826                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
827                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_default_datatype));
828                         if (_ptr_default_datatype) {
829                                 NDR_PULL_ALLOC(ndr, r->default_datatype);
830                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->default_datatype, _ptr_default_datatype));
831                         } else {
832                                 r->default_datatype = NULL;
833                         }
834                         ndr->flags = _flags_save_string;
835                 }
836                 {
837                         uint32_t _flags_save_string_array = ndr->flags;
838                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
839                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_previous_names));
840                         if (_ptr_previous_names) {
841                                 NDR_PULL_ALLOC(ndr, r->previous_names);
842                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->previous_names, _ptr_previous_names));
843                         } else {
844                                 r->previous_names = NULL;
845                         }
846                         ndr->flags = _flags_save_string_array;
847                 }
848                 NDR_CHECK(ndr_pull_NTTIME(ndr, NDR_SCALARS, &r->driver_date));
849                 NDR_CHECK(ndr_pull_hyper(ndr, NDR_SCALARS, &r->driver_version));
850                 {
851                         uint32_t _flags_save_string = ndr->flags;
852                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
853                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_manufacturer_name));
854                         if (_ptr_manufacturer_name) {
855                                 NDR_PULL_ALLOC(ndr, r->manufacturer_name);
856                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->manufacturer_name, _ptr_manufacturer_name));
857                         } else {
858                                 r->manufacturer_name = NULL;
859                         }
860                         ndr->flags = _flags_save_string;
861                 }
862                 {
863                         uint32_t _flags_save_string = ndr->flags;
864                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
865                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_manufacturer_url));
866                         if (_ptr_manufacturer_url) {
867                                 NDR_PULL_ALLOC(ndr, r->manufacturer_url);
868                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->manufacturer_url, _ptr_manufacturer_url));
869                         } else {
870                                 r->manufacturer_url = NULL;
871                         }
872                         ndr->flags = _flags_save_string;
873                 }
874                 {
875                         uint32_t _flags_save_string = ndr->flags;
876                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
877                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_hardware_id));
878                         if (_ptr_hardware_id) {
879                                 NDR_PULL_ALLOC(ndr, r->hardware_id);
880                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->hardware_id, _ptr_hardware_id));
881                         } else {
882                                 r->hardware_id = NULL;
883                         }
884                         ndr->flags = _flags_save_string;
885                 }
886                 {
887                         uint32_t _flags_save_string = ndr->flags;
888                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
889                         NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_provider));
890                         if (_ptr_provider) {
891                                 NDR_PULL_ALLOC(ndr, r->provider);
892                                 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->provider, _ptr_provider));
893                         } else {
894                                 r->provider = NULL;
895                         }
896                         ndr->flags = _flags_save_string;
897                 }
898         }
899         if (ndr_flags & NDR_BUFFERS) {
900                 {
901                         uint32_t _flags_save_string = ndr->flags;
902                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
903                         if (r->driver_name) {
904                                 uint32_t _relative_save_offset;
905                                 _relative_save_offset = ndr->offset;
906                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->driver_name));
907                                 _mem_save_driver_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
908                                 NDR_PULL_SET_MEM_CTX(ndr, r->driver_name, 0);
909                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->driver_name));
910                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_driver_name_0, 0);
911                                 ndr->offset = _relative_save_offset;
912                         }
913                         ndr->flags = _flags_save_string;
914                 }
915                 {
916                         uint32_t _flags_save_string = ndr->flags;
917                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
918                         if (r->architecture) {
919                                 uint32_t _relative_save_offset;
920                                 _relative_save_offset = ndr->offset;
921                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->architecture));
922                                 _mem_save_architecture_0 = NDR_PULL_GET_MEM_CTX(ndr);
923                                 NDR_PULL_SET_MEM_CTX(ndr, r->architecture, 0);
924                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->architecture));
925                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_architecture_0, 0);
926                                 ndr->offset = _relative_save_offset;
927                         }
928                         ndr->flags = _flags_save_string;
929                 }
930                 if (r->file_info) {
931                         uint32_t _relative_save_offset;
932                         _relative_save_offset = ndr->offset;
933                         NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->file_info));
934                         _mem_save_file_info_0 = NDR_PULL_GET_MEM_CTX(ndr);
935                         NDR_PULL_SET_MEM_CTX(ndr, r->file_info, 0);
936 #if 0
937                         NDR_CHECK(ndr_pull_array_size(ndr, &r->file_info));
938 #else
939                         NDR_CHECK(ndr_token_store(ndr, &ndr->array_size_list, &r->file_info, r->file_count));
940 #endif
941                         NDR_PULL_ALLOC_N(ndr, r->file_info, ndr_get_array_size(ndr, &r->file_info));
942                         _mem_save_file_info_1 = NDR_PULL_GET_MEM_CTX(ndr);
943                         NDR_PULL_SET_MEM_CTX(ndr, r->file_info, 0);
944                         for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
945                                 NDR_CHECK(ndr_pull_spoolss_DriverFileInfo(ndr, NDR_SCALARS, &r->file_info[cntr_file_info_1]));
946                         }
947                         for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
948                                 NDR_CHECK(ndr_pull_spoolss_DriverFileInfo(ndr, NDR_BUFFERS, &r->file_info[cntr_file_info_1]));
949                         }
950                         NDR_PULL_SET_MEM_CTX(ndr, _mem_save_file_info_1, 0);
951                         NDR_PULL_SET_MEM_CTX(ndr, _mem_save_file_info_0, 0);
952                         ndr->offset = _relative_save_offset;
953                 }
954                 {
955                         uint32_t _flags_save_string = ndr->flags;
956                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
957                         if (r->monitor_name) {
958                                 uint32_t _relative_save_offset;
959                                 _relative_save_offset = ndr->offset;
960                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->monitor_name));
961                                 _mem_save_monitor_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
962                                 NDR_PULL_SET_MEM_CTX(ndr, r->monitor_name, 0);
963                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->monitor_name));
964                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_monitor_name_0, 0);
965                                 ndr->offset = _relative_save_offset;
966                         }
967                         ndr->flags = _flags_save_string;
968                 }
969                 {
970                         uint32_t _flags_save_string = ndr->flags;
971                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
972                         if (r->default_datatype) {
973                                 uint32_t _relative_save_offset;
974                                 _relative_save_offset = ndr->offset;
975                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->default_datatype));
976                                 _mem_save_default_datatype_0 = NDR_PULL_GET_MEM_CTX(ndr);
977                                 NDR_PULL_SET_MEM_CTX(ndr, r->default_datatype, 0);
978                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->default_datatype));
979                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_default_datatype_0, 0);
980                                 ndr->offset = _relative_save_offset;
981                         }
982                         ndr->flags = _flags_save_string;
983                 }
984                 {
985                         uint32_t _flags_save_string_array = ndr->flags;
986                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
987                         if (r->previous_names) {
988                                 uint32_t _relative_save_offset;
989                                 _relative_save_offset = ndr->offset;
990                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->previous_names));
991                                 _mem_save_previous_names_0 = NDR_PULL_GET_MEM_CTX(ndr);
992                                 NDR_PULL_SET_MEM_CTX(ndr, r->previous_names, 0);
993                                 NDR_CHECK(ndr_pull_string_array(ndr, NDR_SCALARS, &r->previous_names));
994                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_previous_names_0, 0);
995                                 ndr->offset = _relative_save_offset;
996                         }
997                         ndr->flags = _flags_save_string_array;
998                 }
999                 {
1000                         uint32_t _flags_save_string = ndr->flags;
1001                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1002                         if (r->manufacturer_name) {
1003                                 uint32_t _relative_save_offset;
1004                                 _relative_save_offset = ndr->offset;
1005                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->manufacturer_name));
1006                                 _mem_save_manufacturer_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
1007                                 NDR_PULL_SET_MEM_CTX(ndr, r->manufacturer_name, 0);
1008                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->manufacturer_name));
1009                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_manufacturer_name_0, 0);
1010                                 ndr->offset = _relative_save_offset;
1011                         }
1012                         ndr->flags = _flags_save_string;
1013                 }
1014                 {
1015                         uint32_t _flags_save_string = ndr->flags;
1016                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1017                         if (r->manufacturer_url) {
1018                                 uint32_t _relative_save_offset;
1019                                 _relative_save_offset = ndr->offset;
1020                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->manufacturer_url));
1021                                 _mem_save_manufacturer_url_0 = NDR_PULL_GET_MEM_CTX(ndr);
1022                                 NDR_PULL_SET_MEM_CTX(ndr, r->manufacturer_url, 0);
1023                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->manufacturer_url));
1024                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_manufacturer_url_0, 0);
1025                                 ndr->offset = _relative_save_offset;
1026                         }
1027                         ndr->flags = _flags_save_string;
1028                 }
1029                 {
1030                         uint32_t _flags_save_string = ndr->flags;
1031                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1032                         if (r->hardware_id) {
1033                                 uint32_t _relative_save_offset;
1034                                 _relative_save_offset = ndr->offset;
1035                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->hardware_id));
1036                                 _mem_save_hardware_id_0 = NDR_PULL_GET_MEM_CTX(ndr);
1037                                 NDR_PULL_SET_MEM_CTX(ndr, r->hardware_id, 0);
1038                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->hardware_id));
1039                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_hardware_id_0, 0);
1040                                 ndr->offset = _relative_save_offset;
1041                         }
1042                         ndr->flags = _flags_save_string;
1043                 }
1044                 {
1045                         uint32_t _flags_save_string = ndr->flags;
1046                         ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1047                         if (r->provider) {
1048                                 uint32_t _relative_save_offset;
1049                                 _relative_save_offset = ndr->offset;
1050                                 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->provider));
1051                                 _mem_save_provider_0 = NDR_PULL_GET_MEM_CTX(ndr);
1052                                 NDR_PULL_SET_MEM_CTX(ndr, r->provider, 0);
1053                                 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->provider));
1054                                 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_provider_0, 0);
1055                                 ndr->offset = _relative_save_offset;
1056                         }
1057                         ndr->flags = _flags_save_string;
1058                 }
1059                 if (r->file_info) {
1060                         NDR_CHECK(ndr_check_array_size(ndr, (void*)&r->file_info, r->file_count));
1061                 }
1062         }
1063         return NDR_ERR_SUCCESS;
1064 }