The branch, v3-2-test has been updated
       via  4128ed8bdfb82324e80c0e5a4114da464d50f6de (commit)
      from  4f125110cfe25b499eb628b5b08fdb610a5d972c (commit)

http://gitweb.samba.org/?p=samba.git;a=shortlog;h=v3-2-test


- Log -----------------------------------------------------------------
commit 4128ed8bdfb82324e80c0e5a4114da464d50f6de
Author: Günther Deschner <[EMAIL PROTECTED]>
Date:   Thu Feb 7 09:43:46 2008 +0100

    Re-run make idl after metzes fixes for multilevel and embedded pointers.
    
    Thanks metze! Now we can move a lot more opcodes to use pidl generated
    marshalling.
    
    Guenther

-----------------------------------------------------------------------

Summary of changes:
 source/librpc/gen_ndr/ndr_dfs.c      |   87 +++++++----
 source/librpc/gen_ndr/ndr_echo.c     |  100 +++++++-----
 source/librpc/gen_ndr/ndr_lsa.c      |  108 ++++++++-----
 source/librpc/gen_ndr/ndr_netlogon.c |  294 +++++++++++++++++++++-------------
 source/librpc/gen_ndr/ndr_samr.c     |  147 ++++++++++-------
 source/librpc/gen_ndr/ndr_svcctl.c   |  264 +++++++++++++++++++-----------
 source/librpc/gen_ndr/ndr_wkssvc.c   |  257 +++++++++++++++++++++--------
 7 files changed, 799 insertions(+), 458 deletions(-)


Changeset truncated at 500 lines:

diff --git a/source/librpc/gen_ndr/ndr_dfs.c b/source/librpc/gen_ndr/ndr_dfs.c
index dee3248..c373a43 100644
--- a/source/librpc/gen_ndr/ndr_dfs.c
+++ b/source/librpc/gen_ndr/ndr_dfs.c
@@ -4974,14 +4974,13 @@ static enum ndr_err_code 
ndr_push_dfs_GetDcAddress(struct ndr_push *ndr, int fla
                if (r->in.server_fullname == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->in.server_fullname == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->in.server_fullname));
