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_EnumPrinterDataEx
444 enum ndr_err_code ndr_push_spoolss_EnumPrinterDataEx(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrinterDataEx *r)
446 struct _spoolss_EnumPrinterDataEx _r;
447 if (flags & NDR_IN) {
448 _r.in.handle = r->in.handle;
449 _r.in.key_name = r->in.key_name;
450 _r.in.offered = r->in.offered;
451 NDR_CHECK(ndr_push__spoolss_EnumPrinterDataEx(ndr, flags, &_r));
453 if (flags & NDR_OUT) {
454 struct ndr_push *_ndr_info;
455 _r.in.handle = r->in.handle;
456 _r.in.key_name = r->in.key_name;
457 _r.in.offered = r->in.offered;
458 _r.out.count = r->out.count;
459 _r.out.needed = r->out.needed;
460 _r.out.result = r->out.result;
461 if (r->in.offered >= *r->out.needed) {
462 struct __spoolss_EnumPrinterDataEx __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.count = *r->out.count;
467 __r.out.info = *r->out.info;
468 NDR_CHECK(ndr_push___spoolss_EnumPrinterDataEx(_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.info = ndr_push_blob(_ndr_info);
475 NDR_CHECK(ndr_push__spoolss_EnumPrinterDataEx(ndr, flags, &_r));
477 return NDR_ERR_SUCCESS;
480 enum ndr_err_code ndr_pull_spoolss_EnumPrinterDataEx(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrinterDataEx *r)
482 struct _spoolss_EnumPrinterDataEx _r;
483 if (flags & NDR_IN) {
484 _r.in.handle = r->in.handle;
485 _r.in.key_name = r->in.key_name;
487 NDR_CHECK(ndr_pull__spoolss_EnumPrinterDataEx(ndr, flags, &_r));
488 r->in.handle = _r.in.handle;
489 r->in.key_name = _r.in.key_name;
490 r->in.offered = _r.in.offered;
491 r->out.needed = _r.out.needed;
492 r->out.count = _r.out.count;
493 NDR_PULL_ALLOC(ndr, r->out.info);
494 ZERO_STRUCTP(r->out.info);
496 if (flags & NDR_OUT) {
497 _r.in.handle = r->in.handle;
498 _r.in.key_name = r->in.key_name;
499 _r.in.offered = r->in.offered;
500 _r.out.count = r->out.count;
501 _r.out.needed = r->out.needed;
502 NDR_CHECK(ndr_pull__spoolss_EnumPrinterDataEx(ndr, flags, &_r));
503 if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
504 NDR_PULL_ALLOC(ndr, r->out.info);
507 r->out.needed = _r.out.needed;
508 r->out.count = _r.out.count;
509 r->out.result = _r.out.result;
510 if (_r.out.info.length) {
511 struct ndr_pull *_ndr_info;
512 NDR_PULL_ALLOC(ndr, *r->out.info);
513 _ndr_info = ndr_pull_init_blob(&_r.out.info, *r->out.info, ndr->iconv_convenience);
514 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);
515 _ndr_info->flags= ndr->flags;
516 if (r->in.offered != _ndr_info->data_size) {
517 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,
518 "SPOOLSS Buffer: offered[%u] doesn't match length of buffer[%u]",
519 (unsigned)r->in.offered, (unsigned)_ndr_info->data_size);
521 if (*r->out.needed <= _ndr_info->data_size) {
522 struct __spoolss_EnumPrinterDataEx __r;
523 __r.in.count = *r->out.count;
525 NDR_CHECK(ndr_pull___spoolss_EnumPrinterDataEx(_ndr_info, flags, &__r));
526 *r->out.info = __r.out.info;
530 return NDR_ERR_SUCCESS;
534 spoolss_GetPrinterData
536 enum ndr_err_code ndr_push_spoolss_GetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_GetPrinterData *r)
538 struct _spoolss_GetPrinterData _r;
539 if (flags & NDR_IN) {
540 _r.in.handle = r->in.handle;
541 _r.in.value_name= r->in.value_name;
542 _r.in.offered = r->in.offered;
543 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
545 if (flags & NDR_OUT) {
546 struct ndr_push *_ndr_info;
547 DATA_BLOB blob = data_blob(NULL, 0);
548 _r.in.handle = r->in.handle;
549 _r.in.value_name= r->in.value_name;
550 _r.in.offered = r->in.offered;
551 _r.out.type = r->out.type;
553 _r.out.needed = r->out.needed;
554 _r.out.result = r->out.result;
556 struct __spoolss_GetPrinterData __r;
558 _ndr_info = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
559 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);
560 _ndr_info->flags= ndr->flags;
561 __r.in.type = *r->out.type;
562 __r.out.data = r->out.data;
563 NDR_CHECK(ndr_push___spoolss_GetPrinterData(_ndr_info, flags, &__r));
564 if (r->in.offered > _ndr_info->offset) {
565 uint32_t _padding_len = r->in.offered - _ndr_info->offset;
566 NDR_CHECK(ndr_push_zero(_ndr_info, _padding_len));
568 _blob = ndr_push_blob(_ndr_info);
569 _r.out.data = &_blob;
571 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
573 return NDR_ERR_SUCCESS;
576 enum ndr_err_code ndr_pull_spoolss_GetPrinterData(struct ndr_pull *ndr, int flags, struct spoolss_GetPrinterData *r)
578 struct _spoolss_GetPrinterData _r;
579 if (flags & NDR_IN) {
580 DATA_BLOB blob = data_blob(NULL,0);
583 _r.in.handle = r->in.handle;
584 _r.in.value_name= r->in.value_name;
585 _r.in.offered = r->in.offered;
586 _r.out.type = r->out.type;
588 _r.out.needed = r->out.needed;
589 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
590 r->in.handle = _r.in.handle;
591 r->in.value_name= _r.in.value_name;
592 r->in.offered = _r.in.offered;
593 r->out.needed = _r.out.needed;
595 if (flags & NDR_OUT) {
596 DATA_BLOB blob = data_blob_talloc(ndr,NULL,0);
597 _r.in.handle = r->in.handle;
598 _r.in.value_name= r->in.value_name;
599 _r.in.offered = r->in.offered;
600 _r.out.type = r->out.type;
602 _r.out.needed = r->out.needed;
603 _r.out.result = r->out.result;
604 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
605 r->out.type = _r.out.type;
606 if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
607 NDR_PULL_ALLOC(ndr, r->out.data);
609 ZERO_STRUCTP(r->out.data);
610 r->out.needed = _r.out.needed;
611 r->out.result = _r.out.result;
612 if (_r.out.data && _r.out.data->length != r->in.offered) {
613 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,
614 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of out buffer[%u]",
615 (unsigned)r->in.offered, (unsigned)_r.out.data->length);
617 if (_r.out.data && _r.out.data->length > 0 && *r->out.needed <= _r.out.data->length) {
618 struct __spoolss_GetPrinterData __r;
619 struct ndr_pull *_ndr_data = ndr_pull_init_blob(_r.out.data, ndr, ndr->iconv_convenience);
620 NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
621 _ndr_data->flags= ndr->flags;
622 __r.in.type = *r->out.type;
623 __r.out.data = r->out.data;
624 NDR_CHECK(ndr_pull___spoolss_GetPrinterData(_ndr_data, flags, &__r));
625 r->out.data = __r.out.data;
627 *r->out.type = REG_NONE;
630 return NDR_ERR_SUCCESS;
634 spoolss_SetPrinterData
636 enum ndr_err_code ndr_push_spoolss_SetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_SetPrinterData *r)
638 struct _spoolss_SetPrinterData _r;
639 if (flags & NDR_IN) {
640 struct ndr_push *_ndr_data;
641 struct __spoolss_SetPrinterData __r;
642 DATA_BLOB _data_blob_data;
644 _ndr_data = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
645 NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
646 _ndr_data->flags= ndr->flags;
648 __r.in.type = r->in.type;
649 __r.out.data = discard_const_p(union spoolss_PrinterData, &r->in.data);
650 NDR_CHECK(ndr_push___spoolss_SetPrinterData(_ndr_data, NDR_OUT, &__r));
651 _data_blob_data = ndr_push_blob(_ndr_data);
653 _r.in.handle = r->in.handle;
654 _r.in.value_name= r->in.value_name;
655 _r.in.type = r->in.type;
656 _r.in.data = _data_blob_data;
657 _r.in._offered = _data_blob_data.length;
658 _r.out.result = r->out.result;
659 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
661 if (flags & NDR_OUT) {
662 _r.in.handle = r->in.handle;
663 _r.in.value_name= r->in.value_name;
664 _r.in.type = r->in.type;
665 _r.in.data = data_blob(NULL,0),
666 _r.in._offered = r->in._offered;
667 _r.out.result = r->out.result;
668 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
670 return NDR_ERR_SUCCESS;
673 uint32_t _ndr_size_spoolss_DeviceMode(struct spoolss_DeviceMode *devmode, struct smb_iconv_convenience *ic, uint32_t flags)
675 if (!devmode) return 0;
676 return ndr_size_spoolss_DeviceMode(devmode,ic,flags);
679 _PUBLIC_ size_t ndr_size_spoolss_StringArray(const struct spoolss_StringArray *r, struct smb_iconv_convenience *ic, int flags)
685 return ndr_size_struct(r, flags, (ndr_push_flags_fn_t)ndr_push_spoolss_StringArray, ic);
688 /* hand marshall as pidl cannot (yet) generate a relative pointer to a fixed array of
691 _PUBLIC_ enum ndr_err_code ndr_push_spoolss_DriverInfo101(struct ndr_push *ndr, int ndr_flags, const struct spoolss_DriverInfo101 *r)
693 uint32_t cntr_file_info_1;
694 if (ndr_flags & NDR_SCALARS) {
695 NDR_CHECK(ndr_push_align(ndr, 8));
696 NDR_CHECK(ndr_push_spoolss_DriverOSVersion(ndr, NDR_SCALARS, r->version));
698 uint32_t _flags_save_string = ndr->flags;
699 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
700 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->driver_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 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->architecture));
707 ndr->flags = _flags_save_string;
709 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->file_info));
710 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
712 uint32_t _flags_save_string = ndr->flags;
713 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
714 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->monitor_name));
715 ndr->flags = _flags_save_string;
718 uint32_t _flags_save_string = ndr->flags;
719 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
720 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->default_datatype));
721 ndr->flags = _flags_save_string;
724 uint32_t _flags_save_string_array = ndr->flags;
725 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
726 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->previous_names));
727 ndr->flags = _flags_save_string_array;
729 NDR_CHECK(ndr_push_NTTIME(ndr, NDR_SCALARS, r->driver_date));
730 NDR_CHECK(ndr_push_hyper(ndr, NDR_SCALARS, r->driver_version));
732 uint32_t _flags_save_string = ndr->flags;
733 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
734 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->manufacturer_name));
735 ndr->flags = _flags_save_string;
738 uint32_t _flags_save_string = ndr->flags;
739 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
740 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->manufacturer_url));
741 ndr->flags = _flags_save_string;
744 uint32_t _flags_save_string = ndr->flags;
745 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
746 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->hardware_id));
747 ndr->flags = _flags_save_string;
750 uint32_t _flags_save_string = ndr->flags;
751 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
752 NDR_CHECK(ndr_push_relative_ptr1(ndr, r->provider));
753 ndr->flags = _flags_save_string;
756 if (ndr_flags & NDR_BUFFERS) {
758 uint32_t _flags_save_string = ndr->flags;
759 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
760 if (r->driver_name) {
761 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->driver_name));
762 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->driver_name));
764 ndr->flags = _flags_save_string;
767 uint32_t _flags_save_string = ndr->flags;
768 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
769 if (r->architecture) {
770 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->architecture));
771 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->architecture));
773 ndr->flags = _flags_save_string;
776 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->file_info));
778 NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, r->file_count));
780 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
781 NDR_CHECK(ndr_push_spoolss_DriverFileInfo(ndr, NDR_SCALARS, &r->file_info[cntr_file_info_1]));
783 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
784 NDR_CHECK(ndr_push_spoolss_DriverFileInfo(ndr, NDR_BUFFERS, &r->file_info[cntr_file_info_1]));
788 uint32_t _flags_save_string = ndr->flags;
789 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
790 if (r->monitor_name) {
791 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->monitor_name));
792 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->monitor_name));
794 ndr->flags = _flags_save_string;
797 uint32_t _flags_save_string = ndr->flags;
798 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
799 if (r->default_datatype) {
800 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->default_datatype));
801 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->default_datatype));
803 ndr->flags = _flags_save_string;
806 uint32_t _flags_save_string_array = ndr->flags;
807 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
808 if (r->previous_names) {
809 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->previous_names));
810 NDR_CHECK(ndr_push_string_array(ndr, NDR_SCALARS, r->previous_names));
812 ndr->flags = _flags_save_string_array;
815 uint32_t _flags_save_string = ndr->flags;
816 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
817 if (r->manufacturer_name) {
818 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->manufacturer_name));
819 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->manufacturer_name));
821 ndr->flags = _flags_save_string;
824 uint32_t _flags_save_string = ndr->flags;
825 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
826 if (r->manufacturer_url) {
827 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->manufacturer_url));
828 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->manufacturer_url));
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 if (r->hardware_id) {
836 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->hardware_id));
837 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->hardware_id));
839 ndr->flags = _flags_save_string;
842 uint32_t _flags_save_string = ndr->flags;
843 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
845 NDR_CHECK(ndr_push_relative_ptr2(ndr, r->provider));
846 NDR_CHECK(ndr_push_string(ndr, NDR_SCALARS, r->provider));
848 ndr->flags = _flags_save_string;
851 return NDR_ERR_SUCCESS;
854 _PUBLIC_ enum ndr_err_code ndr_pull_spoolss_DriverInfo101(struct ndr_pull *ndr, int ndr_flags, struct spoolss_DriverInfo101 *r)
856 uint32_t _ptr_driver_name;
857 TALLOC_CTX *_mem_save_driver_name_0;
858 uint32_t _ptr_architecture;
859 TALLOC_CTX *_mem_save_architecture_0;
860 uint32_t _ptr_file_info;
861 uint32_t cntr_file_info_1;
862 TALLOC_CTX *_mem_save_file_info_0;
863 TALLOC_CTX *_mem_save_file_info_1;
864 uint32_t _ptr_monitor_name;
865 TALLOC_CTX *_mem_save_monitor_name_0;
866 uint32_t _ptr_default_datatype;
867 TALLOC_CTX *_mem_save_default_datatype_0;
868 uint32_t _ptr_previous_names;
869 TALLOC_CTX *_mem_save_previous_names_0;
870 uint32_t _ptr_manufacturer_name;
871 TALLOC_CTX *_mem_save_manufacturer_name_0;
872 uint32_t _ptr_manufacturer_url;
873 TALLOC_CTX *_mem_save_manufacturer_url_0;
874 uint32_t _ptr_hardware_id;
875 TALLOC_CTX *_mem_save_hardware_id_0;
876 uint32_t _ptr_provider;
877 TALLOC_CTX *_mem_save_provider_0;
878 if (ndr_flags & NDR_SCALARS) {
879 NDR_CHECK(ndr_pull_align(ndr, 8));
880 NDR_CHECK(ndr_pull_spoolss_DriverOSVersion(ndr, NDR_SCALARS, &r->version));
882 uint32_t _flags_save_string = ndr->flags;
883 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
884 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_driver_name));
885 if (_ptr_driver_name) {
886 NDR_PULL_ALLOC(ndr, r->driver_name);
887 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->driver_name, _ptr_driver_name));
889 r->driver_name = NULL;
891 ndr->flags = _flags_save_string;
894 uint32_t _flags_save_string = ndr->flags;
895 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
896 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_architecture));
897 if (_ptr_architecture) {
898 NDR_PULL_ALLOC(ndr, r->architecture);
899 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->architecture, _ptr_architecture));
901 r->architecture = NULL;
903 ndr->flags = _flags_save_string;
905 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_file_info));
906 if (_ptr_file_info) {
907 NDR_PULL_ALLOC(ndr, r->file_info);
908 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->file_info, _ptr_file_info));
912 NDR_CHECK(ndr_pull_uint32(ndr, NDR_SCALARS, &r->file_count));
914 uint32_t _flags_save_string = ndr->flags;
915 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
916 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_monitor_name));
917 if (_ptr_monitor_name) {
918 NDR_PULL_ALLOC(ndr, r->monitor_name);
919 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->monitor_name, _ptr_monitor_name));
921 r->monitor_name = NULL;
923 ndr->flags = _flags_save_string;
926 uint32_t _flags_save_string = ndr->flags;
927 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
928 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_default_datatype));
929 if (_ptr_default_datatype) {
930 NDR_PULL_ALLOC(ndr, r->default_datatype);
931 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->default_datatype, _ptr_default_datatype));
933 r->default_datatype = NULL;
935 ndr->flags = _flags_save_string;
938 uint32_t _flags_save_string_array = ndr->flags;
939 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
940 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_previous_names));
941 if (_ptr_previous_names) {
942 NDR_PULL_ALLOC(ndr, r->previous_names);
943 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->previous_names, _ptr_previous_names));
945 r->previous_names = NULL;
947 ndr->flags = _flags_save_string_array;
949 NDR_CHECK(ndr_pull_NTTIME(ndr, NDR_SCALARS, &r->driver_date));
950 NDR_CHECK(ndr_pull_hyper(ndr, NDR_SCALARS, &r->driver_version));
952 uint32_t _flags_save_string = ndr->flags;
953 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
954 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_manufacturer_name));
955 if (_ptr_manufacturer_name) {
956 NDR_PULL_ALLOC(ndr, r->manufacturer_name);
957 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->manufacturer_name, _ptr_manufacturer_name));
959 r->manufacturer_name = NULL;
961 ndr->flags = _flags_save_string;
964 uint32_t _flags_save_string = ndr->flags;
965 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
966 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_manufacturer_url));
967 if (_ptr_manufacturer_url) {
968 NDR_PULL_ALLOC(ndr, r->manufacturer_url);
969 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->manufacturer_url, _ptr_manufacturer_url));
971 r->manufacturer_url = NULL;
973 ndr->flags = _flags_save_string;
976 uint32_t _flags_save_string = ndr->flags;
977 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
978 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_hardware_id));
979 if (_ptr_hardware_id) {
980 NDR_PULL_ALLOC(ndr, r->hardware_id);
981 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->hardware_id, _ptr_hardware_id));
983 r->hardware_id = NULL;
985 ndr->flags = _flags_save_string;
988 uint32_t _flags_save_string = ndr->flags;
989 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
990 NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_provider));
992 NDR_PULL_ALLOC(ndr, r->provider);
993 NDR_CHECK(ndr_pull_relative_ptr1(ndr, r->provider, _ptr_provider));
997 ndr->flags = _flags_save_string;
1000 if (ndr_flags & NDR_BUFFERS) {
1002 uint32_t _flags_save_string = ndr->flags;
1003 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1004 if (r->driver_name) {
1005 uint32_t _relative_save_offset;
1006 _relative_save_offset = ndr->offset;
1007 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->driver_name));
1008 _mem_save_driver_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
1009 NDR_PULL_SET_MEM_CTX(ndr, r->driver_name, 0);
1010 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->driver_name));
1011 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_driver_name_0, 0);
1012 ndr->offset = _relative_save_offset;
1014 ndr->flags = _flags_save_string;
1017 uint32_t _flags_save_string = ndr->flags;
1018 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1019 if (r->architecture) {
1020 uint32_t _relative_save_offset;
1021 _relative_save_offset = ndr->offset;
1022 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->architecture));
1023 _mem_save_architecture_0 = NDR_PULL_GET_MEM_CTX(ndr);
1024 NDR_PULL_SET_MEM_CTX(ndr, r->architecture, 0);
1025 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->architecture));
1026 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_architecture_0, 0);
1027 ndr->offset = _relative_save_offset;
1029 ndr->flags = _flags_save_string;
1032 uint32_t _relative_save_offset;
1033 _relative_save_offset = ndr->offset;
1034 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->file_info));
1035 _mem_save_file_info_0 = NDR_PULL_GET_MEM_CTX(ndr);
1036 NDR_PULL_SET_MEM_CTX(ndr, r->file_info, 0);
1038 NDR_CHECK(ndr_pull_array_size(ndr, &r->file_info));
1040 NDR_CHECK(ndr_token_store(ndr, &ndr->array_size_list, &r->file_info, r->file_count));
1042 NDR_PULL_ALLOC_N(ndr, r->file_info, ndr_get_array_size(ndr, &r->file_info));
1043 _mem_save_file_info_1 = NDR_PULL_GET_MEM_CTX(ndr);
1044 NDR_PULL_SET_MEM_CTX(ndr, r->file_info, 0);
1045 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
1046 NDR_CHECK(ndr_pull_spoolss_DriverFileInfo(ndr, NDR_SCALARS, &r->file_info[cntr_file_info_1]));
1048 for (cntr_file_info_1 = 0; cntr_file_info_1 < r->file_count; cntr_file_info_1++) {
1049 NDR_CHECK(ndr_pull_spoolss_DriverFileInfo(ndr, NDR_BUFFERS, &r->file_info[cntr_file_info_1]));
1051 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_file_info_1, 0);
1052 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_file_info_0, 0);
1053 ndr->offset = _relative_save_offset;
1056 uint32_t _flags_save_string = ndr->flags;
1057 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1058 if (r->monitor_name) {
1059 uint32_t _relative_save_offset;
1060 _relative_save_offset = ndr->offset;
1061 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->monitor_name));
1062 _mem_save_monitor_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
1063 NDR_PULL_SET_MEM_CTX(ndr, r->monitor_name, 0);
1064 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->monitor_name));
1065 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_monitor_name_0, 0);
1066 ndr->offset = _relative_save_offset;
1068 ndr->flags = _flags_save_string;
1071 uint32_t _flags_save_string = ndr->flags;
1072 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1073 if (r->default_datatype) {
1074 uint32_t _relative_save_offset;
1075 _relative_save_offset = ndr->offset;
1076 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->default_datatype));
1077 _mem_save_default_datatype_0 = NDR_PULL_GET_MEM_CTX(ndr);
1078 NDR_PULL_SET_MEM_CTX(ndr, r->default_datatype, 0);
1079 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->default_datatype));
1080 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_default_datatype_0, 0);
1081 ndr->offset = _relative_save_offset;
1083 ndr->flags = _flags_save_string;
1086 uint32_t _flags_save_string_array = ndr->flags;
1087 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1088 if (r->previous_names) {
1089 uint32_t _relative_save_offset;
1090 _relative_save_offset = ndr->offset;
1091 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->previous_names));
1092 _mem_save_previous_names_0 = NDR_PULL_GET_MEM_CTX(ndr);
1093 NDR_PULL_SET_MEM_CTX(ndr, r->previous_names, 0);
1094 NDR_CHECK(ndr_pull_string_array(ndr, NDR_SCALARS, &r->previous_names));
1095 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_previous_names_0, 0);
1096 ndr->offset = _relative_save_offset;
1098 ndr->flags = _flags_save_string_array;
1101 uint32_t _flags_save_string = ndr->flags;
1102 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1103 if (r->manufacturer_name) {
1104 uint32_t _relative_save_offset;
1105 _relative_save_offset = ndr->offset;
1106 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->manufacturer_name));
1107 _mem_save_manufacturer_name_0 = NDR_PULL_GET_MEM_CTX(ndr);
1108 NDR_PULL_SET_MEM_CTX(ndr, r->manufacturer_name, 0);
1109 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->manufacturer_name));
1110 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_manufacturer_name_0, 0);
1111 ndr->offset = _relative_save_offset;
1113 ndr->flags = _flags_save_string;
1116 uint32_t _flags_save_string = ndr->flags;
1117 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1118 if (r->manufacturer_url) {
1119 uint32_t _relative_save_offset;
1120 _relative_save_offset = ndr->offset;
1121 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->manufacturer_url));
1122 _mem_save_manufacturer_url_0 = NDR_PULL_GET_MEM_CTX(ndr);
1123 NDR_PULL_SET_MEM_CTX(ndr, r->manufacturer_url, 0);
1124 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->manufacturer_url));
1125 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_manufacturer_url_0, 0);
1126 ndr->offset = _relative_save_offset;
1128 ndr->flags = _flags_save_string;
1131 uint32_t _flags_save_string = ndr->flags;
1132 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1133 if (r->hardware_id) {
1134 uint32_t _relative_save_offset;
1135 _relative_save_offset = ndr->offset;
1136 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->hardware_id));
1137 _mem_save_hardware_id_0 = NDR_PULL_GET_MEM_CTX(ndr);
1138 NDR_PULL_SET_MEM_CTX(ndr, r->hardware_id, 0);
1139 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->hardware_id));
1140 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_hardware_id_0, 0);
1141 ndr->offset = _relative_save_offset;
1143 ndr->flags = _flags_save_string;
1146 uint32_t _flags_save_string = ndr->flags;
1147 ndr_set_flags(&ndr->flags, LIBNDR_FLAG_STR_NULLTERM);
1149 uint32_t _relative_save_offset;
1150 _relative_save_offset = ndr->offset;
1151 NDR_CHECK(ndr_pull_relative_ptr2(ndr, r->provider));
1152 _mem_save_provider_0 = NDR_PULL_GET_MEM_CTX(ndr);
1153 NDR_PULL_SET_MEM_CTX(ndr, r->provider, 0);
1154 NDR_CHECK(ndr_pull_string(ndr, NDR_SCALARS, &r->provider));
1155 NDR_PULL_SET_MEM_CTX(ndr, _mem_save_provider_0, 0);
1156 ndr->offset = _relative_save_offset;
1158 ndr->flags = _flags_save_string;
1161 NDR_CHECK(ndr_check_array_size(ndr, (void*)&r->file_info, r->file_count));
1164 return NDR_ERR_SUCCESS;