From db83242ea9b533143769ce6b8185094c13739095 Mon Sep 17 00:00:00 2001 From: jsdelfino Date: Mon, 19 Apr 2010 06:26:31 +0000 Subject: Reuse the same file descriptor when reopening a tinycdb database. git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@935461 13f79535-47bb-0310-9956-ffa450edef68 --- sca-cpp/trunk/components/nosqldb/tinycdb.hpp | 39 +++++++++++++++++++++++++--- 1 file changed, 35 insertions(+), 4 deletions(-) (limited to 'sca-cpp/trunk/components/nosqldb') diff --git a/sca-cpp/trunk/components/nosqldb/tinycdb.hpp b/sca-cpp/trunk/components/nosqldb/tinycdb.hpp index b98d622e25..a22cd81fd1 100644 --- a/sca-cpp/trunk/components/nosqldb/tinycdb.hpp +++ b/sca-cpp/trunk/components/nosqldb/tinycdb.hpp @@ -143,19 +143,50 @@ const string dbname(const TinyCDB& cdb) { * Open a database. */ const failable cdbopen(TinyCDB& cdb) { + + // Get database file serial number struct stat st; - int s = stat(c_str(cdb.name), &st); + const int s = stat(c_str(cdb.name), &st); if (s == -1) return mkfailure(string("Couldn't read database stat ") + cdb.name); - if (st.st_ino != cdb.st.st_ino || cdb.fd == -1) { - if (cdb.fd != -1) - close(cdb.fd); + + // Open database for the first time + if (cdb.fd == -1) { cdb.fd = open(c_str(cdb.name), O_RDONLY); if (cdb.fd == -1) return mkfailure(string("Couldn't open database file ") + cdb.name); debug(cdb.fd, "tinycdb::open::fd"); cdb.st = st; + return cdb.fd; + } + + // Close and reopen database after a change + if (st.st_ino != cdb.st.st_ino) { + + // Close current fd + close(cdb.fd); + + // Reopen database + const int newfd = open(c_str(cdb.name), O_RDONLY); + if (newfd == -1) + return mkfailure(string("Couldn't open database file ") + cdb.name); + if (newfd == cdb.fd) { + debug(cdb.fd, "tinycdb::open::fd"); + cdb.st = st; + return cdb.fd; + } + + // We got a different fd, dup it to the current fd then close it + if (fcntl(newfd, F_DUPFD, cdb.fd) == -1) + return mkfailure(string("Couldn't dup database file handle ") + cdb.name); + close(newfd); + + debug(cdb.fd, "tinycdb::open::fd"); + cdb.st = st; + return cdb.fd; } + + // No change, just return the current fd return cdb.fd; } -- cgit v1.2.3