+               if (*r->in.server_fullname) {
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->in.server_fullname, CH_UTF16)));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->in.server_fullname, CH_UTF16)));
+                       NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, 
*r->in.server_fullname, ndr_charset_length(*r->in.server_fullname, CH_UTF16), 
sizeof(uint16_t), CH_UTF16));
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->in.server_fullname, CH_UTF16)));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->in.server_fullname, CH_UTF16)));
-               NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, 
*r->in.server_fullname, ndr_charset_length(*r->in.server_fullname, CH_UTF16), 
sizeof(uint16_t), CH_UTF16));
                if (r->in.is_root == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
@@ -4995,14 +4994,13 @@ static enum ndr_err_code 
ndr_push_dfs_GetDcAddress(struct ndr_push *ndr, int fla
                if (r->out.server_fullname == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->out.server_fullname == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->out.server_fullname));
+               if (*r->out.server_fullname) {
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.server_fullname, CH_UTF16)));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.server_fullname, CH_UTF16)));
+                       NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, 
*r->out.server_fullname, ndr_charset_length(*r->out.server_fullname, CH_UTF16), 
sizeof(uint16_t), CH_UTF16));
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.server_fullname, CH_UTF16)));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.server_fullname, CH_UTF16)));
-               NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, 
*r->out.server_fullname, ndr_charset_length(*r->out.server_fullname, CH_UTF16), 
sizeof(uint16_t), CH_UTF16));
                if (r->out.is_root == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
@@ -5020,6 +5018,7 @@ static enum ndr_err_code ndr_pull_dfs_GetDcAddress(struct 
ndr_pull *ndr, int fla
 {
        uint32_t _ptr_server_fullname;
        TALLOC_CTX *_mem_save_server_fullname_0;
+       TALLOC_CTX *_mem_save_server_fullname_1;
        TALLOC_CTX *_mem_save_is_root_0;
        TALLOC_CTX *_mem_save_ttl_0;
        if (flags & NDR_IN) {
@@ -5037,14 +5036,24 @@ static enum ndr_err_code 
ndr_pull_dfs_GetDcAddress(struct ndr_pull *ndr, int fla
                }
                _mem_save_server_fullname_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->in.server_fullname, 
LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_server_fullname));
-               NDR_CHECK(ndr_pull_array_size(ndr, r->in.server_fullname));
-               NDR_CHECK(ndr_pull_array_length(ndr, r->in.server_fullname));
-               if (ndr_get_array_length(ndr, r->in.server_fullname) > 
ndr_get_array_size(ndr, r->in.server_fullname)) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad 
array size %u should exceed array length %u", ndr_get_array_size(ndr, 
r->in.server_fullname), ndr_get_array_length(ndr, r->in.server_fullname));
-               }
-               NDR_CHECK(ndr_check_string_terminator(ndr, 
ndr_get_array_length(ndr, r->in.server_fullname), sizeof(uint16_t)));
-               NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, 
r->in.server_fullname, ndr_get_array_length(ndr, r->in.server_fullname), 
sizeof(uint16_t), CH_UTF16));
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_server_fullname));
+               if (_ptr_server_fullname) {
+                       NDR_PULL_ALLOC(ndr, *r->in.server_fullname);
+               } else {
+                       *r->in.server_fullname = NULL;
+               }
+               if (*r->in.server_fullname) {
+                       _mem_save_server_fullname_1 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->in.server_fullname, 0);
+                       NDR_CHECK(ndr_pull_array_size(ndr, 
r->in.server_fullname));
+                       NDR_CHECK(ndr_pull_array_length(ndr, 
r->in.server_fullname));
+                       if (ndr_get_array_length(ndr, r->in.server_fullname) > 
ndr_get_array_size(ndr, r->in.server_fullname)) {
+                               return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, 
"Bad array size %u should exceed array length %u", ndr_get_array_size(ndr, 
r->in.server_fullname), ndr_get_array_length(ndr, r->in.server_fullname));
+                       }
+                       NDR_CHECK(ndr_check_string_terminator(ndr, 
ndr_get_array_length(ndr, r->in.server_fullname), sizeof(uint16_t)));
+                       NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, 
r->in.server_fullname, ndr_get_array_length(ndr, r->in.server_fullname), 
sizeof(uint16_t), CH_UTF16));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_server_fullname_1, 
0);
+               }
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_server_fullname_0, 
LIBNDR_FLAG_REF_ALLOC);
                if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
                        NDR_PULL_ALLOC(ndr, r->in.is_root);
@@ -5073,14 +5082,24 @@ static enum ndr_err_code 
ndr_pull_dfs_GetDcAddress(struct ndr_pull *ndr, int fla
                }
                _mem_save_server_fullname_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->out.server_fullname, 
LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_server_fullname));
-               NDR_CHECK(ndr_pull_array_size(ndr, r->out.server_fullname));
-               NDR_CHECK(ndr_pull_array_length(ndr, r->out.server_fullname));
-               if (ndr_get_array_length(ndr, r->out.server_fullname) > 
ndr_get_array_size(ndr, r->out.server_fullname)) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad 
array size %u should exceed array length %u", ndr_get_array_size(ndr, 
r->out.server_fullname), ndr_get_array_length(ndr, r->out.server_fullname));
-               }
-               NDR_CHECK(ndr_check_string_terminator(ndr, 
ndr_get_array_length(ndr, r->out.server_fullname), sizeof(uint16_t)));
-               NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, 
r->out.server_fullname, ndr_get_array_length(ndr, r->out.server_fullname), 
sizeof(uint16_t), CH_UTF16));
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_server_fullname));
+               if (_ptr_server_fullname) {
+                       NDR_PULL_ALLOC(ndr, *r->out.server_fullname);
+               } else {
+                       *r->out.server_fullname = NULL;
+               }
+               if (*r->out.server_fullname) {
+                       _mem_save_server_fullname_1 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->out.server_fullname, 0);
+                       NDR_CHECK(ndr_pull_array_size(ndr, 
r->out.server_fullname));
+                       NDR_CHECK(ndr_pull_array_length(ndr, 
r->out.server_fullname));
+                       if (ndr_get_array_length(ndr, r->out.server_fullname) > 
ndr_get_array_size(ndr, r->out.server_fullname)) {
+                               return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, 
"Bad array size %u should exceed array length %u", ndr_get_array_size(ndr, 
r->out.server_fullname), ndr_get_array_length(ndr, r->out.server_fullname));
+                       }
+                       NDR_CHECK(ndr_check_string_terminator(ndr, 
ndr_get_array_length(ndr, r->out.server_fullname), sizeof(uint16_t)));
+                       NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, 
r->out.server_fullname, ndr_get_array_length(ndr, r->out.server_fullname), 
sizeof(uint16_t), CH_UTF16));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_server_fullname_1, 
0);
+               }
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_server_fullname_0, 
LIBNDR_FLAG_REF_ALLOC);
                if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
                        NDR_PULL_ALLOC(ndr, r->out.is_root);
