From: Günther Deschner Date: Mon, 14 Dec 2009 13:08:34 +0000 (+0100) Subject: libndr: add ndr_push_relative_ptr2_start and ndr_push_relative_ptr2_end. X-Git-Url: http://git.samba.org/?p=abartlet%2Fsamba.git%2F.git;a=commitdiff_plain;h=bc20d3446aa6de9f1d21d167c384e9eb4edd55eb libndr: add ndr_push_relative_ptr2_start and ndr_push_relative_ptr2_end. Guenther --- diff --git a/librpc/ndr/libndr.h b/librpc/ndr/libndr.h index 09e5334aa42..95ccb27912f 100644 --- a/librpc/ndr/libndr.h +++ b/librpc/ndr/libndr.h @@ -385,6 +385,8 @@ enum ndr_err_code ndr_push_setup_relative_base_offset2(struct ndr_push *ndr, con enum ndr_err_code ndr_push_relative_ptr1(struct ndr_push *ndr, const void *p); enum ndr_err_code ndr_push_short_relative_ptr1(struct ndr_push *ndr, const void *p); enum ndr_err_code ndr_push_relative_ptr2(struct ndr_push *ndr, const void *p); +enum ndr_err_code ndr_push_relative_ptr2_start(struct ndr_push *ndr, const void *p); +enum ndr_err_code ndr_push_relative_ptr2_end(struct ndr_push *ndr, const void *p); enum ndr_err_code ndr_push_short_relative_ptr2(struct ndr_push *ndr, const void *p); uint32_t ndr_pull_get_relative_base_offset(struct ndr_pull *ndr); void ndr_pull_restore_relative_base_offset(struct ndr_pull *ndr, uint32_t offset); diff --git a/librpc/ndr/ndr.c b/librpc/ndr/ndr.c index a151994b6af..fb1e5671fe0 100644 --- a/librpc/ndr/ndr.c +++ b/librpc/ndr/ndr.c @@ -1144,6 +1144,30 @@ _PUBLIC_ enum ndr_err_code ndr_push_short_relative_ptr2(struct ndr_push *ndr, co return NDR_ERR_SUCCESS; } +/* + push a relative object - stage2 start + this is called during buffers processing +*/ +_PUBLIC_ enum ndr_err_code ndr_push_relative_ptr2_start(struct ndr_push *ndr, const void *p) +{ + if (p == NULL) { + return NDR_ERR_SUCCESS; + } + return ndr_push_relative_ptr2(ndr, p); +} + +/* + push a relative object - stage2 end + this is called during buffers processing +*/ +_PUBLIC_ enum ndr_err_code ndr_push_relative_ptr2_end(struct ndr_push *ndr, const void *p) +{ + if (p == NULL) { + return NDR_ERR_SUCCESS; + } + return NDR_ERR_SUCCESS; +} + /* get the current base for relative pointers for the pull */