summaryrefslogtreecommitdiff
path: root/source3/lib
diff options
context:
space:
mode:
authorStefan Metzmacher <metze@samba.org>2007-04-17 08:03:29 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 12:19:24 -0500
commita8c62502741fe287091cc9001b69fbd7496e3562 (patch)
tree6bb0fe3d00b6c12f299728943a8a22e6c74250fb /source3/lib
parent2da54a66b970917ca5290001af0f4ab7adf68460 (diff)
downloadsamba-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')
-rw-r--r--source3/lib/replace/README6
-rw-r--r--source3/lib/replace/replace.h29
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