@@ -5116,7 +5135,9 @@ _PUBLIC_ void ndr_print_dfs_GetDcAddress(struct ndr_print 
*ndr, const char *name
                ndr->depth++;
                ndr_print_ptr(ndr, "server_fullname", *r->in.server_fullname);
                ndr->depth++;
-               ndr_print_string(ndr, "server_fullname", 
*r->in.server_fullname);
+               if (*r->in.server_fullname) {
+                       ndr_print_string(ndr, "server_fullname", 
*r->in.server_fullname);
+               }
                ndr->depth--;
                ndr->depth--;
                ndr_print_ptr(ndr, "is_root", r->in.is_root);
@@ -5136,7 +5157,9 @@ _PUBLIC_ void ndr_print_dfs_GetDcAddress(struct ndr_print 
*ndr, const char *name
                ndr->depth++;
                ndr_print_ptr(ndr, "server_fullname", *r->out.server_fullname);
                ndr->depth++;
-               ndr_print_string(ndr, "server_fullname", 
*r->out.server_fullname);
+               if (*r->out.server_fullname) {
+                       ndr_print_string(ndr, "server_fullname", 
*r->out.server_fullname);
+               }
                ndr->depth--;
                ndr->depth--;
                ndr_print_ptr(ndr, "is_root", r->out.is_root);
diff --git a/source/librpc/gen_ndr/ndr_echo.c b/source/librpc/gen_ndr/ndr_echo.c
index 29a1022..dda9813 100644
--- a/source/librpc/gen_ndr/ndr_echo.c
+++ b/source/librpc/gen_ndr/ndr_echo.c
@@ -876,14 +876,13 @@ static enum ndr_err_code ndr_push_echo_TestCall(struct 
ndr_push *ndr, int flags,
                if (r->out.s2 == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->out.s2 == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->out.s2));
+               if (*r->out.s2) {
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.s2, CH_UTF16)));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
+                       NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.s2, CH_UTF16)));
+                       NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, 
*r->out.s2, ndr_charset_length(*r->out.s2, CH_UTF16), sizeof(uint16_t), 
CH_UTF16));
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.s2, CH_UTF16)));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 0));
-               NDR_CHECK(ndr_push_uint32(ndr, NDR_SCALARS, 
ndr_charset_length(*r->out.s2, CH_UTF16)));
-               NDR_CHECK(ndr_push_charset(ndr, NDR_SCALARS, *r->out.s2, 
ndr_charset_length(*r->out.s2, CH_UTF16), sizeof(uint16_t), CH_UTF16));
        }
        return NDR_ERR_SUCCESS;
 }
