diff options
author | Stefan Metzmacher <metze@samba.org> | 2007-04-17 08:03:29 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 12:19:24 -0500 |
commit | a8c62502741fe287091cc9001b69fbd7496e3562 (patch) | |
tree | 6bb0fe3d00b6c12f299728943a8a22e6c74250fb /source3/lib/replace | |
parent | 2da54a66b970917ca5290001af0f4ab7adf68460 (diff) | |
download | samba-a8c62502741fe287091cc9001b69fbd7496e3562.tar.gz samba-a8c62502741fe287091cc9001b69fbd7496e3562.tar.bz2 samba-a8c62502741fe287091cc9001b69fbd7496e3562.zip |
r22298: move ZERO_*, ARRAY_SIZE and PTR_DIFF macros into libreplace
metze
(This used to be commit 8a7d2e633b98aa9c73cf1f7d1369015b294cf2e1)
Diffstat (limited to 'source3/lib/replace')
-rw-r--r-- | source3/lib/replace/README | 6 | ||||
-rw-r--r-- | source3/lib/replace/replace.h | 29 |
2 files changed, 35 insertions, 0 deletions
diff --git a/source3/lib/replace/README b/source3/lib/replace/README index c2de560314..77558b2ca9 100644 --- a/source3/lib/replace/README +++ b/source3/lib/replace/README @@ -86,6 +86,12 @@ __STRINGSTRING MIN MAX QSORT_CAST +ZERO_STRUCT +ZERO_STRUCTP +ZERO_STRUCTPN +ZERO_ARRAY +ARRAY_SIZE +PTR_DIFF Headers: stdint.h diff --git a/source3/lib/replace/replace.h b/source3/lib/replace/replace.h index 840b448d24..b96356ac46 100644 --- a/source3/lib/replace/replace.h +++ b/source3/lib/replace/replace.h @@ -451,6 +451,35 @@ typedef int bool; #define __location__ __FILE__ ":" __LINESTR__ #endif +/** + * zero a structure + */ +#define ZERO_STRUCT(x) memset((char *)&(x), 0, sizeof(x)) + +/** + * zero a structure given a pointer to the structure + */ +#define ZERO_STRUCTP(x) do { if ((x) != NULL) memset((char *)(x), 0, sizeof(*(x))); } while(0) + +/** + * zero a structure given a pointer to the structure - no zero check + */ +#define ZERO_STRUCTPN(x) memset((char *)(x), 0, sizeof(*(x))) + +/* zero an array - note that sizeof(array) must work - ie. it must not be a + pointer */ +#define ZERO_ARRAY(x) memset((char *)(x), 0, sizeof(x)) + +/** + * work out how many elements there are in a static array + */ +#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0])) + +/** + * pointer difference macro + */ +#define PTR_DIFF(p1,p2) ((ptrdiff_t)(((const char *)(p1)) - (const char *)(p2))) + #if MMAP_BLACKLIST #undef HAVE_MMAP #endif |