#include "chiark_tcl_cdb.h"
-static void destroy_cdb_idtabcb(Tcl_Interp *ip, void *val) { abort(); }
-
-const IdDataSpec cdbtcl_databases= {
- "cdb-db", "cdb-opendatabases-table", destroy_cdb_idtabcb
-};
-
typedef struct Ro {
int ix, fd;
struct cdb cdb;
} Ro;
+static void ro_close(Ro *ro) {
+ cdb_free(&ro->cdb);
+ close(ro->fd);
+}
+
+static void destroy_cdb_idtabcb(Tcl_Interp *ip, void *ro_v) {
+ ro_close(ro_v);
+ TFREE(ro_v);
+}
+
+const IdDataSpec cdbtcl_databases= {
+ "cdb-db", "cdb-opendatabases-table", destroy_cdb_idtabcb
+};
+
int cht_do_cdb_open(ClientData cd, Tcl_Interp *ip,
const char *path, void **result) {
Ro *ro;
}
int cht_do_cdb_close(ClientData cd, Tcl_Interp *ip, void *ro_v) {
- Ro *ro= ro_v;
- cdb_free(&ro->cdb);
- close(ro->fd);
- TFREE(ro);
+ ro_close(ro_v);
+ cht_tabledataid_disposing(ip, ro_v, &cdbtcl_databases);
+ TFREE(ro_v);
return TCL_OK;
}
return rc;
}
-static void destroy_cdbrw_idtabcb(Tcl_Interp *ip, void *rw) {
- rw_close(0,rw);
- TFREE(rw);
+static void destroy_cdbrw_idtabcb(Tcl_Interp *ip, void *rw_v) {
+ rw_close(0,rw_v);
+ TFREE(rw_v);
}
const IdDataSpec cdbtcl_rwdatabases= {
"cdb-rwdb", "cdb-openrwdatabases-table", destroy_cdbrw_idtabcb
else rc= TCL_OK;
if (!rc) {
- if (!rw->logfile) {
+ if (rw->logfile) {
logsz= ftello(rw->logfile);
if (logsz < 0)
rc= cht_posixerr(ip, errno, "ftell logfile during close info");
rc= infocb(ip, rw, "close", "main=%luby log=%luby",
rw->mainsz, logsz);
} else if (reccount>=0) {
- rc= infocb(ip, rw, "close", "main=%luby nrecs=%l", rw->mainsz, reccount);
+ rc= infocb(ip, rw, "close", "main=%luby nrecs=%ld",
+ rw->mainsz, reccount);
} else {
rc= infocb(ip, rw, "close", "main=%luby", rw->mainsz);
}