@@ -892,6 +891,7 @@ static enum ndr_err_code ndr_pull_echo_TestCall(struct 
ndr_pull *ndr, int flags,
 {
        uint32_t _ptr_s2;
        TALLOC_CTX *_mem_save_s2_0;
+       TALLOC_CTX *_mem_save_s2_1;
        if (flags & NDR_IN) {
                ZERO_STRUCT(r->out);
 
@@ -911,14 +911,24 @@ static enum ndr_err_code ndr_pull_echo_TestCall(struct 
ndr_pull *ndr, int flags,
                }
                _mem_save_s2_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->out.s2, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_s2));
-               NDR_CHECK(ndr_pull_array_size(ndr, r->out.s2));
-               NDR_CHECK(ndr_pull_array_length(ndr, r->out.s2));
-               if (ndr_get_array_length(ndr, r->out.s2) > 
ndr_get_array_size(ndr, r->out.s2)) {
-                       return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, "Bad 
array size %u should exceed array length %u", ndr_get_array_size(ndr, 
r->out.s2), ndr_get_array_length(ndr, r->out.s2));
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_s2));
+               if (_ptr_s2) {
+                       NDR_PULL_ALLOC(ndr, *r->out.s2);
+               } else {
+                       *r->out.s2 = NULL;
+               }
+               if (*r->out.s2) {
+                       _mem_save_s2_1 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->out.s2, 0);
+                       NDR_CHECK(ndr_pull_array_size(ndr, r->out.s2));
+                       NDR_CHECK(ndr_pull_array_length(ndr, r->out.s2));
+                       if (ndr_get_array_length(ndr, r->out.s2) > 
ndr_get_array_size(ndr, r->out.s2)) {
+                               return ndr_pull_error(ndr, NDR_ERR_ARRAY_SIZE, 
"Bad array size %u should exceed array length %u", ndr_get_array_size(ndr, 
r->out.s2), ndr_get_array_length(ndr, r->out.s2));
+                       }
+                       NDR_CHECK(ndr_check_string_terminator(ndr, 
ndr_get_array_length(ndr, r->out.s2), sizeof(uint16_t)));
+                       NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, r->out.s2, 
ndr_get_array_length(ndr, r->out.s2), sizeof(uint16_t), CH_UTF16));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_s2_1, 0);
                }
-               NDR_CHECK(ndr_check_string_terminator(ndr, 
ndr_get_array_length(ndr, r->out.s2), sizeof(uint16_t)));
-               NDR_CHECK(ndr_pull_charset(ndr, NDR_SCALARS, r->out.s2, 
ndr_get_array_length(ndr, r->out.s2), sizeof(uint16_t), CH_UTF16));
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_s2_0, 
LIBNDR_FLAG_REF_ALLOC);
        }
        return NDR_ERR_SUCCESS;
@@ -947,7 +957,9 @@ _PUBLIC_ void ndr_print_echo_TestCall(struct ndr_print 
*ndr, const char *name, i
                ndr->depth++;
                ndr_print_ptr(ndr, "s2", *r->out.s2);
                ndr->depth++;
-               ndr_print_string(ndr, "s2", *r->out.s2);
+               if (*r->out.s2) {
+                       ndr_print_string(ndr, "s2", *r->out.s2);
+               }
                ndr->depth--;
                ndr->depth--;
                ndr->depth--;
@@ -1290,15 +1302,13 @@ static enum ndr_err_code 
ndr_push_echo_TestDoublePointer(struct ndr_push *ndr, i
                if (r->in.data == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->in.data == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
-               }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               if (**r->in.data == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->in.data));
+               if (*r->in.data) {
+                       NDR_CHECK(ndr_push_unique_ptr(ndr, **r->in.data));
+                       if (**r->in.data) {
+                               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, 
***r->in.data));
+                       }
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, ***r->in.data));
        }
        if (flags & NDR_OUT) {
                NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->out.result));
@@ -1318,21 +1328,29 @@ static enum ndr_err_code 
ndr_pull_echo_TestDoublePointer(struct ndr_pull *ndr, i
                }
                _mem_save_data_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->in.data, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_data));
-               if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_data));
+               if (_ptr_data) {
                        NDR_PULL_ALLOC(ndr, *r->in.data);
+               } else {
+                       *r->in.data = NULL;
                }
-               _mem_save_data_1 = NDR_PULL_GET_MEM_CTX(ndr);
-               NDR_PULL_SET_MEM_CTX(ndr, *r->in.data, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_data));
-               if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
-                       NDR_PULL_ALLOC(ndr, **r->in.data);
+               if (*r->in.data) {
+                       _mem_save_data_1 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->in.data, 0);
+                       NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_data));
+                       if (_ptr_data) {
+                               NDR_PULL_ALLOC(ndr, **r->in.data);
+                       } else {
+                               **r->in.data = NULL;
+                       }
+                       if (**r->in.data) {
+                               _mem_save_data_2 = NDR_PULL_GET_MEM_CTX(ndr);
+                               NDR_PULL_SET_MEM_CTX(ndr, **r->in.data, 0);
+                               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, 
**r->in.data));
+                               NDR_PULL_SET_MEM_CTX(ndr, _mem_save_data_2, 0);
+                       }
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_data_1, 0);
                }
