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_EnumJobs_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_EnumPrintProcessors_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 DATA_BLOB blob = data_blob(NULL, 0);
455 _r.in.handle = r->in.handle;
456 _r.in.value_name= r->in.value_name;
457 _r.in.offered = r->in.offered;
458 _r.out.type = r->out.type;
460 _r.out.needed = r->out.needed;
461 _r.out.result = r->out.result;
463 struct __spoolss_GetPrinterData __r;
465 _ndr_info = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
466 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);
467 _ndr_info->flags= ndr->flags;
468 __r.in.type = *r->out.type;
469 __r.out.data = r->out.data;
470 NDR_CHECK(ndr_push___spoolss_GetPrinterData(_ndr_info, flags, &__r));
471 if (r->in.offered > _ndr_info->offset) {
472 uint32_t _padding_len = r->in.offered - _ndr_info->offset;
473 NDR_CHECK(ndr_push_zero(_ndr_info, _padding_len));
475 _blob = ndr_push_blob(_ndr_info);
476 _r.out.data = &_blob;
478 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
480 return NDR_ERR_SUCCESS;
483 enum ndr_err_code ndr_pull_spoolss_GetPrinterData(struct ndr_pull *ndr, int flags, struct spoolss_GetPrinterData *r)
485 struct _spoolss_GetPrinterData _r;
486 if (flags & NDR_IN) {
487 DATA_BLOB blob = data_blob(NULL,0);
490 _r.in.handle = r->in.handle;
491 _r.in.value_name= r->in.value_name;
492 _r.in.offered = r->in.offered;
493 _r.out.type = r->out.type;
495 _r.out.needed = r->out.needed;
496 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
497 r->in.handle = _r.in.handle;
498 r->in.value_name= _r.in.value_name;
499 r->in.offered = _r.in.offered;
500 r->out.needed = _r.out.needed;
502 if (flags & NDR_OUT) {
503 DATA_BLOB blob = data_blob_talloc(ndr,NULL,0);
504 _r.in.handle = r->in.handle;
505 _r.in.value_name= r->in.value_name;
506 _r.in.offered = r->in.offered;
507 _r.out.type = r->out.type;
509 _r.out.needed = r->out.needed;
510 _r.out.result = r->out.result;
511 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
512 r->out.type = _r.out.type;
513 if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
514 NDR_PULL_ALLOC(ndr, r->out.data);
516 ZERO_STRUCTP(r->out.data);
517 r->out.needed = _r.out.needed;
518 r->out.result = _r.out.result;
519 if (_r.out.data && _r.out.data->length != r->in.offered) {
520 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,
521 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of out buffer[%u]",
522 (unsigned)r->in.offered, (unsigned)_r.out.data->length);
524 if (_r.out.data && _r.out.data->length > 0 && *r->out.needed <= _r.out.data->length) {
525 struct __spoolss_GetPrinterData __r;
526 struct ndr_pull *_ndr_data = ndr_pull_init_blob(_r.out.data, ndr, ndr->iconv_convenience);
527 NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
528 _ndr_data->flags= ndr->flags;
529 __r.in.type = *r->out.type;
530 __r.out.data = r->out.data;
531 NDR_CHECK(ndr_pull___spoolss_GetPrinterData(_ndr_data, flags, &__r));
532 r->out.data = __r.out.data;
534 *r->out.type = REG_NONE;
537 return NDR_ERR_SUCCESS;
541 spoolss_SetPrinterData
543 enum ndr_err_code ndr_push_spoolss_SetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_SetPrinterData *r)
545 struct _spoolss_SetPrinterData _r;
546 if (flags & NDR_IN) {
547 struct ndr_push *_ndr_data;
548 struct __spoolss_SetPrinterData __r;
549 DATA_BLOB _data_blob_data;
551 _ndr_data = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
552 NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
553 _ndr_data->flags= ndr->flags;
555 __r.in.type = r->in.type;
556 __r.out.data = discard_const_p(union spoolss_PrinterData, &r->in.data);
557 NDR_CHECK(ndr_push___spoolss_SetPrinterData(_ndr_data, NDR_OUT, &__r));
558 _data_blob_data = ndr_push_blob(_ndr_data);
560 _r.in.handle = r->in.handle;
561 _r.in.value_name= r->in.value_name;
562 _r.in.type = r->in.type;
563 _r.in.data = _data_blob_data;
564 _r.in._offered = _data_blob_data.length;
565 _r.out.result = r->out.result;
566 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
568 if (flags & NDR_OUT) {
569 _r.in.handle = r->in.handle;
570 _r.in.value_name= r->in.value_name;
571 _r.in.type = r->in.type;
572 _r.in.data = data_blob(NULL,0),
573 _r.in._offered = r->in._offered;
574 _r.out.result = r->out.result;
575 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
577 return NDR_ERR_SUCCESS;
580 uint32_t _ndr_size_spoolss_DeviceMode(struct spoolss_DeviceMode *devmode, struct smb_iconv_convenience *ic, uint32_t flags)
582 if (!devmode) return 0;
583 return ndr_size_spoolss_DeviceMode(devmode,ic,flags);
586 _PUBLIC_ size_t ndr_size_spoolss_StringArray(const struct spoolss_StringArray *r, struct smb_iconv_convenience *ic, int flags)
592 return ndr_size_struct(r, flags, (ndr_push_flags_fn_t)ndr_push_spoolss_StringArray, ic);
595 /* hand marshall as pidl cannot (yet) generate a relative pointer to a fixed array of
598 _PUBLIC_ enum ndr_err_code ndr_push_spoolss_DriverInfo101(struct ndr_push *ndr, int ndr_flags, const struct spoolss_DriverInfo101 *r)
600 uint32_t cntr_file_info_1;
601 if (ndr_flags & NDR_SCALARS) {
602 NDR_CHECK(ndr_push_align(ndr, 8));
603 NDR_CHECK(ndr_push_spoolss_DriverOSVersion(ndr, NDR_SCALARS, r->version));
605 uint32_t _flags_save_string = ndr->flags;
606 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
607 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->driver_name));
608 ndr->flags = _flags_save_string;
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->architecture));
614 ndr->flags = _flags_save_string;
616 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->file_info));
617 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
619 uint32_t _flags_save_string = ndr->flags;
620 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
621 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->monitor_name));
622 ndr->flags = _flags_save_string;
625 uint32_t _flags_save_string = ndr->flags;
626 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
627 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->default_datatype));
628 ndr->flags = _flags_save_string;
631 uint32_t _flags_save_string_array = ndr->flags;
632 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
633 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->previous_names));
634 ndr->flags = _flags_save_string_array;
636 NDR_CHECK(ndr_push_NTTIME(ndr, NDR_SCALARS, r->driver_date));
637 NDR_CHECK(ndr_push_hyper(ndr, NDR_SCALARS, r->driver_version));
639 uint32_t _flags_save_string = ndr->flags;
640 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
641 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->manufacturer_name));
642 ndr->flags = _flags_save_string;
645 uint32_t _flags_save_string = ndr->flags;
646 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
647 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->manufacturer_url));
648 ndr->flags = _flags_save_string;
651 uint32_t _flags_save_string = ndr->flags;
652 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
653 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->hardware_id));
654 ndr->flags = _flags_save_string;
657 uint32_t _flags_save_string = ndr->flags;
658 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
659 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->provider));
660 ndr->flags = _flags_save_string;
663 if (ndr_flags & NDR_BUFFERS) {
665 uint32_t _flags_save_string = ndr->flags;
666 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
667 if (r->driver_name) {
668 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->driver_name));
669 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->driver_name));
671 ndr->flags = _flags_save_string;
674 uint32_t _flags_save_string = ndr->flags;
675 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
676 if (r->architecture) {
677 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->architecture));
678 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->architecture));
680 ndr->flags = _flags_save_string;
683 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->file_info));
685 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
687 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
688 NDR_CHECK(ndr_push_spoolss_DriverFileInfo(ndr, NDR_SCALARS, &r->file_info[cntr_file_info_1]));
690 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
691 NDR_CHECK(ndr_push_spoolss_DriverFileInfo(ndr, NDR_BUFFERS, &r->file_info[cntr_file_info_1]));
695 uint32_t _flags_save_string = ndr->flags;
696 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
697 if (r->monitor_name) {
698 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->monitor_name));
699 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->monitor_name));
701 ndr->flags = _flags_save_string;
704 uint32_t _flags_save_string = ndr->flags;
705 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
706 if (r->default_datatype) {
707 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->default_datatype));
708 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->default_datatype));
710 ndr->flags = _flags_save_string;
713 uint32_t _flags_save_string_array = ndr->flags;
714 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
715 if (r->previous_names) {
716 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->previous_names));
717 NDR_CHECK(ndr_push_string_array(ndr, NDR_SCALARS, r->previous_names));
719 ndr->flags = _flags_save_string_array;
722 uint32_t _flags_save_string = ndr->flags;
723 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
724 if (r->manufacturer_name) {
725 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->manufacturer_name));
726 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->manufacturer_name));
728 ndr->flags = _flags_save_string;
731 uint32_t _flags_save_string = ndr->flags;
732 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
733 if (r->manufacturer_url) {
734 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->manufacturer_url));
735 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->manufacturer_url));
737 ndr->flags = _flags_save_string;
740 uint32_t _flags_save_string = ndr->flags;
741 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
742 if (r->hardware_id) {
743 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->hardware_id));
744 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->hardware_id));
746 ndr->flags = _flags_save_string;
749 uint32_t _flags_save_string = ndr->flags;
750 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
752 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->provider));
753 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->provider));
755 ndr->flags = _flags_save_string;
758 return NDR_ERR_SUCCESS;
761 _PUBLIC_ enum ndr_err_code ndr_pull_spoolss_DriverInfo101(struct ndr_pull *ndr, int ndr_flags, struct spoolss_DriverInfo101 *r)
763 uint32_t _ptr_driver_name;
764 TALLOC_CTX *_mem_save_driver_name_0;
765 uint32_t _ptr_architecture;
766 TALLOC_CTX *_mem_save_architecture_0;
767 uint32_t _ptr_file_info;
768 uint32_t cntr_file_info_1;
769 TALLOC_CTX *_mem_save_file_info_0;
770 TALLOC_CTX *_mem_save_file_info_1;
771 uint32_t _ptr_monitor_name;
772 TALLOC_CTX *_mem_save_monitor_name_0;
773 uint32_t _ptr_default_datatype;
774 TALLOC_CTX *_mem_save_default_datatype_0;
775 uint32_t _ptr_previous_names;
776 TALLOC_CTX *_mem_save_previous_names_0;
777 uint32_t _ptr_manufacturer_name;
778 TALLOC_CTX *_mem_save_manufacturer_name_0;
779 uint32_t _ptr_manufacturer_url;
780 TALLOC_CTX *_mem_save_manufacturer_url_0;
781 uint32_t _ptr_hardware_id;
782 TALLOC_CTX *_mem_save_hardware_id_0;
783 uint32_t _ptr_provider;
784 TALLOC_CTX *_mem_save_provider_0;
785 if (ndr_flags & NDR_SCALARS) {
786 NDR_CHECK(ndr_pull_align(ndr, 8));
787 NDR_CHECK(ndr_pull_spoolss_DriverOSVersion(ndr, NDR_SCALARS, &r->version));
789 uint32_t _flags_save_string = ndr->flags;
790 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
791 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_driver_name));
792 if (_ptr_driver_name) {
793 NDR_PULL_ALLOC(ndr, r->driver_name);
794 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->driver_name, _ptr_driver_name));
796 r->driver_name = NULL;
798 ndr->flags = _flags_save_string;
801 uint32_t _flags_save_string = ndr->flags;
802 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
803 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_architecture));
804 if (_ptr_architecture) {
805 NDR_PULL_ALLOC(ndr, r->architecture);
806 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->architecture, _ptr_architecture));
808 r->architecture = NULL;
810 ndr->flags = _flags_save_string;
812 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_file_info));
813 if (_ptr_file_info) {
814 NDR_PULL_ALLOC(ndr, r->file_info);
815 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->file_info, _ptr_file_info));
819 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->file_count));
821 uint32_t _flags_save_string = ndr->flags;
822 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
823 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_monitor_name));
824 if (_ptr_monitor_name) {
825 NDR_PULL_ALLOC(ndr, r->monitor_name);
826 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->monitor_name, _ptr_monitor_name));
828 r->monitor_name = NULL;
830 ndr->flags = _flags_save_string;
833 uint32_t _flags_save_string = ndr->flags;
834 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
835 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_default_datatype));
836 if (_ptr_default_datatype) {
837 NDR_PULL_ALLOC(ndr, r->default_datatype);
838 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->default_datatype, _ptr_default_datatype));
840 r->default_datatype = NULL;
842 ndr->flags = _flags_save_string;
845 uint32_t _flags_save_string_array = ndr->flags;
846 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
847 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_previous_names));
848 if (_ptr_previous_names) {
849 NDR_PULL_ALLOC(ndr, r->previous_names);
850 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->previous_names, _ptr_previous_names));
852 r->previous_names = NULL;
854 ndr->flags = _flags_save_string_array;
856 NDR_CHECK(ndr_pull_NTTIME(ndr, NDR_SCALARS, &r->driver_date));
857 NDR_CHECK(ndr_pull_hyper(ndr, NDR_SCALARS, &r->driver_version));
859 uint32_t _flags_save_string = ndr->flags;
860 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
861 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_manufacturer_name));
862 if (_ptr_manufacturer_name) {
863 NDR_PULL_ALLOC(ndr, r->manufacturer_name);
864 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->manufacturer_name, _ptr_manufacturer_name));
866 r->manufacturer_name = NULL;
868 ndr->flags = _flags_save_string;
871 uint32_t _flags_save_string = ndr->flags;
872 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
873 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_manufacturer_url));
874 if (_ptr_manufacturer_url) {
875 NDR_PULL_ALLOC(ndr, r->manufacturer_url);
876 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->manufacturer_url, _ptr_manufacturer_url));
878 r->manufacturer_url = NULL;
880 ndr->flags = _flags_save_string;
883 uint32_t _flags_save_string = ndr->flags;
884 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
885 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_hardware_id));
886 if (_ptr_hardware_id) {
887 NDR_PULL_ALLOC(ndr, r->hardware_id);
888 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->hardware_id, _ptr_hardware_id));
890 r->hardware_id = NULL;
892 ndr->flags = _flags_save_string;
895 uint32_t _flags_save_string = ndr->flags;
896 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
897 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_provider));
899 NDR_PULL_ALLOC(ndr, r->provider);
900 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->provider, _ptr_provider));
904 ndr->flags = _flags_save_string;
907 if (ndr_flags & NDR_BUFFERS) {
909 uint32_t _flags_save_string = ndr->flags;
910 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
911 if (r->driver_name) {
912 uint32_t _relative_save_offset;
913 _relative_save_offset = ndr->offset;
914 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->driver_name));
915 _mem_save_driver_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
916 NDR_PULL_SET_MEM_CTX(ndr, r->driver_name, 0);
917 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->driver_name));
918 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_driver_name_0, 0);
919 ndr->offset = _relative_save_offset;
921 ndr->flags = _flags_save_string;
924 uint32_t _flags_save_string = ndr->flags;
925 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
926 if (r->architecture) {
927 uint32_t _relative_save_offset;
928 _relative_save_offset = ndr->offset;
929 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->architecture));
930 _mem_save_architecture_0 = NDR_PULL_GET_MEM_CTX(ndr);
931 NDR_PULL_SET_MEM_CTX(ndr, r->architecture, 0);
932 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->architecture));
933 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_architecture_0, 0);
934 ndr->offset = _relative_save_offset;
936 ndr->flags = _flags_save_string;
939 uint32_t _relative_save_offset;
940 _relative_save_offset = ndr->offset;
941 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->file_info));
942 _mem_save_file_info_0 = NDR_PULL_GET_MEM_CTX(ndr);
943 NDR_PULL_SET_MEM_CTX(ndr, r->file_info, 0);
945 NDR_CHECK(ndr_pull_array_size(ndr, &r->file_info));
947 NDR_CHECK(ndr_token_store(ndr, &ndr->array_size_list, &r->file_info, r->file_count));
949 NDR_PULL_ALLOC_N(ndr, r->file_info, ndr_get_array_size(ndr, &r->file_info));
950 _mem_save_file_info_1 = NDR_PULL_GET_MEM_CTX(ndr);
951 NDR_PULL_SET_MEM_CTX(ndr, r->file_info, 0);
952 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
953 NDR_CHECK(ndr_pull_spoolss_DriverFileInfo(ndr, NDR_SCALARS, &r->file_info[cntr_file_info_1]));
955 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
956 NDR_CHECK(ndr_pull_spoolss_DriverFileInfo(ndr, NDR_BUFFERS, &r->file_info[cntr_file_info_1]));
958 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_file_info_1, 0);
959 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_file_info_0, 0);
960 ndr->offset = _relative_save_offset;
963 uint32_t _flags_save_string = ndr->flags;
964 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
965 if (r->monitor_name) {
966 uint32_t _relative_save_offset;
967 _relative_save_offset = ndr->offset;
968 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->monitor_name));
969 _mem_save_monitor_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
970 NDR_PULL_SET_MEM_CTX(ndr, r->monitor_name, 0);
971 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->monitor_name));
972 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_monitor_name_0, 0);
973 ndr->offset = _relative_save_offset;
975 ndr->flags = _flags_save_string;
978 uint32_t _flags_save_string = ndr->flags;
979 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
980 if (r->default_datatype) {
981 uint32_t _relative_save_offset;
982 _relative_save_offset = ndr->offset;
983 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->default_datatype));
984 _mem_save_default_datatype_0 = NDR_PULL_GET_MEM_CTX(ndr);
985 NDR_PULL_SET_MEM_CTX(ndr, r->default_datatype, 0);
986 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->default_datatype));
987 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_default_datatype_0, 0);
988 ndr->offset = _relative_save_offset;
990 ndr->flags = _flags_save_string;
993 uint32_t _flags_save_string_array = ndr->flags;
994 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
995 if (r->previous_names) {
996 uint32_t _relative_save_offset;
997 _relative_save_offset = ndr->offset;
998 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->previous_names));
999 _mem_save_previous_names_0 = NDR_PULL_GET_MEM_CTX(ndr);
1000 NDR_PULL_SET_MEM_CTX(ndr, r->previous_names, 0);
1001 NDR_CHECK(ndr_pull_string_array(ndr, NDR_SCALARS, &r->previous_names));
1002 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_previous_names_0, 0);
1003 ndr->offset = _relative_save_offset;
1005 ndr->flags = _flags_save_string_array;
1008 uint32_t _flags_save_string = ndr->flags;
1009 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1010 if (r->manufacturer_name) {
1011 uint32_t _relative_save_offset;
1012 _relative_save_offset = ndr->offset;
1013 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->manufacturer_name));
1014 _mem_save_manufacturer_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
1015 NDR_PULL_SET_MEM_CTX(ndr, r->manufacturer_name, 0);
1016 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->manufacturer_name));
1017 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_manufacturer_name_0, 0);
1018 ndr->offset = _relative_save_offset;
1020 ndr->flags = _flags_save_string;
1023 uint32_t _flags_save_string = ndr->flags;
1024 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1025 if (r->manufacturer_url) {
1026 uint32_t _relative_save_offset;
1027 _relative_save_offset = ndr->offset;
1028 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->manufacturer_url));
1029 _mem_save_manufacturer_url_0 = NDR_PULL_GET_MEM_CTX(ndr);
1030 NDR_PULL_SET_MEM_CTX(ndr, r->manufacturer_url, 0);
1031 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->manufacturer_url));
1032 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_manufacturer_url_0, 0);
1033 ndr->offset = _relative_save_offset;
1035 ndr->flags = _flags_save_string;
1038 uint32_t _flags_save_string = ndr->flags;
1039 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1040 if (r->hardware_id) {
1041 uint32_t _relative_save_offset;
1042 _relative_save_offset = ndr->offset;
1043 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->hardware_id));
1044 _mem_save_hardware_id_0 = NDR_PULL_GET_MEM_CTX(ndr);
1045 NDR_PULL_SET_MEM_CTX(ndr, r->hardware_id, 0);
1046 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->hardware_id));
1047 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_hardware_id_0, 0);
1048 ndr->offset = _relative_save_offset;
1050 ndr->flags = _flags_save_string;
1053 uint32_t _flags_save_string = ndr->flags;
1054 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1056 uint32_t _relative_save_offset;
1057 _relative_save_offset = ndr->offset;
1058 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->provider));
1059 _mem_save_provider_0 = NDR_PULL_GET_MEM_CTX(ndr);
1060 NDR_PULL_SET_MEM_CTX(ndr, r->provider, 0);
1061 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->provider));
1062 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_provider_0, 0);
1063 ndr->offset = _relative_save_offset;
1065 ndr->flags = _flags_save_string;
1068 NDR_CHECK(ndr_check_array_size(ndr, (void*)&r->file_info, r->file_count));
1071 return NDR_ERR_SUCCESS;