From bbb41081d797c3301e4d202e30c4111207fe7693 Mon Sep 17 00:00:00 2001
From: Ali Polatel <alip@exherbo.org>
Date: Sat, 24 Sep 2011 15:43:43 +0300
Subject: [PATCH] ruby: Wrap notmuch_database_{begin,end}_atomic

Adding ruby wrappers for functions:
- notmuch_database_begin_atomic()
- notmuch_database_end_atomic()
added by 957f1ba3fc1d737887029ff1787fc6bea94de00b

New functions:
Notmuch::Database.begin_atomic()
Notmuch::Database.end_atomic()
---
 bindings/ruby/database.c | 40 +++++++++++++++++++++++++++++++++++++++-
 bindings/ruby/defs.h     |  6 ++++++
 bindings/ruby/init.c     |  2 ++
 3 files changed, 47 insertions(+), 1 deletion(-)

diff --git a/bindings/ruby/database.c b/bindings/ruby/database.c
index f4edd773..a4659ca3 100644
--- a/bindings/ruby/database.c
+++ b/bindings/ruby/database.c
@@ -1,6 +1,6 @@
 /* The Ruby interface to the notmuch mail library
  *
- * Copyright © 2010 Ali Polatel
+ * Copyright © 2010, 2011 Ali Polatel
  *
  * This program is free software: you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -204,6 +204,44 @@ notmuch_rb_database_upgrade(VALUE self)
     return Qtrue;
 }
 
+/*
+ * call-seq: DB.begin_atomic => nil
+ *
+ * Begin an atomic database operation.
+ */
+VALUE
+notmuch_rb_database_begin_atomic(VALUE self)
+{
+    notmuch_status_t ret;
+    notmuch_database_t *db;
+
+    Data_Get_Notmuch_Database(self, db);
+
+    ret = notmuch_database_begin_atomic(db);
+    notmuch_rb_status_raise(ret);
+
+    return Qtrue;
+}
+
+/*
+ * call-seq: DB.end_atomic => nil
+ *
+ * Indicate the end of an atomic database operation.
+ */
+VALUE
+notmuch_rb_database_end_atomic(VALUE self)
+{
+    notmuch_status_t ret;
+    notmuch_database_t *db;
+
+    Data_Get_Notmuch_Database(self, db);
+
+    ret = notmuch_database_end_atomic(db);
+    notmuch_rb_status_raise(ret);
+
+    return Qtrue;
+}
+
 /*
  * call-seq: DB.get_directory(path) => DIR
  *
diff --git a/bindings/ruby/defs.h b/bindings/ruby/defs.h
index f00afeff..a0303169 100644
--- a/bindings/ruby/defs.h
+++ b/bindings/ruby/defs.h
@@ -150,6 +150,12 @@ notmuch_rb_database_needs_upgrade(VALUE self);
 VALUE
 notmuch_rb_database_upgrade(VALUE self);
 
+VALUE
+notmuch_rb_database_begin_atomic(VALUE self);
+
+VALUE
+notmuch_rb_database_end_atomic(VALUE self);
+
 VALUE
 notmuch_rb_database_get_directory(VALUE self, VALUE pathv);
 
diff --git a/bindings/ruby/init.c b/bindings/ruby/init.c
index f5376fda..a516ab98 100644
--- a/bindings/ruby/init.c
+++ b/bindings/ruby/init.c
@@ -181,6 +181,8 @@ Init_notmuch(void)
     rb_define_method(notmuch_rb_cDatabase, "version", notmuch_rb_database_version, 0); /* in database.c */
     rb_define_method(notmuch_rb_cDatabase, "needs_upgrade?", notmuch_rb_database_needs_upgrade, 0); /* in database.c */
     rb_define_method(notmuch_rb_cDatabase, "upgrade!", notmuch_rb_database_upgrade, 0); /* in database.c */
+    rb_define_method(notmuch_rb_cDatabase, "begin_atomic", notmuch_rb_database_begin_atomic, 0); /* in database.c */
+    rb_define_method(notmuch_rb_cDatabase, "end_atomic", notmuch_rb_database_end_atomic, 0); /* in database.c */
     rb_define_method(notmuch_rb_cDatabase, "get_directory", notmuch_rb_database_get_directory, 1); /* in database.c */
     rb_define_method(notmuch_rb_cDatabase, "add_message", notmuch_rb_database_add_message, 1); /* in database.c */
     rb_define_method(notmuch_rb_cDatabase, "remove_message", notmuch_rb_database_remove_message, 1); /* in database.c */
-- 
2.45.2