-               _mem_save_data_2 = NDR_PULL_GET_MEM_CTX(ndr);
-               NDR_PULL_SET_MEM_CTX(ndr, **r->in.data, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, **r->in.data));
-               NDR_PULL_SET_MEM_CTX(ndr, _mem_save_data_2, 
LIBNDR_FLAG_REF_ALLOC);
-               NDR_PULL_SET_MEM_CTX(ndr, _mem_save_data_1, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_data_0, 
LIBNDR_FLAG_REF_ALLOC);
        }
        if (flags & NDR_OUT) {
@@ -1355,10 +1373,14 @@ _PUBLIC_ void ndr_print_echo_TestDoublePointer(struct 
ndr_print *ndr, const char
                ndr->depth++;
                ndr_print_ptr(ndr, "data", *r->in.data);
                ndr->depth++;
-               ndr_print_ptr(ndr, "data", **r->in.data);
-               ndr->depth++;
-               ndr_print_uint16(ndr, "data", ***r->in.data);
-               ndr->depth--;
+               if (*r->in.data) {
+                       ndr_print_ptr(ndr, "data", **r->in.data);
+                       ndr->depth++;
+                       if (**r->in.data) {
+                               ndr_print_uint16(ndr, "data", ***r->in.data);
+                       }
+                       ndr->depth--;
+               }
                ndr->depth--;
                ndr->depth--;
                ndr->depth--;
diff --git a/source/librpc/gen_ndr/ndr_lsa.c b/source/librpc/gen_ndr/ndr_lsa.c
index 89b7da5..e934ca8 100644
--- a/source/librpc/gen_ndr/ndr_lsa.c
+++ b/source/librpc/gen_ndr/ndr_lsa.c
@@ -4771,11 +4771,10 @@ static enum ndr_err_code 
ndr_push_lsa_QuerySecurity(struct ndr_push *ndr, int fl
                if (r->out.sdbuf == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->out.sdbuf == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->out.sdbuf));
+               if (*r->out.sdbuf) {
+                       NDR_CHECK(ndr_push_sec_desc_buf(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.sdbuf));
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_sec_desc_buf(ndr, NDR_SCALARS|NDR_BUFFERS, 
*r->out.sdbuf));
                NDR_CHECK(ndr_push_NTSTATUS(ndr, NDR_SCALARS, r->out.result));
        }
        return NDR_ERR_SUCCESS;
@@ -4807,14 +4806,18 @@ static enum ndr_err_code 
ndr_pull_lsa_QuerySecurity(struct ndr_pull *ndr, int fl
                }
                _mem_save_sdbuf_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->out.sdbuf, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_sdbuf));
-               if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_sdbuf));
+               if (_ptr_sdbuf) {
                        NDR_PULL_ALLOC(ndr, *r->out.sdbuf);
+               } else {
+                       *r->out.sdbuf = NULL;
+               }
+               if (*r->out.sdbuf) {
+                       _mem_save_sdbuf_1 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->out.sdbuf, 0);
+                       NDR_CHECK(ndr_pull_sec_desc_buf(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.sdbuf));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_sdbuf_1, 0);
                }
-               _mem_save_sdbuf_1 = NDR_PULL_GET_MEM_CTX(ndr);
-               NDR_PULL_SET_MEM_CTX(ndr, *r->out.sdbuf, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_sec_desc_buf(ndr, NDR_SCALARS|NDR_BUFFERS, 
*r->out.sdbuf));
-               NDR_PULL_SET_MEM_CTX(ndr, _mem_save_sdbuf_1, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_sdbuf_0, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_CHECK(ndr_pull_NTSTATUS(ndr, NDR_SCALARS, &r->out.result));
        }
