summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 0b030d2)
raw | patch | inline | side by side (parent: 0b030d2)
author | Sven Trenkel <collectd@semidefinite.de> | |
Tue, 22 Dec 2009 01:20:42 +0000 (02:20 +0100) | ||
committer | Florian Forster <octo@noris.net> | |
Tue, 5 Jan 2010 10:02:37 +0000 (11:02 +0100) |
src/cpython.h | patch | blob | history | |
src/pyconfig.c | patch | blob | history |
diff --git a/src/cpython.h b/src/cpython.h
index 001a3ae9829e0d0d7836222270f7427c8442bc65..10a1a54cb66fb976e2a3a48ae519da5d824af1bb 100644 (file)
--- a/src/cpython.h
+++ b/src/cpython.h
# define Py_RETURN_NONE return Py_INCREF(Py_None), Py_None
#endif
+/* This macro is a shortcut for calls like
+ * x = PyObject_Repr(x);
+ * This can't be done like this example because this would leak
+ * a reference the the original x and crash in case of x == NULL.
+ * This calling syntax is less than elegant but it works, saves
+ * a lot of lines and avoids potential refcount errors. */
+
+#define CPY_SUBSTITUTE(func, a, ...) do {\
+ if ((a) != NULL) {\
+ PyObject *tmp = (a);\
+ (a) = func(__VA_ARGS__);\
+ Py_DECREF(tmp);\
+ }\
+} while(0)
/* Python3 compatibility layer. To keep the actual code as clean as possible
* do a lot of defines here. */
diff --git a/src/pyconfig.c b/src/pyconfig.c
index d794c9a8a1556c223149289b04943472e789bede..53e80e43fba9c9142034055b455e652dd9d02fea 100644 (file)
--- a/src/pyconfig.c
+++ b/src/pyconfig.c
static PyObject *Config_repr(PyObject *s) {
Config *self = (Config *) s;
- PyObject *name, *tmp, *ret = NULL;
+ PyObject *ret = NULL;
static PyObject *node_prefix = NULL, *root_prefix = NULL, *ending = NULL;
/* This is ok because we have the GIL, so this is thread-save by default. */
if (node_prefix == NULL || root_prefix == NULL || ending == NULL)
return NULL;
- name = PyObject_Str(self->key);
- if (name == NULL)
- return NULL;
-
+ ret = PyObject_Str(self->key);
if (self->parent == NULL || self->parent == Py_None)
- tmp = CPY_STRCAT(root_prefix, name);
+ CPY_SUBSTITUTE(CPY_STRCAT, ret, root_prefix, ret);
else
- tmp = CPY_STRCAT(node_prefix, name);
-
- Py_DECREF(name);
- if (tmp != NULL)
- ret = CPY_STRCAT(tmp, ending);
- Py_DECREF(tmp);
+ CPY_SUBSTITUTE(CPY_STRCAT, ret, node_prefix, ret);
+ CPY_SUBSTITUTE(CPY_STRCAT, ret, ret, ending);
return ret;
}