2 Unix SMB/CIFS implementation.
4 routines for marshalling/unmarshalling spoolss subcontext buffer structures
6 Copyright (C) Andrew Tridgell 2003
7 Copyright (C) Tim Potter 2003
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.
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.
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/>.
25 #include "librpc/gen_ndr/ndr_spoolss.h"
26 #if (_SAMBA_BUILD_ >= 4)
27 #include "param/param.h"
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);\
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));\
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;\
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");\
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;\
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)); \
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);\
79 _data_blob_info = ndr_push_blob(_ndr_info);\
80 _r.out.info = &_data_blob_info;\
82 NDR_CHECK(ndr_push__##fn(ndr, flags, &_r));\
85 #define NDR_SPOOLSS_PUSH_ENUM(fn,in,out) do { \
87 if (flags & NDR_IN) {\
89 NDR_SPOOLSS_PUSH_ENUM_IN(fn);\
91 if (flags & NDR_OUT) {\
93 NDR_SPOOLSS_PUSH_ENUM_OUT(fn);\
97 #define NDR_SPOOLSS_PULL_ENUM_IN(fn) do { \
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);\
114 NDR_PULL_ALLOC(ndr, r->out.info);\
115 ZERO_STRUCTP(r->out.info);\
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);\
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;\
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);\
143 if (*r->out.needed <= _ndr_info->data_size) {\
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;\
154 #define NDR_SPOOLSS_PULL_ENUM(fn,in,out) do { \
156 if (flags & NDR_IN) {\
158 NDR_SPOOLSS_PULL_ENUM_IN(fn);\
161 if (flags & NDR_OUT) {\
163 NDR_SPOOLSS_PULL_ENUM_OUT(fn);\
167 #define _NDR_CHECK_UINT32(call) do {\
168 enum ndr_err_code _ndr_err; \
170 if (!NDR_ERR_CODE_IS_SUCCESS(_ndr_err)) { \
175 /* TODO: set _ndr_info->flags correct */
176 #define NDR_SPOOLSS_SIZE_ENUM(fn) do { \
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;\
193 enum ndr_err_code ndr_push_spoolss_EnumPrinters(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrinters *r)
195 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrinters,{
196 _r.in.flags = r->in.flags;
197 _r.in.server = r->in.server;
199 _r.in.flags = r->in.flags;
200 _r.in.server = r->in.server;
202 return NDR_ERR_SUCCESS;
205 enum ndr_err_code ndr_pull_spoolss_EnumPrinters(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrinters *r)
207 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrinters,{
208 r->in.flags = _r.in.flags;
209 r->in.server = _r.in.server;
211 _r.in.flags = r->in.flags;
212 _r.in.server = r->in.server;
214 return NDR_ERR_SUCCESS;
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)
219 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrinters);
225 enum ndr_err_code ndr_push_spoolss_EnumJobs(struct ndr_push *ndr, int flags, const struct spoolss_EnumJobs *r)
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;
232 _r.in.handle = r->in.handle;
233 _r.in.firstjob = r->in.firstjob;
234 _r.in.numjobs = r->in.numjobs;
236 return NDR_ERR_SUCCESS;
239 enum ndr_err_code ndr_pull_spoolss_EnumJobs(struct ndr_pull *ndr, int flags, struct spoolss_EnumJobs *r)
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;
246 _r.in.handle = r->in.handle;
247 _r.in.firstjob = r->in.firstjob;
248 _r.in.numjobs = r->in.numjobs;
250 return NDR_ERR_SUCCESS;
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)
255 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumJobs);
259 spoolss_EnumPrinterDrivers
261 enum ndr_err_code ndr_push_spoolss_EnumPrinterDrivers(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrinterDrivers *r)
263 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrinterDrivers,{
264 _r.in.server = r->in.server;
265 _r.in.environment = r->in.environment;
267 _r.in.server = r->in.server;
268 _r.in.environment = r->in.environment;
270 return NDR_ERR_SUCCESS;
273 enum ndr_err_code ndr_pull_spoolss_EnumPrinterDrivers(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrinterDrivers *r)
275 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrinterDrivers,{
276 r->in.server = _r.in.server;
277 r->in.environment = _r.in.environment;
279 _r.in.server = r->in.server;
280 _r.in.environment = r->in.environment;
282 return NDR_ERR_SUCCESS;
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)
287 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrinterDrivers);
293 enum ndr_err_code ndr_push_spoolss_EnumForms(struct ndr_push *ndr, int flags, const struct spoolss_EnumForms *r)
295 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumForms,{
296 _r.in.handle = r->in.handle;
298 _r.in.handle = r->in.handle;
300 return NDR_ERR_SUCCESS;
303 enum ndr_err_code ndr_pull_spoolss_EnumForms(struct ndr_pull *ndr, int flags, struct spoolss_EnumForms *r)
305 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumForms,{
306 r->in.handle = _r.in.handle;
308 _r.in.handle = r->in.handle;
310 return NDR_ERR_SUCCESS;
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)
315 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumForms);
321 enum ndr_err_code ndr_push_spoolss_EnumPorts(struct ndr_push *ndr, int flags, const struct spoolss_EnumPorts *r)
323 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPorts,{
324 _r.in.servername= r->in.servername;
326 _r.in.servername= r->in.servername;
328 return NDR_ERR_SUCCESS;
331 enum ndr_err_code ndr_pull_spoolss_EnumPorts(struct ndr_pull *ndr, int flags, struct spoolss_EnumPorts *r)
333 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPorts,{
334 r->in.servername= _r.in.servername;
336 _r.in.servername= r->in.servername;
338 return NDR_ERR_SUCCESS;
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)
343 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPorts);
349 enum ndr_err_code ndr_push_spoolss_EnumMonitors(struct ndr_push *ndr, int flags, const struct spoolss_EnumMonitors *r)
351 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumMonitors,{
352 _r.in.servername= r->in.servername;
354 _r.in.servername= r->in.servername;
356 return NDR_ERR_SUCCESS;
359 enum ndr_err_code ndr_pull_spoolss_EnumMonitors(struct ndr_pull *ndr, int flags, struct spoolss_EnumMonitors *r)
361 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumMonitors,{
362 r->in.servername= _r.in.servername;
364 _r.in.servername= r->in.servername;
366 return NDR_ERR_SUCCESS;
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)
371 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumMonitors);
375 spoolss_EnumPrintProcessors
377 enum ndr_err_code ndr_push_spoolss_EnumPrintProcessors(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrintProcessors *r)
379 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrintProcessors,{
380 _r.in.servername = r->in.servername;
381 _r.in.environment = r->in.environment;
383 _r.in.servername = r->in.servername;
384 _r.in.environment = r->in.environment;
386 return NDR_ERR_SUCCESS;
389 enum ndr_err_code ndr_pull_spoolss_EnumPrintProcessors(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrintProcessors *r)
391 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrintProcessors,{
392 r->in.servername = _r.in.servername;
393 r->in.environment = _r.in.environment;
395 _r.in.servername = r->in.servername;
396 _r.in.environment = r->in.environment;
398 return NDR_ERR_SUCCESS;
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)
404 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrintProcessors);
408 spoolss_EnumPrintProcessors
410 enum ndr_err_code ndr_push_spoolss_EnumPrintProcDataTypes(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrintProcDataTypes *r)
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;
416 _r.in.servername = r->in.servername;
417 _r.in.print_processor_name = r->in.print_processor_name;
419 return NDR_ERR_SUCCESS;
422 enum ndr_err_code ndr_pull_spoolss_EnumPrintProcDataTypes(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrintProcDataTypes *r)
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;
428 _r.in.servername = r->in.servername;
429 _r.in.print_processor_name = r->in.print_processor_name;
431 return NDR_ERR_SUCCESS;
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)
437 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrintProcDataTypes);
441 spoolss_GetPrinterData
443 enum ndr_err_code ndr_push_spoolss_GetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_GetPrinterData *r)
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));
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;
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));
473 _r.out.data = ndr_push_blob(_ndr_info);
475 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
477 return NDR_ERR_SUCCESS;
480 enum ndr_err_code ndr_pull_spoolss_GetPrinterData(struct ndr_pull *ndr, int flags, struct spoolss_GetPrinterData *r)
482 struct _spoolss_GetPrinterData _r;
483 if (flags & NDR_IN) {
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;
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);
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;
526 *r->out.type = SPOOLSS_PRINTER_DATA_TYPE_NULL;
529 return NDR_ERR_SUCCESS;
533 spoolss_SetPrinterData
535 enum ndr_err_code ndr_push_spoolss_SetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_SetPrinterData *r)
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;
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;
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);
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));
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));
569 return NDR_ERR_SUCCESS;
572 uint32_t _ndr_size_spoolss_DeviceMode(struct spoolss_DeviceMode *devmode, struct smb_iconv_convenience *ic, uint32_t flags)
574 if (!devmode) return 0;
575 return ndr_size_spoolss_DeviceMode(devmode,ic,flags);
578 _PUBLIC_ size_t ndr_size_spoolss_StringArray(const struct spoolss_StringArray *r, struct smb_iconv_convenience *ic, int flags)
584 return ndr_size_struct(r, flags, (ndr_push_flags_fn_t)ndr_push_spoolss_StringArray, ic);
587 /* hand marshall as pidl cannot (yet) generate a relative pointer to a fixed array of
590 _PUBLIC_ enum ndr_err_code ndr_push_spoolss_DriverInfo101(struct ndr_push *ndr, int ndr_flags, const struct spoolss_DriverInfo101 *r)
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));
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;
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;
608 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->file_info));
609 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
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;
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;
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;
628 NDR_CHECK(ndr_push_NTTIME(ndr, NDR_SCALARS, r->driver_date));
629 NDR_CHECK(ndr_push_hyper(ndr, NDR_SCALARS, r->driver_version));
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;
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;
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;
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;
655 if (ndr_flags & NDR_BUFFERS) {
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));
663 ndr->flags = _flags_save_string;
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));
672 ndr->flags = _flags_save_string;
675 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->file_info));
677 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
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]));
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]));
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));
693 ndr->flags = _flags_save_string;
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));
702 ndr->flags = _flags_save_string;
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));
711 ndr->flags = _flags_save_string_array;
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));
720 ndr->flags = _flags_save_string;
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));
729 ndr->flags = _flags_save_string;
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));
738 ndr->flags = _flags_save_string;
741 uint32_t _flags_save_string = ndr->flags;
742 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
744 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->provider));
745 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->provider));
747 ndr->flags = _flags_save_string;
750 return NDR_ERR_SUCCESS;
753 _PUBLIC_ enum ndr_err_code ndr_pull_spoolss_DriverInfo101(struct ndr_pull *ndr, int ndr_flags, struct spoolss_DriverInfo101 *r)
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));
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));
788 r->driver_name = NULL;
790 ndr->flags = _flags_save_string;
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));
800 r->architecture = NULL;
802 ndr->flags = _flags_save_string;
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));
811 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->file_count));
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));
820 r->monitor_name = NULL;
822 ndr->flags = _flags_save_string;
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));
832 r->default_datatype = NULL;
834 ndr->flags = _flags_save_string;
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));
844 r->previous_names = NULL;
846 ndr->flags = _flags_save_string_array;
848 NDR_CHECK(ndr_pull_NTTIME(ndr, NDR_SCALARS, &r->driver_date));
849 NDR_CHECK(ndr_pull_hyper(ndr, NDR_SCALARS, &r->driver_version));
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));
858 r->manufacturer_name = NULL;
860 ndr->flags = _flags_save_string;
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));
870 r->manufacturer_url = NULL;
872 ndr->flags = _flags_save_string;
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));
882 r->hardware_id = NULL;
884 ndr->flags = _flags_save_string;
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));
891 NDR_PULL_ALLOC(ndr, r->provider);
892 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->provider, _ptr_provider));
896 ndr->flags = _flags_save_string;
899 if (ndr_flags & NDR_BUFFERS) {
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;
913 ndr->flags = _flags_save_string;
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;
928 ndr->flags = _flags_save_string;
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);
937 NDR_CHECK(ndr_pull_array_size(ndr, &r->file_info));
939 NDR_CHECK(ndr_token_store(ndr, &ndr->array_size_list, &r->file_info, r->file_count));
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]));
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]));
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;
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;
967 ndr->flags = _flags_save_string;
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;
982 ndr->flags = _flags_save_string;
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;
997 ndr->flags = _flags_save_string_array;
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;
1012 ndr->flags = _flags_save_string;
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;
1027 ndr->flags = _flags_save_string;
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;
1042 ndr->flags = _flags_save_string;
1045 uint32_t _flags_save_string = ndr->flags;
1046 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
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;
1057 ndr->flags = _flags_save_string;
1060 NDR_CHECK(ndr_check_array_size(ndr, (void*)&r->file_info, r->file_count));
1063 return NDR_ERR_SUCCESS;