@@ -4845,7 +4848,9 @@ _PUBLIC_ void ndr_print_lsa_QuerySecurity(struct 
ndr_print *ndr, const char *nam
                ndr->depth++;
                ndr_print_ptr(ndr, "sdbuf", *r->out.sdbuf);
                ndr->depth++;
-               ndr_print_sec_desc_buf(ndr, "sdbuf", *r->out.sdbuf);
+               if (*r->out.sdbuf) {
+                       ndr_print_sec_desc_buf(ndr, "sdbuf", *r->out.sdbuf);
+               }
                ndr->depth--;
                ndr->depth--;
                ndr_print_NTSTATUS(ndr, "result", r->out.result);
@@ -7640,21 +7645,19 @@ static enum ndr_err_code 
ndr_push_lsa_DeleteObject(struct ndr_push *ndr, int fla
                if (r->in.handle == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->in.handle == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->in.handle));
+               if (*r->in.handle) {
+                       NDR_CHECK(ndr_push_policy_handle(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->in.handle));
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_policy_handle(ndr, NDR_SCALARS|NDR_BUFFERS, 
*r->in.handle));
        }
        if (flags & NDR_OUT) {
                if (r->out.handle == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->out.handle == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->out.handle));
+               if (*r->out.handle) {
+                       NDR_CHECK(ndr_push_policy_handle(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.handle));
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_policy_handle(ndr, NDR_SCALARS|NDR_BUFFERS, 
*r->out.handle));
                NDR_CHECK(ndr_push_NTSTATUS(ndr, NDR_SCALARS, r->out.result));
        }
        return NDR_ERR_SUCCESS;
@@ -7673,14 +7676,18 @@ static enum ndr_err_code 
ndr_pull_lsa_DeleteObject(struct ndr_pull *ndr, int fla
                }
                _mem_save_handle_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->in.handle, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_handle));
-               if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_handle));
+               if (_ptr_handle) {
                        NDR_PULL_ALLOC(ndr, *r->in.handle);
+               } else {
+                       *r->in.handle = NULL;
+               }
+               if (*r->in.handle) {
+                       _mem_save_handle_1 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->in.handle, 0);
+                       NDR_CHECK(ndr_pull_policy_handle(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->in.handle));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_handle_1, 0);
                }
-               _mem_save_handle_1 = NDR_PULL_GET_MEM_CTX(ndr);
-               NDR_PULL_SET_MEM_CTX(ndr, *r->in.handle, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_policy_handle(ndr, NDR_SCALARS|NDR_BUFFERS, 
*r->in.handle));
-               NDR_PULL_SET_MEM_CTX(ndr, _mem_save_handle_1, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_handle_0, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_PULL_ALLOC(ndr, r->out.handle);
                *r->out.handle = *r->in.handle;
@@ -7691,14 +7698,18 @@ static enum ndr_err_code 
ndr_pull_lsa_DeleteObject(struct ndr_pull *ndr, int fla
                }
                _mem_save_handle_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->out.handle, LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_handle));
-               if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_handle));
+               if (_ptr_handle) {
                        NDR_PULL_ALLOC(ndr, *r->out.handle);
+               } else {
+                       *r->out.handle = NULL;
+               }
+               if (*r->out.handle) {
+                       _mem_save_handle_1 = NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->out.handle, 0);
+                       NDR_CHECK(ndr_pull_policy_handle(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.handle));
+                       NDR_PULL_SET_MEM_CTX(ndr, _mem_save_handle_1, 0);
                }
-               _mem_save_handle_1 = NDR_PULL_GET_MEM_CTX(ndr);
-               NDR_PULL_SET_MEM_CTX(ndr, *r->out.handle, 
LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_policy_handle(ndr, NDR_SCALARS|NDR_BUFFERS, 
*r->out.handle));
-               NDR_PULL_SET_MEM_CTX(ndr, _mem_save_handle_1, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_handle_0, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_CHECK(ndr_pull_NTSTATUS(ndr, NDR_SCALARS, &r->out.result));
        }
@@ -7719,7 +7730,9 @@ _PUBLIC_ void ndr_print_lsa_DeleteObject(struct ndr_print 
*ndr, const char *name
                ndr->depth++;
                ndr_print_ptr(ndr, "handle", *r->in.handle);
                ndr->depth++;
-               ndr_print_policy_handle(ndr, "handle", *r->in.handle);
+               if (*r->in.handle) {
+                       ndr_print_policy_handle(ndr, "handle", *r->in.handle);
+               }
                ndr->depth--;
                ndr->depth--;
                ndr->depth--;
@@ -7731,7 +7744,9 @@ _PUBLIC_ void ndr_print_lsa_DeleteObject(struct ndr_print 
*ndr, const char *name
                ndr->depth++;
                ndr_print_ptr(ndr, "handle", *r->out.handle);
                ndr->depth++;
-               ndr_print_policy_handle(ndr, "handle", *r->out.handle);
+               if (*r->out.handle) {
+                       ndr_print_policy_handle(ndr, "handle", *r->out.handle);
+               }
                ndr->depth--;
                ndr->depth--;
                ndr_print_NTSTATUS(ndr, "result", r->out.result);
@@ -10701,11 +10716,10 @@ static enum ndr_err_code 
ndr_push_lsa_lsaRQueryForestTrustInformation(struct ndr
                if (r->out.forest_trust_info == NULL) {
                        return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
                }
-               if (*r->out.forest_trust_info == NULL) {
-                       return ndr_push_error(ndr, NDR_ERR_INVALID_POINTER, 
"NULL [ref] pointer");
+               NDR_CHECK(ndr_push_unique_ptr(ndr, *r->out.forest_trust_info));
+               if (*r->out.forest_trust_info) {
+                       NDR_CHECK(ndr_push_lsa_ForestTrustInformation(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.forest_trust_info));
                }
-               NDR_CHECK(ndr_push_ref_ptr(ndr));
-               NDR_CHECK(ndr_push_lsa_ForestTrustInformation(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.forest_trust_info));
                NDR_CHECK(ndr_push_NTSTATUS(ndr, NDR_SCALARS, r->out.result));
        }
        return NDR_ERR_SUCCESS;
@@ -10745,14 +10759,18 @@ static enum ndr_err_code 
ndr_pull_lsa_lsaRQueryForestTrustInformation(struct ndr
                }
                _mem_save_forest_trust_info_0 = NDR_PULL_GET_MEM_CTX(ndr);
                NDR_PULL_SET_MEM_CTX(ndr, r->out.forest_trust_info, 
LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_ref_ptr(ndr, &_ptr_forest_trust_info));
-               if (ndr->flags & LIBNDR_FLAG_REF_ALLOC) {
+               NDR_CHECK(ndr_pull_generic_ptr(ndr, &_ptr_forest_trust_info));
+               if (_ptr_forest_trust_info) {
                        NDR_PULL_ALLOC(ndr, *r->out.forest_trust_info);
+               } else {
+                       *r->out.forest_trust_info = NULL;
+               }
+               if (*r->out.forest_trust_info) {
+                       _mem_save_forest_trust_info_1 = 
NDR_PULL_GET_MEM_CTX(ndr);
+                       NDR_PULL_SET_MEM_CTX(ndr, *r->out.forest_trust_info, 0);
+                       NDR_CHECK(ndr_pull_lsa_ForestTrustInformation(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.forest_trust_info));
+                       NDR_PULL_SET_MEM_CTX(ndr, 
_mem_save_forest_trust_info_1, 0);
                }
-               _mem_save_forest_trust_info_1 = NDR_PULL_GET_MEM_CTX(ndr);
-               NDR_PULL_SET_MEM_CTX(ndr, *r->out.forest_trust_info, 
LIBNDR_FLAG_REF_ALLOC);
-               NDR_CHECK(ndr_pull_lsa_ForestTrustInformation(ndr, 
NDR_SCALARS|NDR_BUFFERS, *r->out.forest_trust_info));
-               NDR_PULL_SET_MEM_CTX(ndr, _mem_save_forest_trust_info_1, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_PULL_SET_MEM_CTX(ndr, _mem_save_forest_trust_info_0, 
LIBNDR_FLAG_REF_ALLOC);
                NDR_CHECK(ndr_pull_NTSTATUS(ndr, NDR_SCALARS, &r->out.result));
        }
@@ -10787,7 +10805,9 @@ _PUBLIC_ void 
ndr_print_lsa_lsaRQueryForestTrustInformation(struct ndr_print *nd
                ndr->depth++;
                ndr_print_ptr(ndr, "forest_trust_info", 
*r->out.forest_trust_info);
                ndr->depth++;


-- 
Samba Shared Repository

Reply via email to