/*
- * $Id: cnid_delete.c,v 1.6 2001-08-31 14:58:48 rufustfirefly Exp $
+ * $Id: cnid_delete.c,v 1.7 2001-09-20 06:10:42 jmarcus Exp $
*
* Copyright (c) 1999. Adrian Sun (asun@zoology.washington.edu)
* All Rights Reserved. See COPYRIGHT.
CNID_private *db;
DBT key, data;
DB_TXN *tid;
+ int rc = 0;
if (!(db = CNID) || !id || (db->flags & CNIDFLAG_DB_RO))
return -1;
retry:
- if ((errno = txn_begin(db->dbenv, NULL, &tid, 0))) {
- return errno;
+ if ((rc = txn_begin(db->dbenv, NULL, &tid, 0))) {
+ return rc;
}
/* get from main database */
key.data = (cnid_t *) &id;
key.size = sizeof(id);
- if ((errno = db->db_cnid->get(db->db_cnid, tid, &key, &data, 0))) {
+ if ((rc = db->db_cnid->get(db->db_cnid, tid, &key, &data, 0))) {
txn_abort(tid);
- switch (errno) {
+ switch (rc) {
case DB_LOCK_DEADLOCK:
goto retry;
return 0;
default:
syslog(LOG_ERR, "cnid_delete: can't delete entry");
- return errno;
+ return rc;
}
}
/* now delete from dev/ino database */
key.data = data.data;
key.size = CNID_DEVINO_LEN;
- if ((errno = db->db_devino->del(db->db_devino, tid, &key, 0))) {
- if (errno == DB_LOCK_DEADLOCK) {
+ if ((rc = db->db_devino->del(db->db_devino, tid, &key, 0))) {
+ if (rc == DB_LOCK_DEADLOCK) {
txn_abort(tid);
goto retry;
}
/* be silent if there isn't an entry */
- if (errno != DB_NOTFOUND) {
+ if (rc != DB_NOTFOUND) {
txn_abort(tid);
goto abort_err;
}
/* delete from did/name database */
key.data = (char *) data.data + CNID_DEVINO_LEN;
key.size = data.size - CNID_DEVINO_LEN;
- if ((errno = db->db_didname->del(db->db_didname, tid, &key, 0))) {
- if (errno == DB_LOCK_DEADLOCK) {
+ if ((rc = db->db_didname->del(db->db_didname, tid, &key, 0))) {
+ if (rc == DB_LOCK_DEADLOCK) {
txn_abort(tid);
goto retry;
}
/* be silent if there isn't an entry */
- if (errno != DB_NOTFOUND) {
+ if (rc != DB_NOTFOUND) {
txn_abort(tid);
goto abort_err;
}
/* now delete from main database */
key.data = (cnid_t *) &id;
key.size = sizeof(id);
- if ((errno = db->db_cnid->del(db->db_cnid, tid, &key, 0))) {
+ if ((rc = db->db_cnid->del(db->db_cnid, tid, &key, 0))) {
txn_abort(tid);
- if (errno == DB_LOCK_DEADLOCK) {
+ if (rc == DB_LOCK_DEADLOCK) {
goto retry;
}
goto abort_err;
abort_err:
syslog(LOG_ERR, "cnid_del: unable to delete CNID(%x)", id);
- return errno;
+ return rc;
}
#endif /* CNID_DB */
/*
- * $Id: cnid_update.c,v 1.6 2001-08-31 14:58:48 rufustfirefly Exp $
+ * $Id: cnid_update.c,v 1.7 2001-09-20 06:07:12 jmarcus Exp $
*/
#ifdef HAVE_CONFIG_H
CNID_private *db;
DBT key, data, altdata;
DB_TXN *tid;
+ int rc = 0;
if (!(db = CNID) || !id || !st || !name || (db->flags & CNIDFLAG_DB_RO))
return -1;
/* begin a transaction */
retry:
- if ((errno = txn_begin(db->dbenv, NULL, &tid, 0))) {
- return errno;
+ if ((rc = txn_begin(db->dbenv, NULL, &tid, 0))) {
+ return rc;
}
/* get the old info */
key.data = (cnid_t *) &id;
key.size = sizeof(id);
- if ((errno = db->db_cnid->get(db->db_cnid, tid, &key, &data, 0))) {
+ if ((rc = db->db_cnid->get(db->db_cnid, tid, &key, &data, 0))) {
txn_abort(tid);
- if (errno == DB_LOCK_DEADLOCK)
+ if (rc == DB_LOCK_DEADLOCK)
goto retry;
goto update_err;
}
/* delete the old dev/ino mapping */
key.data = data.data;
key.size = CNID_DEVINO_LEN;
- if ((errno = db->db_devino->del(db->db_devino, tid, &key, 0))) {
- if (errno == DB_LOCK_DEADLOCK) {
+ if ((rc = db->db_devino->del(db->db_devino, tid, &key, 0))) {
+ if (rc == DB_LOCK_DEADLOCK) {
txn_abort(tid);
goto retry;
}
/* silently fail on a non-existent entry */
- if (errno != DB_NOTFOUND) {
+ if (rc != DB_NOTFOUND) {
txn_abort(tid);
goto update_err;
}
/* delete the old did/name mapping */
key.data = (char *) data.data + CNID_DEVINO_LEN;
key.size = data.size - CNID_DEVINO_LEN;
- if ((errno = db->db_didname->del(db->db_didname, tid, &key, 0))) {
- if (errno == DB_LOCK_DEADLOCK) {
+ if ((rc = db->db_didname->del(db->db_didname, tid, &key, 0))) {
+ if (rc == DB_LOCK_DEADLOCK) {
txn_abort(tid);
goto retry;
}
/* silently fail on a non-existent entry */
- if (errno != DB_NOTFOUND) {
+ if (rc != DB_NOTFOUND) {
txn_abort(tid);
goto update_err;
}
key.size = CNID_DEVINO_LEN;
altdata.data = (cnid_t *) &id;
altdata.size = sizeof(id);
- if ((errno = db->db_devino->put(db->db_devino, tid, &key, &altdata, 0))) {
+ if ((rc = db->db_devino->put(db->db_devino, tid, &key, &altdata, 0))) {
txn_abort(tid);
- if (errno == DB_LOCK_DEADLOCK) {
+ if (rc == DB_LOCK_DEADLOCK) {
goto retry;
}
goto update_err;
/* put a new did/name mapping in */
key.data = (char *) data.data + CNID_DEVINO_LEN;
key.size = data.size - CNID_DEVINO_LEN;
- if ((errno = db->db_didname->put(db->db_didname, tid, &key, &altdata, 0))) {
+ if ((rc = db->db_didname->put(db->db_didname, tid, &key, &altdata, 0))) {
txn_abort(tid);
- if (errno == DB_LOCK_DEADLOCK) {
+ if (rc == DB_LOCK_DEADLOCK) {
goto retry;
}
goto update_err;
/* update the old CNID with the new info */
key.data = (cnid_t *) &id;
key.size = sizeof(id);
- if ((errno = db->db_cnid->put(db->db_cnid, tid, &key, &data, 0))) {
+ if ((rc = db->db_cnid->put(db->db_cnid, tid, &key, &data, 0))) {
txn_abort(tid);
- if (errno == DB_LOCK_DEADLOCK) {
+ if (rc == DB_LOCK_DEADLOCK) {
goto retry;
}
goto update_err;