]> git.notmuchmail.org Git - notmuch/blobdiff - bindings/ruby/defs.h
ruby: Wrap notmuch_database_{begin,end}_atomic
[notmuch] / bindings / ruby / defs.h
index f36b7227695b5a8671b14e490e05a2e676fdab6d..a03031699b51cb31779dcd3aecae0b2e516fc668 100644 (file)
@@ -49,13 +49,91 @@ ID ID_call;
 ID ID_db_create;
 ID ID_db_mode;
 
+#define Data_Get_Notmuch_Database(obj, ptr)                \
+    do {                                                   \
+        Check_Type(obj, T_DATA);                           \
+        if (DATA_PTR(obj) == NULL)                         \
+            rb_raise(rb_eRuntimeError, "database closed"); \
+        Data_Get_Struct(obj, notmuch_database_t, ptr);     \
+    } while(0)
+
+#define Data_Get_Notmuch_Directory(obj, ptr)                   \
+    do {                                                       \
+        Check_Type(obj, T_DATA);                               \
+        if (DATA_PTR(obj) == NULL)                             \
+            rb_raise(rb_eRuntimeError, "directory destroyed"); \
+        Data_Get_Struct(obj, notmuch_directory_t, ptr);        \
+    } while(0)
+
+#define Data_Get_Notmuch_FileNames(obj, ptr)                   \
+    do {                                                       \
+        Check_Type(obj, T_DATA);                               \
+        if (DATA_PTR(obj) == NULL)                             \
+            rb_raise(rb_eRuntimeError, "filenames destroyed"); \
+        Data_Get_Struct(obj, notmuch_filenames_t, ptr);        \
+    } while(0)
+
+#define Data_Get_Notmuch_Query(obj, ptr)                   \
+    do {                                                   \
+        Check_Type(obj, T_DATA);                           \
+        if (DATA_PTR(obj) == NULL)                         \
+            rb_raise(rb_eRuntimeError, "query destroyed"); \
+        Data_Get_Struct(obj, notmuch_query_t, ptr);        \
+    } while(0)
+
+#define Data_Get_Notmuch_Threads(obj, ptr)                   \
+    do {                                                     \
+        Check_Type(obj, T_DATA);                             \
+        if (DATA_PTR(obj) == NULL)                           \
+            rb_raise(rb_eRuntimeError, "threads destroyed"); \
+        Data_Get_Struct(obj, notmuch_threads_t, ptr);        \
+    } while(0)
+
+#define Data_Get_Notmuch_Messages(obj, ptr)                   \
+    do {                                                      \
+        Check_Type(obj, T_DATA);                              \
+        if (DATA_PTR(obj) == NULL)                            \
+            rb_raise(rb_eRuntimeError, "messages destroyed"); \
+        Data_Get_Struct(obj, notmuch_messages_t, ptr);        \
+    } while(0)
+
+#define Data_Get_Notmuch_Thread(obj, ptr)                   \
+    do {                                                    \
+        Check_Type(obj, T_DATA);                            \
+        if (DATA_PTR(obj) == NULL)                          \
+            rb_raise(rb_eRuntimeError, "thread destroyed"); \
+        Data_Get_Struct(obj, notmuch_thread_t, ptr);        \
+    } while(0)
+
+#define Data_Get_Notmuch_Message(obj, ptr)                   \
+    do {                                                     \
+        Check_Type(obj, T_DATA);                             \
+        if (DATA_PTR(obj) == NULL)                           \
+            rb_raise(rb_eRuntimeError, "message destroyed"); \
+        Data_Get_Struct(obj, notmuch_message_t, ptr);        \
+    } while(0)
+
+#define Data_Get_Notmuch_Tags(obj, ptr)                   \
+    do {                                                  \
+        Check_Type(obj, T_DATA);                          \
+        if (DATA_PTR(obj) == NULL)                        \
+            rb_raise(rb_eRuntimeError, "tags destroyed"); \
+        Data_Get_Struct(obj, notmuch_tags_t, ptr);        \
+    } while(0)
+
 /* status.c */
 void
 notmuch_rb_status_raise(notmuch_status_t status);
 
 /* database.c */
 VALUE
-notmuch_rb_database_new(int argc, VALUE *argv, VALUE klass);
+notmuch_rb_database_alloc(VALUE klass);
+
+VALUE
+notmuch_rb_database_initialize(int argc, VALUE *argv, VALUE klass);
+
+VALUE
+notmuch_rb_database_open(int argc, VALUE *argv, VALUE klass);
 
 VALUE
 notmuch_rb_database_close(VALUE self);
@@ -72,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);
 
@@ -111,9 +195,15 @@ notmuch_rb_filenames_each(VALUE self);
 VALUE
 notmuch_rb_query_destroy(VALUE self);
 
+VALUE
+notmuch_rb_query_get_sort(VALUE self);
+
 VALUE
 notmuch_rb_query_set_sort(VALUE self, VALUE sortv);
 
+VALUE
+notmuch_rb_query_get_string(VALUE self);
+
 VALUE
 notmuch_rb_query_search_threads(VALUE self);
 
@@ -184,6 +274,9 @@ notmuch_rb_message_get_replies(VALUE self);
 VALUE
 notmuch_rb_message_get_filename(VALUE self);
 
+VALUE
+notmuch_rb_message_get_filenames(VALUE self);
+
 VALUE
 notmuch_rb_message_get_flag(VALUE self, VALUE flagv);
 
@@ -208,6 +301,12 @@ notmuch_rb_message_remove_tag(VALUE self, VALUE tagv);
 VALUE
 notmuch_rb_message_remove_all_tags(VALUE self);
 
+VALUE
+notmuch_rb_message_maildir_flags_to_tags(VALUE self);
+
+VALUE
+notmuch_rb_message_tags_to_maildir_flags(VALUE self);
+
 VALUE
 notmuch_rb_message_freeze(VALUE self);