summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Modules/_bsddb.c131
1 files changed, 65 insertions, 66 deletions
diff --git a/Modules/_bsddb.c b/Modules/_bsddb.c
index 9654cf3..fd64151 100644
--- a/Modules/_bsddb.c
+++ b/Modules/_bsddb.c
@@ -1986,14 +1986,14 @@ DB_set_bt_minkey(DBObject* self, PyObject* args)
#if (DBVER >= 33)
static int
-_default_cmp (const DBT *leftKey,
- const DBT *rightKey)
+_default_cmp(const DBT *leftKey,
+ const DBT *rightKey)
{
int res;
int lsize = leftKey->size, rsize = rightKey->size;
- res = memcmp (leftKey->data, rightKey->data,
- lsize < rsize ? lsize : rsize);
+ res = memcmp(leftKey->data, rightKey->data,
+ lsize < rsize ? lsize : rsize);
if (res == 0) {
if (lsize < rsize) {
@@ -2007,58 +2007,56 @@ _default_cmp (const DBT *leftKey,
}
static int
-_db_compareCallback (DB* db,
- const DBT *leftKey,
- const DBT *rightKey)
+_db_compareCallback(DB* db,
+ const DBT *leftKey,
+ const DBT *rightKey)
{
int res = 0;
PyObject *args;
PyObject *result;
PyObject *leftObject;
PyObject *rightObject;
- DBObject *self = (DBObject *) db->app_private;
+ DBObject *self = (DBObject *)db->app_private;
if (self == NULL || self->btCompareCallback == NULL) {
MYDB_BEGIN_BLOCK_THREADS;
- PyErr_SetString (PyExc_TypeError,
- (self == 0
- ? "DB_bt_compare db is NULL."
- : "DB_bt_compare callback is NULL."));
+ PyErr_SetString(PyExc_TypeError,
+ (self == 0
+ ? "DB_bt_compare db is NULL."
+ : "DB_bt_compare callback is NULL."));
/* we're in a callback within the DB code, we can't raise */
- PyErr_Print ();
- res = _default_cmp (leftKey, rightKey);
+ PyErr_Print();
+ res = _default_cmp(leftKey, rightKey);
MYDB_END_BLOCK_THREADS;
- }
- else {
+ } else {
MYDB_BEGIN_BLOCK_THREADS;
- leftObject = PyString_FromStringAndSize (leftKey->data, leftKey->size);
- rightObject = PyString_FromStringAndSize (rightKey->data, rightKey->size);
+ leftObject = PyString_FromStringAndSize(leftKey->data, leftKey->size);
+ rightObject = PyString_FromStringAndSize(rightKey->data, rightKey->size);
- args = PyTuple_New (2);
- Py_INCREF (self);
- PyTuple_SET_ITEM (args, 0, leftObject); /* steals reference */
- PyTuple_SET_ITEM (args, 1, rightObject); /* steals reference */
-
- result = PyEval_CallObject (self->btCompareCallback, args);
- if (result == 0) {
- /* we're in a callback within the DB code, we can't raise */
- PyErr_Print ();
- res = _default_cmp (leftKey, rightKey);
- }
- else if (PyInt_Check (result)) {
- res = PyInt_AsLong (result);
+ args = PyTuple_New(2);
+ if (args != NULL) {
+ Py_INCREF(self);
+ PyTuple_SET_ITEM(args, 0, leftObject); /* steals reference */
+ PyTuple_SET_ITEM(args, 1, rightObject); /* steals reference */
+ result = PyEval_CallObject(self->btCompareCallback, args);
}
- else {
- PyErr_SetString (PyExc_TypeError,
- "DB_bt_compare callback MUST return an int.");
+ if (args == NULL || result == NULL) {
+ /* we're in a callback within the DB code, we can't raise */
+ PyErr_Print();
+ res = _default_cmp(leftKey, rightKey);
+ } else if (PyInt_Check(result)) {
+ res = PyInt_AsLong(result);
+ } else {
+ PyErr_SetString(PyExc_TypeError,
+ "DB_bt_compare callback MUST return an int.");
/* we're in a callback within the DB code, we can't raise */
- PyErr_Print ();
- res = _default_cmp (leftKey, rightKey);
+ PyErr_Print();
+ res = _default_cmp(leftKey, rightKey);
}
- Py_DECREF (args);
- Py_XDECREF (result);
+ Py_DECREF(args);
+ Py_XDECREF(result);
MYDB_END_BLOCK_THREADS;
}
@@ -2066,19 +2064,19 @@ _db_compareCallback (DB* db,
}
static PyObject*
-DB_set_bt_compare (DBObject* self, PyObject* args)
+DB_set_bt_compare(DBObject* self, PyObject* args)
{
int err;
PyObject *comparator;
PyObject *tuple, *emptyStr, *result;
- if (!PyArg_ParseTuple(args,"O:set_bt_compare", &comparator ))
+ if (!PyArg_ParseTuple(args, "O:set_bt_compare", &comparator))
return NULL;
- CHECK_DB_NOT_CLOSED (self);
+ CHECK_DB_NOT_CLOSED(self);
- if (! PyCallable_Check (comparator)) {
- makeTypeError ("Callable", comparator);
+ if (!PyCallable_Check(comparator)) {
+ makeTypeError("Callable", comparator);
return NULL;
}
@@ -2087,22 +2085,23 @@ DB_set_bt_compare (DBObject* self, PyObject* args)
* string objects here. verify that it returns an int (0).
* err if not.
*/
- tuple = PyTuple_New (2);
-
- emptyStr = PyString_FromStringAndSize (NULL, 0);
- Py_INCREF(emptyStr);
- PyTuple_SET_ITEM (tuple, 0, emptyStr);
- PyTuple_SET_ITEM (tuple, 1, emptyStr); /* steals reference */
- result = PyEval_CallObject (comparator, tuple);
- Py_DECREF (tuple);
- if (result == 0 || !PyInt_Check(result)) {
- PyErr_SetString (PyExc_TypeError,
- "callback MUST return an int");
+ tuple = PyTuple_New(2);
+ emptyStr = PyString_FromStringAndSize(NULL, 0);
+ if (tuple == NULL || emptyStr == NULL)
+ return NULL;
+
+ Py_INCREF(emptyStr); /* now we have two references */
+ PyTuple_SET_ITEM(tuple, 0, emptyStr); /* steals reference */
+ PyTuple_SET_ITEM(tuple, 1, emptyStr); /* steals reference */
+ result = PyEval_CallObject(comparator, tuple);
+ Py_DECREF(tuple);
+ if (result == NULL || !PyInt_Check(result)) {
+ PyErr_SetString(PyExc_TypeError,
+ "callback MUST return an int");
return NULL;
- }
- else if (PyInt_AsLong(result) != 0) {
- PyErr_SetString (PyExc_TypeError,
- "callback failed to return 0 on two empty strings");
+ } else if (PyInt_AsLong(result) != 0) {
+ PyErr_SetString(PyExc_TypeError,
+ "callback failed to return 0 on two empty strings");
return NULL;
}
@@ -2110,11 +2109,11 @@ DB_set_bt_compare (DBObject* self, PyObject* args)
* simplify the code. This would have no real use, as one cannot
* change the function once the db is opened anyway */
if (self->btCompareCallback != NULL) {
- PyErr_SetString (PyExc_RuntimeError, "set_bt_compare () cannot be called more than once");
+ PyErr_SetString(PyExc_RuntimeError, "set_bt_compare() cannot be called more than once");
return NULL;
}
- Py_INCREF (comparator);
+ Py_INCREF(comparator);
self->btCompareCallback = comparator;
/* This is to workaround a problem with un-initialized threads (see
@@ -2123,18 +2122,18 @@ DB_set_bt_compare (DBObject* self, PyObject* args)
PyEval_InitThreads();
#endif
- err = self->db->set_bt_compare (self->db,
- (comparator != NULL ?
- _db_compareCallback : NULL));
+ err = self->db->set_bt_compare(self->db,
+ (comparator != NULL ?
+ _db_compareCallback : NULL));
if (err) {
/* restore the old state in case of error */
- Py_DECREF (comparator);
+ Py_DECREF(comparator);
self->btCompareCallback = NULL;
}
- RETURN_IF_ERR ();
- RETURN_NONE ();
+ RETURN_IF_ERR();
+ RETURN_NONE();
}
#endif /* DBVER >= 33 */