summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTim Peters <tim.peters@gmail.com>2004-07-22 01:46:43 (GMT)
committerTim Peters <tim.peters@gmail.com>2004-07-22 01:46:43 (GMT)
commit5980ff2d924b55cf963e9fb69f41c86b45f4099a (patch)
tree010601edc1df19e1b5dc178850ca632d12a2f998
parentaa1c7ff7e8dd9dbda8ed935b7db7c9a81a164621 (diff)
downloadcpython-5980ff2d924b55cf963e9fb69f41c86b45f4099a.zip
cpython-5980ff2d924b55cf963e9fb69f41c86b45f4099a.tar.gz
cpython-5980ff2d924b55cf963e9fb69f41c86b45f4099a.tar.bz2
SF bug 994255: Py_RETURN_NONE causes too much warnings
Rewrote Py_RETURN_{NONE, TRUE, FALSE} to expand to comma expressions rather than "do {} while(0)" thingies. The OP complained because he likes using MS /W4 sometimes, and then all his uses of these things generate nuisance warnings about testing a constant expression (in the "while(0)" part). Comma expressions don't have this problem (although it's a lucky accident that comma expressions suffice for these macros!).
-rw-r--r--Include/boolobject.h4
-rw-r--r--Include/object.h2
2 files changed, 3 insertions, 3 deletions
diff --git a/Include/boolobject.h b/Include/boolobject.h
index 92d5e27..7f9ad01 100644
--- a/Include/boolobject.h
+++ b/Include/boolobject.h
@@ -24,8 +24,8 @@ PyAPI_DATA(PyIntObject) _Py_ZeroStruct, _Py_TrueStruct;
#define Py_True ((PyObject *) &_Py_TrueStruct)
/* Macros for returning Py_True or Py_False, respectively */
-#define Py_RETURN_TRUE do {Py_INCREF(Py_True); return Py_True;} while (0)
-#define Py_RETURN_FALSE do {Py_INCREF(Py_False); return Py_False;} while (0)
+#define Py_RETURN_TRUE return Py_INCREF(Py_True), Py_True
+#define Py_RETURN_FALSE return Py_INCREF(Py_False), Py_False
/* Function to return a bool from a C long */
PyAPI_FUNC(PyObject *) PyBool_FromLong(long);
diff --git a/Include/object.h b/Include/object.h
index 60cf146..5db4dac 100644
--- a/Include/object.h
+++ b/Include/object.h
@@ -650,7 +650,7 @@ PyAPI_DATA(PyObject) _Py_NoneStruct; /* Don't use this directly */
#define Py_None (&_Py_NoneStruct)
/* Macro for returning Py_None from a function */
-#define Py_RETURN_NONE do {Py_INCREF(Py_None); return Py_None;} while (0)
+#define Py_RETURN_NONE return Py_INCREF(Py_None), Py_None
/*
Py_NotImplemented is a singleton used to signal that an operation is