X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=bindings%2Fruby%2Fdefs.h;h=1f5298838ac73df389d11043d9aac16249caf6ba;hp=1973d26e8c0a3805a2d6e905af549926856d6139;hb=02369d031c1499e015db1736bd259d314d39b8cf;hpb=06bf04500ba282052d38adf428219968ae62bb54 diff --git a/bindings/ruby/defs.h b/bindings/ruby/defs.h index 1973d26e..1f529883 100644 --- a/bindings/ruby/defs.h +++ b/bindings/ruby/defs.h @@ -49,109 +49,91 @@ ID ID_call; ID ID_db_create; ID ID_db_mode; -typedef struct { - notmuch_database_t *nm_db; -} notmuch_rb_database_t; - -typedef struct { - notmuch_directory_t *nm_dir; - VALUE db; -} notmuch_rb_directory_t; - -typedef struct { - notmuch_filenames_t *nm_flist; - VALUE dir; -} notmuch_rb_filenames_t; - -typedef struct { - notmuch_query_t *nm_query; - VALUE db; -} notmuch_rb_query_t; - -typedef struct { - notmuch_threads_t *nm_threads; - VALUE query; -} notmuch_rb_threads_t; - -typedef struct { - notmuch_messages_t *nm_messages; - VALUE parent; -} notmuch_rb_messages_t; - -typedef struct { - notmuch_thread_t *nm_thread; - VALUE threads; -} notmuch_rb_thread_t; - -typedef struct { - notmuch_message_t *nm_message; - VALUE parent; -} notmuch_rb_message_t; - -typedef struct { - notmuch_tags_t *nm_tags; - VALUE parent; -} notmuch_rb_tags_t; +#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); -/* gc.c */ -void -notmuch_rb_database_free(notmuch_rb_database_t *db); - -void -notmuch_rb_directory_mark(notmuch_rb_directory_t *dir); - -void -notmuch_rb_directory_free(notmuch_rb_directory_t *dir); - -void -notmuch_rb_filenames_mark(notmuch_rb_filenames_t *flist); - -void -notmuch_rb_filenames_free(notmuch_rb_filenames_t *flist); - -void -notmuch_rb_query_mark(notmuch_rb_query_t *query); - -void -notmuch_rb_query_free(notmuch_rb_query_t *query); - -void -notmuch_rb_threads_mark(notmuch_rb_threads_t *threads); - -void -notmuch_rb_threads_free(notmuch_rb_threads_t *threads); - -void -notmuch_rb_messages_mark(notmuch_rb_messages_t *messages); - -void -notmuch_rb_messages_free(notmuch_rb_messages_t *messages); - -void -notmuch_rb_thread_mark(notmuch_rb_thread_t *thread); - -void -notmuch_rb_thread_free(notmuch_rb_thread_t *thread); - -void -notmuch_rb_message_mark(notmuch_rb_message_t *message); - -void -notmuch_rb_message_free(notmuch_rb_message_t *message); - -void -notmuch_rb_tags_mark(notmuch_rb_tags_t *tags); +/* database.c */ +VALUE +notmuch_rb_database_alloc(VALUE klass); -void -notmuch_rb_tags_free(notmuch_rb_tags_t *tags); +VALUE +notmuch_rb_database_initialize(int argc, VALUE *argv, VALUE klass); -/* database.c */ VALUE -notmuch_rb_database_new(int argc, VALUE *argv, VALUE klass); +notmuch_rb_database_open(int argc, VALUE *argv, VALUE klass); VALUE notmuch_rb_database_close(VALUE self); @@ -181,6 +163,9 @@ VALUE notmuch_rb_database_query_create(VALUE self, VALUE qstrv); /* directory.c */ +VALUE +notmuch_rb_directory_destroy(VALUE self); + VALUE notmuch_rb_directory_get_mtime(VALUE self); @@ -194,13 +179,25 @@ VALUE notmuch_rb_directory_get_child_directories(VALUE self); /* filenames.c */ +VALUE +notmuch_rb_filenames_destroy(VALUE self); + VALUE notmuch_rb_filenames_each(VALUE self); /* query.c */ +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); @@ -208,10 +205,16 @@ VALUE notmuch_rb_query_search_messages(VALUE self); /* threads.c */ +VALUE +notmuch_rb_threads_destroy(VALUE self); + VALUE notmuch_rb_threads_each(VALUE self); /* messages.c */ +VALUE +notmuch_rb_messages_destroy(VALUE self); + VALUE notmuch_rb_messages_each(VALUE self); @@ -219,6 +222,9 @@ VALUE notmuch_rb_messages_collect_tags(VALUE self); /* thread.c */ +VALUE +notmuch_rb_thread_destroy(VALUE self); + VALUE notmuch_rb_thread_get_thread_id(VALUE self); @@ -247,6 +253,9 @@ VALUE notmuch_rb_thread_get_tags(VALUE self); /* message.c */ +VALUE +notmuch_rb_message_destroy(VALUE self); + VALUE notmuch_rb_message_get_message_id(VALUE self); @@ -283,6 +292,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); @@ -290,6 +305,9 @@ VALUE notmuch_rb_message_thaw(VALUE self); /* tags.c */ +VALUE +notmuch_rb_tags_destroy(VALUE self); + VALUE notmuch_rb_tags_each(VALUE self);