diff options
author | Stefan Metzmacher <metze@samba.org> | 2007-04-17 08:03:01 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 14:50:59 -0500 |
commit | 4047b20c368f473081eeb951dff119a6c060c9f7 (patch) | |
tree | a48de3ebba42464dc7ba5819f92cc382fbea7460 /source4 | |
parent | 3eb286b52a30f126c53fd3d9688c51586f7b73ad (diff) | |
download | samba-4047b20c368f473081eeb951dff119a6c060c9f7.tar.gz samba-4047b20c368f473081eeb951dff119a6c060c9f7.tar.bz2 samba-4047b20c368f473081eeb951dff119a6c060c9f7.zip |
r22297: move ZERO_*, ARRAY_SIZE and PTR_DIFF macros into libreplace
metze
(This used to be commit b69c950858d837d7bd734d418129ade69106a00d)
Diffstat (limited to 'source4')
-rw-r--r-- | source4/lib/replace/README | 6 | ||||
-rw-r--r-- | source4/lib/replace/replace.h | 29 | ||||
-rw-r--r-- | source4/lib/util/util.h | 25 |
3 files changed, 35 insertions, 25 deletions
diff --git a/source4/lib/replace/README b/source4/lib/replace/README index c2de560314..77558b2ca9 100644 --- a/source4/lib/replace/README +++ b/source4/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/source4/lib/replace/replace.h b/source4/lib/replace/replace.h index 840b448d24..b96356ac46 100644 --- a/source4/lib/replace/replace.h +++ b/source4/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 diff --git a/source4/lib/util/util.h b/source4/lib/util/util.h index dd6c1499bd..cfd77e5a13 100644 --- a/source4/lib/util/util.h +++ b/source4/lib/util/util.h @@ -41,31 +41,6 @@ extern const char *panic_action; #include "util/byteorder.h" #include "lib/util/util_proto.h" -/** - * 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))) - -/** - * pointer difference macro - */ -#define PTR_DIFF(p1,p2) ((ptrdiff_t)(((const char *)(p1)) - (const char *)(p2))) - -/** - * work out how many elements there are in a static array - */ -#define ARRAY_SIZE(a) (sizeof(a)/sizeof(a[0])) - /** * assert macros */ |