aboutsummaryrefslogtreecommitdiffstats
path: root/libibex
diff options
context:
space:
mode:
Diffstat (limited to 'libibex')
-rw-r--r--libibex/ChangeLog5
-rw-r--r--libibex/ibex.h3
-rw-r--r--libibex/ibex_block.c24
3 files changed, 32 insertions, 0 deletions
diff --git a/libibex/ChangeLog b/libibex/ChangeLog
index b91a747552..4f85c3845e 100644
--- a/libibex/ChangeLog
+++ b/libibex/ChangeLog
@@ -1,3 +1,8 @@
+2001-10-28 <NotZed@Ximian.com>
+
+ * ibex_block.c (ibex_move): New api entry to move an ibex file in
+ an atomic way.
+
2001-10-12 <NotZed@Ximian.com>
* ibex_block.c (ibex_use): Added environmental variable
diff --git a/libibex/ibex.h b/libibex/ibex.h
index 59308deccb..aafa6e734c 100644
--- a/libibex/ibex.h
+++ b/libibex/ibex.h
@@ -43,6 +43,9 @@ int ibex_write (ibex *ib);
/* only save if ibex has changed. */
int ibex_save (ibex *ib);
+/* rename an ibex file to a new location */
+int ibex_move (ibex *ib, const char *newname);
+
/* Write the ibex to disk if it has changed, and free all memory
* associated with it.
*/
diff --git a/libibex/ibex_block.c b/libibex/ibex_block.c
index 7ce4e7934b..3c96885f4f 100644
--- a/libibex/ibex_block.c
+++ b/libibex/ibex_block.c
@@ -491,6 +491,30 @@ int ibex_close (ibex *ib)
return ret;
}
+/* rename/move the ibex file */
+int ibex_move(ibex *ib, const char *newname)
+{
+ int ret = -1;
+
+ IBEX_LOCK(ib);
+
+ if (ib->blocks)
+ close_backend(ib);
+
+ if (rename(ib->name, newname) == -1)
+ goto error;
+
+ g_free(ib->name);
+ ib->name = g_strdup(newname);
+ ret = 0;
+
+error:
+ IBEX_UNLOCK(ib);
+
+ return ret;
+}
+
+
/**
* ibex_unindex:
* @ib: