]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Enhance Py_ARRAY_LENGTH(): fail at build time if the argument is not an array
authorVictor Stinner <victor.stinner@haypocalc.com>
Wed, 28 Sep 2011 23:12:24 +0000 (01:12 +0200)
committerVictor Stinner <victor.stinner@haypocalc.com>
Wed, 28 Sep 2011 23:12:24 +0000 (01:12 +0200)
Move other various macros to pymcacro.h

Thanks Rusty Russell for having written these amazing C macros!

Include/Python.h
Include/pymacro.h [new file with mode: 0644]
Makefile.pre.in
Misc/ACKS
PCbuild/pythoncore.vcproj

index 63043f2b9d5a94fba80912f628ef0b960f8cf98c..ae384ee01537e709f91d88d27a3aed904fb5786e 100644 (file)
@@ -48,6 +48,7 @@
 #include <assert.h>
 
 #include "pyport.h"
+#include "pymacro.h"
 
 #include "pyatomic.h"
 
 #include "pystrcmp.h"
 #include "dtoa.h"
 #include "fileutils.h"
-
-/* Argument must be a char or an int in [-128, 127] or [0, 255]. */
-#define Py_CHARMASK(c) ((unsigned char)((c) & 0xff))
-
 #include "pyfpe.h"
 
-/* Define macros for inline documentation. */
-#define PyDoc_VAR(name) static char name[]
-#define PyDoc_STRVAR(name,str) PyDoc_VAR(name) = PyDoc_STR(str)
-#ifdef WITH_DOC_STRINGS
-#define PyDoc_STR(str) str
-#else
-#define PyDoc_STR(str) ""
-#endif
-
-#define Py_ARRAY_LENGTH(array) (sizeof(array) / sizeof((array)[0]))
-
-#define Py_MIN(x, y) (((x) > (y)) ? (y) : (x))
-#define Py_MAX(x, y) (((x) > (y)) ? (x) : (y))
-
 #endif /* !Py_PYTHON_H */
diff --git a/Include/pymacro.h b/Include/pymacro.h
new file mode 100644 (file)
index 0000000..22f1d71
--- /dev/null
@@ -0,0 +1,57 @@
+#ifndef Py_PYMACRO_H
+#define Py_PYMACRO_H
+
+#define Py_MIN(x, y) (((x) > (y)) ? (y) : (x))
+#define Py_MAX(x, y) (((x) > (y)) ? (x) : (y))
+
+/* Argument must be a char or an int in [-128, 127] or [0, 255]. */
+#define Py_CHARMASK(c) ((unsigned char)((c) & 0xff))
+
+
+/* Assert a build-time dependency, as an expression.
+
+   Your compile will fail if the condition isn't true, or can't be evaluated
+   by the compiler. This can be used in an expression: its value is 0.
+
+   Example:
+
+   #define foo_to_char(foo)  \
+       ((char *)(foo)        \
+        + Py_BUILD_ASSERT(offsetof(struct foo, string) == 0))
+
+   Written by Rusty Russell, public domain. */
+#define Py_BUILD_ASSERT(cond) \
+    (sizeof(char [1 - 2*!(cond)]) - 1)
+
+#if defined(__GNUC__)
+/* Two gcc extensions.
+   &a[0] degrades to a pointer: a different type from an array */
+#define _Py_ARRAY_LENGTH_CHECK(array) \
+    Py_BUILD_ASSERT(!__builtin_types_compatible_p(typeof(array), \
+                                                  typeof(&(array)[0])))
+#else
+#define _Py_ARRAY_LENGTH_CHECK(array) 0
+#endif
+
+
+/* Get the number of elements in a visible array
+
+   This does not work on pointers, or arrays declared as [], or function
+   parameters. With correct compiler support, such usage will cause a build
+   error (see Py_BUILD_ASSERT).
+
+   Written by Rusty Russell, public domain. */
+#define Py_ARRAY_LENGTH(array) \
+    (sizeof(array) / sizeof((array)[0]) + _Py_ARRAY_LENGTH_CHECK(array))
+
+
+/* Define macros for inline documentation. */
+#define PyDoc_VAR(name) static char name[]
+#define PyDoc_STRVAR(name,str) PyDoc_VAR(name) = PyDoc_STR(str)
+#ifdef WITH_DOC_STRINGS
+#define PyDoc_STR(str) str
+#else
+#define PyDoc_STR(str) ""
+#endif
+
+#endif /* Py_PYMACRO_H */
index 61239460a7da8d85624495d5e03e71ce9ef87a51..52743e434ab3aaf905f67b9d01a4bf1fe585d8e0 100644 (file)
@@ -493,7 +493,7 @@ $(PYTHONFRAMEWORKDIR)/Versions/$(VERSION)/$(PYTHONFRAMEWORK): \
                -install_name $(DESTDIR)$(PYTHONFRAMEWORKINSTALLDIR)/Versions/$(VERSION)/$(PYTHONFRAMEWORK) \
                -compatibility_version $(VERSION) \
                -current_version $(VERSION) \
-               -framework CoreFoundation $(LIBS); 
+               -framework CoreFoundation $(LIBS);
        $(INSTALL) -d -m $(DIRMODE)  \
                $(PYTHONFRAMEWORKDIR)/Versions/$(VERSION)/Resources/English.lproj
        $(INSTALL_DATA) $(RESSRCDIR)/Info.plist \
@@ -718,6 +718,7 @@ PYTHON_HEADERS= \
                Include/pyfpe.h \
                Include/pymath.h \
                Include/pygetopt.h \
+               Include/pymacro.h \
                Include/pymem.h \
                Include/pyport.h \
                Include/pystate.h \
index 0d1a77b7d945c2a23688b5cadebe04a1d357f4de..06feb0b1e366aed985a980b3f58686a775b2fa29 100644 (file)
--- a/Misc/ACKS
+++ b/Misc/ACKS
@@ -825,6 +825,7 @@ Rauli Ruohonen
 Jeff Rush
 Sam Rushing
 Mark Russell
+Rusty Russell
 Nick Russo
 Patrick Sabin
 SĂ©bastien SablĂ©
index ed6e1587ba5c697754b53d831ff447ab9964e191..7e9f472d69f71b1b7340d82a1429f88c5cc21a65 100644 (file)
                                RelativePath="..\Include\pytime.h"\r
                                >\r
                        </File>\r
+                       <File\r
+                               RelativePath="..\Include\pymacro.h"\r
+                               >\r
+                       </File>\r
                        <File\r
                                RelativePath="..\Include\pymem.h"\r
                                >\r