/* TagTable.c generated by valac 0.32.1, the Vala compiler * generated from TagTable.vala, do not modify */ /* Copyright 2016 Software Freedom Conservancy Inc. * * This software is licensed under the GNU Lesser General Public License * (version 2.1 or later). See the COPYING file in this distribution. */ #include #include #include #include #include #include #include #include #define TYPE_TAG_ID (tag_id_get_type ()) typedef struct _TagID TagID; #define TYPE_TAG_ROW (tag_row_get_type ()) #define TAG_ROW(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_TAG_ROW, TagRow)) #define TAG_ROW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_TAG_ROW, TagRowClass)) #define IS_TAG_ROW(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_TAG_ROW)) #define IS_TAG_ROW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_TAG_ROW)) #define TAG_ROW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_TAG_ROW, TagRowClass)) typedef struct _TagRow TagRow; typedef struct _TagRowClass TagRowClass; typedef struct _TagRowPrivate TagRowPrivate; #define _g_free0(var) (var = (g_free (var), NULL)) #define _g_object_unref0(var) ((var == NULL) ? NULL : (var = (g_object_unref (var), NULL))) typedef struct _ParamSpecTagRow ParamSpecTagRow; #define TYPE_DATABASE_TABLE (database_table_get_type ()) #define DATABASE_TABLE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_DATABASE_TABLE, DatabaseTable)) #define DATABASE_TABLE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_DATABASE_TABLE, DatabaseTableClass)) #define IS_DATABASE_TABLE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_DATABASE_TABLE)) #define IS_DATABASE_TABLE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_DATABASE_TABLE)) #define DATABASE_TABLE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_DATABASE_TABLE, DatabaseTableClass)) typedef struct _DatabaseTable DatabaseTable; typedef struct _DatabaseTableClass DatabaseTableClass; typedef struct _DatabaseTablePrivate DatabaseTablePrivate; #define TYPE_TAG_TABLE (tag_table_get_type ()) #define TAG_TABLE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_TAG_TABLE, TagTable)) #define TAG_TABLE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_TAG_TABLE, TagTableClass)) #define IS_TAG_TABLE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_TAG_TABLE)) #define IS_TAG_TABLE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_TAG_TABLE)) #define TAG_TABLE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_TAG_TABLE, TagTableClass)) typedef struct _TagTable TagTable; typedef struct _TagTableClass TagTableClass; typedef struct _TagTablePrivate TagTablePrivate; #define _sqlite3_finalize0(var) ((var == NULL) ? NULL : (var = (sqlite3_finalize (var), NULL))) #define _database_table_unref0(var) ((var == NULL) ? NULL : (var = (database_table_unref (var), NULL))) #define _g_regex_unref0(var) ((var == NULL) ? NULL : (var = (g_regex_unref (var), NULL))) #define _g_error_free0(var) ((var == NULL) ? NULL : (var = (g_error_free (var), NULL))) #define _tag_row_unref0(var) ((var == NULL) ? NULL : (var = (tag_row_unref (var), NULL))) #define _g_string_free0(var) ((var == NULL) ? NULL : (var = (g_string_free (var, TRUE), NULL))) #define TYPE_PHOTO_ID (photo_id_get_type ()) typedef struct _PhotoID PhotoID; #define _vala_assert(expr, msg) if G_LIKELY (expr) ; else g_assertion_message_expr (G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC, msg); #define _vala_return_if_fail(expr, msg) if G_LIKELY (expr) ; else { g_return_if_fail_warning (G_LOG_DOMAIN, G_STRFUNC, msg); return; } #define _vala_return_val_if_fail(expr, msg, val) if G_LIKELY (expr) ; else { g_return_if_fail_warning (G_LOG_DOMAIN, G_STRFUNC, msg); return val; } #define _vala_warn_if_fail(expr, msg) if G_LIKELY (expr) ; else g_warn_message (G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC, msg); struct _TagID { gint64 id; }; struct _TagRow { GTypeInstance parent_instance; volatile int ref_count; TagRowPrivate * priv; TagID tag_id; gchar* name; GeeSet* source_id_list; time_t time_created; }; struct _TagRowClass { GTypeClass parent_class; void (*finalize) (TagRow *self); }; struct _ParamSpecTagRow { GParamSpec parent_instance; }; struct _DatabaseTable { GTypeInstance parent_instance; volatile int ref_count; DatabaseTablePrivate * priv; gchar* table_name; }; struct _DatabaseTableClass { GTypeClass parent_class; void (*finalize) (DatabaseTable *self); }; struct _TagTable { DatabaseTable parent_instance; TagTablePrivate * priv; }; struct _TagTableClass { DatabaseTableClass parent_class; }; typedef enum { DATABASE_ERROR_ERROR, DATABASE_ERROR_BACKING, DATABASE_ERROR_MEMORY, DATABASE_ERROR_ABORT, DATABASE_ERROR_LIMITS, DATABASE_ERROR_TYPESPEC } DatabaseError; #define DATABASE_ERROR database_error_quark () struct _PhotoID { gint64 id; }; static gpointer tag_row_parent_class = NULL; static gpointer tag_table_parent_class = NULL; static TagTable* tag_table_instance; static TagTable* tag_table_instance = NULL; extern sqlite3* database_table_db; GType tag_id_get_type (void) G_GNUC_CONST; TagID* tag_id_dup (const TagID* self); void tag_id_free (TagID* self); #define TAG_ID_INVALID ((gint64) -1) void tag_id_init (TagID *self, gint64 id); gboolean tag_id_is_invalid (TagID *self); gboolean tag_id_is_valid (TagID *self); gpointer tag_row_ref (gpointer instance); void tag_row_unref (gpointer instance); GParamSpec* param_spec_tag_row (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags); void value_set_tag_row (GValue* value, gpointer v_object); void value_take_tag_row (GValue* value, gpointer v_object); gpointer value_get_tag_row (const GValue* value); GType tag_row_get_type (void) G_GNUC_CONST; enum { TAG_ROW_DUMMY_PROPERTY }; TagRow* tag_row_new (void); TagRow* tag_row_construct (GType object_type); static void tag_row_finalize (TagRow* obj); gpointer database_table_ref (gpointer instance); void database_table_unref (gpointer instance); GParamSpec* param_spec_database_table (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags); void value_set_database_table (GValue* value, gpointer v_object); void value_take_database_table (GValue* value, gpointer v_object); gpointer value_get_database_table (const GValue* value); GType database_table_get_type (void) G_GNUC_CONST; GType tag_table_get_type (void) G_GNUC_CONST; enum { TAG_TABLE_DUMMY_PROPERTY }; static TagTable* tag_table_new (void); static TagTable* tag_table_construct (GType object_type); DatabaseTable* database_table_construct (GType object_type); void database_table_set_table_name (DatabaseTable* self, const gchar* table_name); void database_table_fatal (const gchar* op, gint res); TagTable* tag_table_get_instance (void); void tag_table_upgrade_for_htags (void); GQuark database_error_quark (void); GeeList* tag_table_get_all_rows (TagTable* self, GError** error); #define TAG_PATH_SEPARATOR_STRING "/" void tag_table_rename (TagTable* self, TagID* tag_id, const gchar* new_name, GError** error); TagRow* tag_table_add (TagTable* self, const gchar* name, GError** error); gulong now_sec (void); void database_table_throw_error (const gchar* method, gint res, GError** error); void tag_table_create_from_row (TagTable* self, TagRow* row, TagID* result, GError** error); static gchar* tag_table_serialize_source_ids (TagTable* self, GeeCollection* source_ids); void tag_table_remove (TagTable* self, TagID* tag_id, GError** error); void database_table_delete_by_id (DatabaseTable* self, gint64 id, GError** error); gchar* tag_table_get_name (TagTable* self, TagID* tag_id, GError** error); gboolean database_table_select_by_id (DatabaseTable* self, gint64 id, const gchar* columns, sqlite3_stmt** stmt); TagRow* tag_table_get_row (TagTable* self, TagID* tag_id, GError** error); static GeeSet* tag_table_unserialize_source_ids (TagTable* self, const gchar* text_list); void database_table_update_text_by_id_2 (DatabaseTable* self, gint64 id, const gchar* column, const gchar* text, GError** error); void tag_table_set_tagged_sources (TagTable* self, TagID* tag_id, GeeCollection* source_ids, GError** error); gboolean is_string_empty (const gchar* s); GType photo_id_get_type (void) G_GNUC_CONST; PhotoID* photo_id_dup (const PhotoID* self); void photo_id_free (PhotoID* self); gchar* photo_id_upgrade_photo_id_to_source_id (PhotoID* photo_id); gint64 parse_int64 (const gchar* str, gint num_base); void photo_id_init (PhotoID *self, gint64 id); static void tag_table_finalize (DatabaseTable* obj); static void _vala_array_destroy (gpointer array, gint array_length, GDestroyNotify destroy_func); static void _vala_array_free (gpointer array, gint array_length, GDestroyNotify destroy_func); static gint _vala_array_length (gpointer array); void tag_id_init (TagID *self, gint64 id) { gint64 _tmp0_ = 0LL; #line 12 "/home/jens/Source/shotwell/src/db/TagTable.vala" memset (self, 0, sizeof (TagID)); #line 13 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = id; #line 13 "/home/jens/Source/shotwell/src/db/TagTable.vala" (*self).id = _tmp0_; #line 213 "TagTable.c" } gboolean tag_id_is_invalid (TagID *self) { gboolean result = FALSE; gint64 _tmp0_ = 0LL; #line 17 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = (*self).id; #line 17 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = _tmp0_ == TAG_ID_INVALID; #line 17 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 226 "TagTable.c" } gboolean tag_id_is_valid (TagID *self) { gboolean result = FALSE; gint64 _tmp0_ = 0LL; #line 21 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = (*self).id; #line 21 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = _tmp0_ != TAG_ID_INVALID; #line 21 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 239 "TagTable.c" } TagID* tag_id_dup (const TagID* self) { TagID* dup; #line 7 "/home/jens/Source/shotwell/src/db/TagTable.vala" dup = g_new0 (TagID, 1); #line 7 "/home/jens/Source/shotwell/src/db/TagTable.vala" memcpy (dup, self, sizeof (TagID)); #line 7 "/home/jens/Source/shotwell/src/db/TagTable.vala" return dup; #line 251 "TagTable.c" } void tag_id_free (TagID* self) { #line 7 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_free (self); #line 258 "TagTable.c" } GType tag_id_get_type (void) { static volatile gsize tag_id_type_id__volatile = 0; if (g_once_init_enter (&tag_id_type_id__volatile)) { GType tag_id_type_id; tag_id_type_id = g_boxed_type_register_static ("TagID", (GBoxedCopyFunc) tag_id_dup, (GBoxedFreeFunc) tag_id_free); g_once_init_leave (&tag_id_type_id__volatile, tag_id_type_id); } return tag_id_type_id__volatile; } TagRow* tag_row_construct (GType object_type) { TagRow* self = NULL; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" self = (TagRow*) g_type_create_instance (object_type); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return self; #line 279 "TagTable.c" } TagRow* tag_row_new (void) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return tag_row_construct (TYPE_TAG_ROW); #line 286 "TagTable.c" } static void value_tag_row_init (GValue* value) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" value->data[0].v_pointer = NULL; #line 293 "TagTable.c" } static void value_tag_row_free_value (GValue* value) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (value->data[0].v_pointer) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_row_unref (value->data[0].v_pointer); #line 302 "TagTable.c" } } static void value_tag_row_copy_value (const GValue* src_value, GValue* dest_value) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (src_value->data[0].v_pointer) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" dest_value->data[0].v_pointer = tag_row_ref (src_value->data[0].v_pointer); #line 312 "TagTable.c" } else { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" dest_value->data[0].v_pointer = NULL; #line 316 "TagTable.c" } } static gpointer value_tag_row_peek_pointer (const GValue* value) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return value->data[0].v_pointer; #line 324 "TagTable.c" } static gchar* value_tag_row_collect_value (GValue* value, guint n_collect_values, GTypeCValue* collect_values, guint collect_flags) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (collect_values[0].v_pointer) { #line 331 "TagTable.c" TagRow* object; object = collect_values[0].v_pointer; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (object->parent_instance.g_class == NULL) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return g_strconcat ("invalid unclassed object pointer for value type `", G_VALUE_TYPE_NAME (value), "'", NULL); #line 338 "TagTable.c" } else if (!g_value_type_compatible (G_TYPE_FROM_INSTANCE (object), G_VALUE_TYPE (value))) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return g_strconcat ("invalid object type `", g_type_name (G_TYPE_FROM_INSTANCE (object)), "' for value type `", G_VALUE_TYPE_NAME (value), "'", NULL); #line 342 "TagTable.c" } #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" value->data[0].v_pointer = tag_row_ref (object); #line 346 "TagTable.c" } else { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" value->data[0].v_pointer = NULL; #line 350 "TagTable.c" } #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 354 "TagTable.c" } static gchar* value_tag_row_lcopy_value (const GValue* value, guint n_collect_values, GTypeCValue* collect_values, guint collect_flags) { TagRow** object_p; object_p = collect_values[0].v_pointer; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (!object_p) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return g_strdup_printf ("value location for `%s' passed as NULL", G_VALUE_TYPE_NAME (value)); #line 365 "TagTable.c" } #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (!value->data[0].v_pointer) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" *object_p = NULL; #line 371 "TagTable.c" } else if (collect_flags & G_VALUE_NOCOPY_CONTENTS) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" *object_p = value->data[0].v_pointer; #line 375 "TagTable.c" } else { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" *object_p = tag_row_ref (value->data[0].v_pointer); #line 379 "TagTable.c" } #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 383 "TagTable.c" } GParamSpec* param_spec_tag_row (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags) { ParamSpecTagRow* spec; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (g_type_is_a (object_type, TYPE_TAG_ROW), NULL); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" spec = g_param_spec_internal (G_TYPE_PARAM_OBJECT, name, nick, blurb, flags); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" G_PARAM_SPEC (spec)->value_type = object_type; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return G_PARAM_SPEC (spec); #line 397 "TagTable.c" } gpointer value_get_tag_row (const GValue* value) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_TAG_ROW), NULL); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return value->data[0].v_pointer; #line 406 "TagTable.c" } void value_set_tag_row (GValue* value, gpointer v_object) { TagRow* old; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_TAG_ROW)); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" old = value->data[0].v_pointer; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (v_object) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (G_TYPE_CHECK_INSTANCE_TYPE (v_object, TYPE_TAG_ROW)); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (g_value_type_compatible (G_TYPE_FROM_INSTANCE (v_object), G_VALUE_TYPE (value))); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" value->data[0].v_pointer = v_object; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_row_ref (value->data[0].v_pointer); #line 426 "TagTable.c" } else { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" value->data[0].v_pointer = NULL; #line 430 "TagTable.c" } #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (old) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_row_unref (old); #line 436 "TagTable.c" } } void value_take_tag_row (GValue* value, gpointer v_object) { TagRow* old; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (G_TYPE_CHECK_VALUE_TYPE (value, TYPE_TAG_ROW)); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" old = value->data[0].v_pointer; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (v_object) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (G_TYPE_CHECK_INSTANCE_TYPE (v_object, TYPE_TAG_ROW)); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (g_value_type_compatible (G_TYPE_FROM_INSTANCE (v_object), G_VALUE_TYPE (value))); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" value->data[0].v_pointer = v_object; #line 455 "TagTable.c" } else { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" value->data[0].v_pointer = NULL; #line 459 "TagTable.c" } #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (old) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_row_unref (old); #line 465 "TagTable.c" } } static void tag_row_class_init (TagRowClass * klass) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_row_parent_class = g_type_class_peek_parent (klass); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" ((TagRowClass *) klass)->finalize = tag_row_finalize; #line 475 "TagTable.c" } static void tag_row_instance_init (TagRow * self) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" self->ref_count = 1; #line 482 "TagTable.c" } static void tag_row_finalize (TagRow* obj) { TagRow * self; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" self = G_TYPE_CHECK_INSTANCE_CAST (obj, TYPE_TAG_ROW, TagRow); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_signal_handlers_destroy (self); #line 27 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (self->name); #line 28 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (self->source_id_list); #line 496 "TagTable.c" } GType tag_row_get_type (void) { static volatile gsize tag_row_type_id__volatile = 0; if (g_once_init_enter (&tag_row_type_id__volatile)) { static const GTypeValueTable g_define_type_value_table = { value_tag_row_init, value_tag_row_free_value, value_tag_row_copy_value, value_tag_row_peek_pointer, "p", value_tag_row_collect_value, "p", value_tag_row_lcopy_value }; static const GTypeInfo g_define_type_info = { sizeof (TagRowClass), (GBaseInitFunc) NULL, (GBaseFinalizeFunc) NULL, (GClassInitFunc) tag_row_class_init, (GClassFinalizeFunc) NULL, NULL, sizeof (TagRow), 0, (GInstanceInitFunc) tag_row_instance_init, &g_define_type_value_table }; static const GTypeFundamentalInfo g_define_type_fundamental_info = { (G_TYPE_FLAG_CLASSED | G_TYPE_FLAG_INSTANTIATABLE | G_TYPE_FLAG_DERIVABLE | G_TYPE_FLAG_DEEP_DERIVABLE) }; GType tag_row_type_id; tag_row_type_id = g_type_register_fundamental (g_type_fundamental_next (), "TagRow", &g_define_type_info, &g_define_type_fundamental_info, 0); g_once_init_leave (&tag_row_type_id__volatile, tag_row_type_id); } return tag_row_type_id__volatile; } gpointer tag_row_ref (gpointer instance) { TagRow* self; self = instance; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_atomic_int_inc (&self->ref_count); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" return instance; #line 521 "TagTable.c" } void tag_row_unref (gpointer instance) { TagRow* self; self = instance; #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (g_atomic_int_dec_and_test (&self->ref_count)) { #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" TAG_ROW_GET_CLASS (self)->finalize (self); #line 25 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_type_free_instance ((GTypeInstance *) self); #line 534 "TagTable.c" } } static TagTable* tag_table_construct (GType object_type) { TagTable* self = NULL; sqlite3_stmt* stmt = NULL; gint res = 0; sqlite3* _tmp0_ = NULL; sqlite3_stmt* _tmp1_ = NULL; gint _tmp2_ = 0; gint _tmp3_ = 0; sqlite3_stmt* _tmp4_ = NULL; gint _tmp5_ = 0; gint _tmp6_ = 0; #line 35 "/home/jens/Source/shotwell/src/db/TagTable.vala" self = (TagTable*) database_table_construct (object_type); #line 36 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_set_table_name (G_TYPE_CHECK_INSTANCE_CAST (self, TYPE_DATABASE_TABLE, DatabaseTable), "TagTable"); #line 39 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = database_table_db; #line 39 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = sqlite3_prepare_v2 (_tmp0_, "CREATE TABLE IF NOT EXISTS " "TagTable " "(" "id INTEGER PRIMARY KEY, " "name TEXT UNIQUE NOT NULL, " "photo_id_list TEXT, " "time_created INTEGER" ")", -1, &_tmp1_, NULL); #line 39 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 39 "/home/jens/Source/shotwell/src/db/TagTable.vala" stmt = _tmp1_; #line 39 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp2_; #line 47 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = res; #line 47 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp3_ == SQLITE_OK, "res == Sqlite.OK"); #line 49 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = stmt; #line 49 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = sqlite3_step (_tmp4_); #line 49 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp5_; #line 50 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = res; #line 50 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp6_ != SQLITE_DONE) { #line 578 "TagTable.c" gint _tmp7_ = 0; #line 51 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = res; #line 51 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_fatal ("create TagTable", _tmp7_); #line 584 "TagTable.c" } #line 35 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 35 "/home/jens/Source/shotwell/src/db/TagTable.vala" return self; #line 590 "TagTable.c" } static TagTable* tag_table_new (void) { #line 35 "/home/jens/Source/shotwell/src/db/TagTable.vala" return tag_table_construct (TYPE_TAG_TABLE); #line 597 "TagTable.c" } static gpointer _database_table_ref0 (gpointer self) { #line 58 "/home/jens/Source/shotwell/src/db/TagTable.vala" return self ? database_table_ref (self) : NULL; #line 604 "TagTable.c" } TagTable* tag_table_get_instance (void) { TagTable* result = NULL; TagTable* _tmp0_ = NULL; TagTable* _tmp2_ = NULL; TagTable* _tmp3_ = NULL; #line 55 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = tag_table_instance; #line 55 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp0_ == NULL) { #line 617 "TagTable.c" TagTable* _tmp1_ = NULL; #line 56 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp1_ = tag_table_new (); #line 56 "/home/jens/Source/shotwell/src/db/TagTable.vala" _database_table_unref0 (tag_table_instance); #line 56 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_table_instance = _tmp1_; #line 625 "TagTable.c" } #line 58 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = tag_table_instance; #line 58 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = _database_table_ref0 (_tmp2_); #line 58 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = _tmp3_; #line 58 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 635 "TagTable.c" } static gpointer _g_object_ref0 (gpointer self) { #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" return self ? g_object_ref (self) : NULL; #line 642 "TagTable.c" } static gchar* string_replace (const gchar* self, const gchar* old, const gchar* replacement) { gchar* result = NULL; GError * _inner_error_ = NULL; #line 1380 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_return_val_if_fail (self != NULL, NULL); #line 1380 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_return_val_if_fail (old != NULL, NULL); #line 1380 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_return_val_if_fail (replacement != NULL, NULL); #line 655 "TagTable.c" { GRegex* regex = NULL; const gchar* _tmp0_ = NULL; gchar* _tmp1_ = NULL; gchar* _tmp2_ = NULL; GRegex* _tmp3_ = NULL; GRegex* _tmp4_ = NULL; gchar* _tmp5_ = NULL; GRegex* _tmp6_ = NULL; const gchar* _tmp7_ = NULL; gchar* _tmp8_ = NULL; gchar* _tmp9_ = NULL; #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp0_ = old; #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp1_ = g_regex_escape_string (_tmp0_, -1); #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp2_ = _tmp1_; #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp3_ = g_regex_new (_tmp2_, 0, 0, &_inner_error_); #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp4_ = _tmp3_; #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _g_free0 (_tmp2_); #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" regex = _tmp4_; #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" if (_inner_error_->domain == G_REGEX_ERROR) { #line 686 "TagTable.c" goto __catch19_g_regex_error; } #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_critical ("file %s: line %d: unexpected error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_clear_error (&_inner_error_); #line 1382 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" return NULL; #line 695 "TagTable.c" } #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp6_ = regex; #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp7_ = replacement; #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp8_ = g_regex_replace_literal (_tmp6_, self, (gssize) -1, 0, _tmp7_, 0, &_inner_error_); #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp5_ = _tmp8_; #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _g_regex_unref0 (regex); #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" if (_inner_error_->domain == G_REGEX_ERROR) { #line 711 "TagTable.c" goto __catch19_g_regex_error; } #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _g_regex_unref0 (regex); #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_critical ("file %s: line %d: unexpected error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_clear_error (&_inner_error_); #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" return NULL; #line 722 "TagTable.c" } #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp9_ = _tmp5_; #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp5_ = NULL; #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" result = _tmp9_; #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _g_free0 (_tmp5_); #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _g_regex_unref0 (regex); #line 1383 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" return result; #line 736 "TagTable.c" } goto __finally19; __catch19_g_regex_error: { GError* e = NULL; #line 1381 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" e = _inner_error_; #line 1381 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _inner_error_ = NULL; #line 1385 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_assert_not_reached (); #line 1381 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _g_error_free0 (e); #line 750 "TagTable.c" } __finally19: #line 1381 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 1381 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 1381 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_clear_error (&_inner_error_); #line 1381 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" return NULL; #line 761 "TagTable.c" } } void tag_table_upgrade_for_htags (void) { TagTable* table = NULL; TagTable* _tmp0_ = NULL; GError * _inner_error_ = NULL; #line 62 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = tag_table_get_instance (); #line 62 "/home/jens/Source/shotwell/src/db/TagTable.vala" table = _tmp0_; #line 774 "TagTable.c" { GeeList* rows = NULL; TagTable* _tmp1_ = NULL; GeeList* _tmp2_ = NULL; #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp1_ = table; #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = tag_table_get_all_rows (_tmp1_, &_inner_error_); #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" rows = _tmp2_; #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 789 "TagTable.c" goto __catch18_database_error; } #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" _database_table_unref0 (table); #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: unexpected error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 65 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 800 "TagTable.c" } { GeeList* _row_list = NULL; GeeList* _tmp3_ = NULL; GeeList* _tmp4_ = NULL; gint _row_size = 0; GeeList* _tmp5_ = NULL; gint _tmp6_ = 0; gint _tmp7_ = 0; gint _row_index = 0; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = rows; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = _g_object_ref0 (_tmp3_); #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _row_list = _tmp4_; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = _row_list; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = gee_collection_get_size (G_TYPE_CHECK_INSTANCE_CAST (_tmp5_, GEE_TYPE_COLLECTION, GeeCollection)); #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = _tmp6_; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _row_size = _tmp7_; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _row_index = -1; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" while (TRUE) { #line 829 "TagTable.c" gint _tmp8_ = 0; gint _tmp9_ = 0; gint _tmp10_ = 0; TagRow* row = NULL; GeeList* _tmp11_ = NULL; gint _tmp12_ = 0; gpointer _tmp13_ = NULL; TagRow* _tmp14_ = NULL; TagRow* _tmp15_ = NULL; const gchar* _tmp16_ = NULL; gchar* _tmp17_ = NULL; TagTable* _tmp18_ = NULL; TagRow* _tmp19_ = NULL; TagID _tmp20_ = {0}; TagRow* _tmp21_ = NULL; const gchar* _tmp22_ = NULL; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = _row_index; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _row_index = _tmp8_ + 1; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = _row_index; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = _row_size; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (!(_tmp9_ < _tmp10_)) { #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" break; #line 858 "TagTable.c" } #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = _row_list; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = _row_index; #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = gee_list_get (_tmp11_, _tmp12_); #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" row = (TagRow*) _tmp13_; #line 68 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = row; #line 68 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_ = row; #line 68 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = _tmp15_->name; #line 68 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_ = string_replace (_tmp16_, TAG_PATH_SEPARATOR_STRING, "-"); #line 68 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (_tmp14_->name); #line 68 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_->name = _tmp17_; #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp18_ = table; #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp19_ = row; #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp20_ = _tmp19_->tag_id; #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp21_ = row; #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp22_ = _tmp21_->name; #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_table_rename (_tmp18_, &_tmp20_, _tmp22_, &_inner_error_); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tag_row_unref0 (row); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (_row_list); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (rows); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 902 "TagTable.c" goto __catch18_database_error; } #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tag_row_unref0 (row); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (_row_list); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (rows); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" _database_table_unref0 (table); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: unexpected error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 69 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 919 "TagTable.c" } #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tag_row_unref0 (row); #line 923 "TagTable.c" } #line 67 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (_row_list); #line 927 "TagTable.c" } #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (rows); #line 931 "TagTable.c" } goto __finally18; __catch18_database_error: { GError* e = NULL; const gchar* _tmp23_ = NULL; #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" e = _inner_error_; #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" _inner_error_ = NULL; #line 72 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp23_ = e->message; #line 72 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_error ("TagTable.vala:72: TagTable: can't upgrade tag names for hierarchical t" \ "ag support: %s", _tmp23_); #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_error_free0 (e); #line 948 "TagTable.c" } __finally18: #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" _database_table_unref0 (table); #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 64 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 961 "TagTable.c" } #line 61 "/home/jens/Source/shotwell/src/db/TagTable.vala" _database_table_unref0 (table); #line 965 "TagTable.c" } TagRow* tag_table_add (TagTable* self, const gchar* name, GError** error) { TagRow* result = NULL; sqlite3_stmt* stmt = NULL; gint res = 0; sqlite3* _tmp0_ = NULL; sqlite3_stmt* _tmp1_ = NULL; gint _tmp2_ = 0; gint _tmp3_ = 0; time_t time_created = 0; gulong _tmp4_ = 0UL; sqlite3_stmt* _tmp5_ = NULL; const gchar* _tmp6_ = NULL; gchar* _tmp7_ = NULL; GDestroyNotify _tmp8_ = NULL; gint _tmp9_ = 0; gint _tmp10_ = 0; sqlite3_stmt* _tmp11_ = NULL; time_t _tmp12_ = 0; gint _tmp13_ = 0; gint _tmp14_ = 0; sqlite3_stmt* _tmp15_ = NULL; gint _tmp16_ = 0; gint _tmp17_ = 0; TagRow* row = NULL; TagRow* _tmp19_ = NULL; TagRow* _tmp20_ = NULL; sqlite3* _tmp21_ = NULL; gint64 _tmp22_ = 0LL; TagRow* _tmp23_ = NULL; const gchar* _tmp24_ = NULL; gchar* _tmp25_ = NULL; TagRow* _tmp26_ = NULL; TagRow* _tmp27_ = NULL; time_t _tmp28_ = 0; GError * _inner_error_ = NULL; #line 76 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (IS_TAG_TABLE (self), NULL); #line 76 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (name != NULL, NULL); #line 78 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = database_table_db; #line 78 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = sqlite3_prepare_v2 (_tmp0_, "INSERT INTO TagTable (name, time_created) VALUES (?, ?)", -1, &_tmp1_, NULL); #line 78 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 78 "/home/jens/Source/shotwell/src/db/TagTable.vala" stmt = _tmp1_; #line 78 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp2_; #line 80 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = res; #line 80 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp3_ == SQLITE_OK, "res == Sqlite.OK"); #line 82 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = now_sec (); #line 82 "/home/jens/Source/shotwell/src/db/TagTable.vala" time_created = (time_t) _tmp4_; #line 84 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = stmt; #line 84 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = name; #line 84 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = g_strdup (_tmp6_); #line 84 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = g_free; #line 84 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = sqlite3_bind_text (_tmp5_, 1, _tmp7_, -1, _tmp8_); #line 84 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp9_; #line 85 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = res; #line 85 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp10_ == SQLITE_OK, "res == Sqlite.OK"); #line 86 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = stmt; #line 86 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = time_created; #line 86 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = sqlite3_bind_int64 (_tmp11_, 2, (gint64) _tmp12_); #line 86 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp13_; #line 87 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = res; #line 87 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp14_ == SQLITE_OK, "res == Sqlite.OK"); #line 89 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_ = stmt; #line 89 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = sqlite3_step (_tmp15_); #line 89 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp16_; #line 90 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_ = res; #line 90 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp17_ != SQLITE_DONE) { #line 1064 "TagTable.c" gint _tmp18_ = 0; #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp18_ = res; #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_throw_error ("TagTable.add", _tmp18_, &_inner_error_); #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_propagate_error (error, _inner_error_); #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 1080 "TagTable.c" } else { #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 91 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 1090 "TagTable.c" } } } #line 93 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp19_ = tag_row_new (); #line 93 "/home/jens/Source/shotwell/src/db/TagTable.vala" row = _tmp19_; #line 94 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp20_ = row; #line 94 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp21_ = database_table_db; #line 94 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp22_ = sqlite3_last_insert_rowid (_tmp21_); #line 94 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_id_init (&_tmp20_->tag_id, _tmp22_); #line 95 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp23_ = row; #line 95 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp24_ = name; #line 95 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp25_ = g_strdup (_tmp24_); #line 95 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (_tmp23_->name); #line 95 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp23_->name = _tmp25_; #line 96 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp26_ = row; #line 96 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (_tmp26_->source_id_list); #line 96 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp26_->source_id_list = NULL; #line 97 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp27_ = row; #line 97 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp28_ = time_created; #line 97 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp27_->time_created = _tmp28_; #line 99 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = row; #line 99 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 99 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 1134 "TagTable.c" } void tag_table_create_from_row (TagTable* self, TagRow* row, TagID* result, GError** error) { sqlite3_stmt* stmt = NULL; gint res = 0; sqlite3* _tmp0_ = NULL; sqlite3_stmt* _tmp1_ = NULL; gint _tmp2_ = 0; gint _tmp3_ = 0; sqlite3_stmt* _tmp4_ = NULL; TagRow* _tmp5_ = NULL; const gchar* _tmp6_ = NULL; gchar* _tmp7_ = NULL; GDestroyNotify _tmp8_ = NULL; gint _tmp9_ = 0; gint _tmp10_ = 0; sqlite3_stmt* _tmp11_ = NULL; TagRow* _tmp12_ = NULL; GeeSet* _tmp13_ = NULL; gchar* _tmp14_ = NULL; GDestroyNotify _tmp15_ = NULL; gint _tmp16_ = 0; gint _tmp17_ = 0; sqlite3_stmt* _tmp18_ = NULL; TagRow* _tmp19_ = NULL; time_t _tmp20_ = 0; gint _tmp21_ = 0; gint _tmp22_ = 0; sqlite3_stmt* _tmp23_ = NULL; gint _tmp24_ = 0; gint _tmp25_ = 0; sqlite3* _tmp27_ = NULL; gint64 _tmp28_ = 0LL; TagID _tmp29_ = {0}; GError * _inner_error_ = NULL; #line 103 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (IS_TAG_TABLE (self)); #line 103 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (IS_TAG_ROW (row)); #line 105 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = database_table_db; #line 105 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = sqlite3_prepare_v2 (_tmp0_, "INSERT INTO TagTable (name, photo_id_list, time_created) VALUES (?, ?," \ " ?)", -1, &_tmp1_, NULL); #line 105 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 105 "/home/jens/Source/shotwell/src/db/TagTable.vala" stmt = _tmp1_; #line 105 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp2_; #line 107 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = res; #line 107 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp3_ == SQLITE_OK, "res == Sqlite.OK"); #line 109 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = stmt; #line 109 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = row; #line 109 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = _tmp5_->name; #line 109 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = g_strdup (_tmp6_); #line 109 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = g_free; #line 109 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = sqlite3_bind_text (_tmp4_, 1, _tmp7_, -1, _tmp8_); #line 109 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp9_; #line 110 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = res; #line 110 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp10_ == SQLITE_OK, "res == Sqlite.OK"); #line 111 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = stmt; #line 111 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = row; #line 111 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = _tmp12_->source_id_list; #line 111 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = tag_table_serialize_source_ids (self, G_TYPE_CHECK_INSTANCE_CAST (_tmp13_, GEE_TYPE_COLLECTION, GeeCollection)); #line 111 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_ = g_free; #line 111 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = sqlite3_bind_text (_tmp11_, 2, _tmp14_, -1, _tmp15_); #line 111 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp16_; #line 112 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_ = res; #line 112 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp17_ == SQLITE_OK, "res == Sqlite.OK"); #line 113 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp18_ = stmt; #line 113 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp19_ = row; #line 113 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp20_ = _tmp19_->time_created; #line 113 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp21_ = sqlite3_bind_int64 (_tmp18_, 3, (gint64) _tmp20_); #line 113 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp21_; #line 114 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp22_ = res; #line 114 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp22_ == SQLITE_OK, "res == Sqlite.OK"); #line 116 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp23_ = stmt; #line 116 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp24_ = sqlite3_step (_tmp23_); #line 116 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp24_; #line 117 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp25_ = res; #line 117 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp25_ != SQLITE_DONE) { #line 1249 "TagTable.c" gint _tmp26_ = 0; #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp26_ = res; #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_throw_error ("TagTable.create_from_row", _tmp26_, &_inner_error_); #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_propagate_error (error, _inner_error_); #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1265 "TagTable.c" } else { #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 118 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1275 "TagTable.c" } } } #line 120 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp27_ = database_table_db; #line 120 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp28_ = sqlite3_last_insert_rowid (_tmp27_); #line 120 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_id_init (&_tmp29_, _tmp28_); #line 120 "/home/jens/Source/shotwell/src/db/TagTable.vala" *result = _tmp29_; #line 120 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 120 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1291 "TagTable.c" } void tag_table_remove (TagTable* self, TagID* tag_id, GError** error) { TagID _tmp0_ = {0}; gint64 _tmp1_ = 0LL; GError * _inner_error_ = NULL; #line 123 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (IS_TAG_TABLE (self)); #line 123 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (tag_id != NULL); #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = *tag_id; #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp1_ = _tmp0_.id; #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_delete_by_id (G_TYPE_CHECK_INSTANCE_CAST (self, TYPE_DATABASE_TABLE, DatabaseTable), _tmp1_, &_inner_error_); #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_propagate_error (error, _inner_error_); #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1317 "TagTable.c" } else { #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 124 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1325 "TagTable.c" } } } gchar* tag_table_get_name (TagTable* self, TagID* tag_id, GError** error) { gchar* result = NULL; sqlite3_stmt* stmt = NULL; TagID _tmp0_ = {0}; gint64 _tmp1_ = 0LL; sqlite3_stmt* _tmp2_ = NULL; gboolean _tmp3_ = FALSE; sqlite3_stmt* _tmp4_ = NULL; const gchar* _tmp5_ = NULL; gchar* _tmp6_ = NULL; #line 127 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (IS_TAG_TABLE (self), NULL); #line 127 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (tag_id != NULL, NULL); #line 129 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = *tag_id; #line 129 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp1_ = _tmp0_.id; #line 129 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = database_table_select_by_id (G_TYPE_CHECK_INSTANCE_CAST (self, TYPE_DATABASE_TABLE, DatabaseTable), _tmp1_, "name", &_tmp2_); #line 129 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 129 "/home/jens/Source/shotwell/src/db/TagTable.vala" stmt = _tmp2_; #line 129 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (!_tmp3_) { #line 130 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = NULL; #line 130 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 130 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 1363 "TagTable.c" } #line 132 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = stmt; #line 132 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = sqlite3_column_text (_tmp4_, 0); #line 132 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = g_strdup (_tmp5_); #line 132 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = _tmp6_; #line 132 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 132 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 1377 "TagTable.c" } TagRow* tag_table_get_row (TagTable* self, TagID* tag_id, GError** error) { TagRow* result = NULL; sqlite3_stmt* stmt = NULL; gint res = 0; sqlite3* _tmp0_ = NULL; sqlite3_stmt* _tmp1_ = NULL; gint _tmp2_ = 0; gint _tmp3_ = 0; sqlite3_stmt* _tmp4_ = NULL; TagID _tmp5_ = {0}; gint64 _tmp6_ = 0LL; gint _tmp7_ = 0; gint _tmp8_ = 0; sqlite3_stmt* _tmp9_ = NULL; gint _tmp10_ = 0; gint _tmp11_ = 0; TagRow* row = NULL; TagRow* _tmp14_ = NULL; TagRow* _tmp15_ = NULL; TagID _tmp16_ = {0}; TagRow* _tmp17_ = NULL; sqlite3_stmt* _tmp18_ = NULL; const gchar* _tmp19_ = NULL; gchar* _tmp20_ = NULL; TagRow* _tmp21_ = NULL; sqlite3_stmt* _tmp22_ = NULL; const gchar* _tmp23_ = NULL; GeeSet* _tmp24_ = NULL; TagRow* _tmp25_ = NULL; sqlite3_stmt* _tmp26_ = NULL; gint64 _tmp27_ = 0LL; GError * _inner_error_ = NULL; #line 135 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (IS_TAG_TABLE (self), NULL); #line 135 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (tag_id != NULL, NULL); #line 137 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = database_table_db; #line 137 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = sqlite3_prepare_v2 (_tmp0_, "SELECT name, photo_id_list, time_created FROM TagTable WHERE id=?", -1, &_tmp1_, NULL); #line 137 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 137 "/home/jens/Source/shotwell/src/db/TagTable.vala" stmt = _tmp1_; #line 137 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp2_; #line 139 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = res; #line 139 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp3_ == SQLITE_OK, "res == Sqlite.OK"); #line 141 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = stmt; #line 141 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = *tag_id; #line 141 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = _tmp5_.id; #line 141 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = sqlite3_bind_int64 (_tmp4_, 1, _tmp6_); #line 141 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp7_; #line 142 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = res; #line 142 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp8_ == SQLITE_OK, "res == Sqlite.OK"); #line 144 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = stmt; #line 144 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = sqlite3_step (_tmp9_); #line 144 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp10_; #line 145 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = res; #line 145 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp11_ == SQLITE_DONE) { #line 146 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = NULL; #line 146 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 146 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 1461 "TagTable.c" } else { gint _tmp12_ = 0; #line 147 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = res; #line 147 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp12_ != SQLITE_ROW) { #line 1468 "TagTable.c" gint _tmp13_ = 0; #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = res; #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_throw_error ("TagTable.get_row", _tmp13_, &_inner_error_); #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_propagate_error (error, _inner_error_); #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 1484 "TagTable.c" } else { #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 148 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 1494 "TagTable.c" } } } } #line 150 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = tag_row_new (); #line 150 "/home/jens/Source/shotwell/src/db/TagTable.vala" row = _tmp14_; #line 151 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_ = row; #line 151 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = *tag_id; #line 151 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_->tag_id = _tmp16_; #line 152 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_ = row; #line 152 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp18_ = stmt; #line 152 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp19_ = sqlite3_column_text (_tmp18_, 0); #line 152 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp20_ = g_strdup (_tmp19_); #line 152 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (_tmp17_->name); #line 152 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_->name = _tmp20_; #line 153 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp21_ = row; #line 153 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp22_ = stmt; #line 153 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp23_ = sqlite3_column_text (_tmp22_, 1); #line 153 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp24_ = tag_table_unserialize_source_ids (self, _tmp23_); #line 153 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (_tmp21_->source_id_list); #line 153 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp21_->source_id_list = _tmp24_; #line 154 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp25_ = row; #line 154 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp26_ = stmt; #line 154 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp27_ = sqlite3_column_int64 (_tmp26_, 2); #line 154 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp25_->time_created = (time_t) _tmp27_; #line 156 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = row; #line 156 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 156 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 1547 "TagTable.c" } GeeList* tag_table_get_all_rows (TagTable* self, GError** error) { GeeList* result = NULL; sqlite3_stmt* stmt = NULL; gint res = 0; sqlite3* _tmp0_ = NULL; sqlite3_stmt* _tmp1_ = NULL; gint _tmp2_ = 0; gint _tmp3_ = 0; GeeList* rows = NULL; GeeArrayList* _tmp4_ = NULL; GError * _inner_error_ = NULL; #line 159 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (IS_TAG_TABLE (self), NULL); #line 161 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = database_table_db; #line 161 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = sqlite3_prepare_v2 (_tmp0_, "SELECT id, name, photo_id_list, time_created FROM TagTable", -1, &_tmp1_, NULL); #line 161 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 161 "/home/jens/Source/shotwell/src/db/TagTable.vala" stmt = _tmp1_; #line 161 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp2_; #line 163 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = res; #line 163 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp3_ == SQLITE_OK, "res == Sqlite.OK"); #line 165 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = gee_array_list_new (TYPE_TAG_ROW, (GBoxedCopyFunc) tag_row_ref, tag_row_unref, NULL, NULL, NULL); #line 165 "/home/jens/Source/shotwell/src/db/TagTable.vala" rows = G_TYPE_CHECK_INSTANCE_CAST (_tmp4_, GEE_TYPE_LIST, GeeList); #line 1582 "TagTable.c" { gboolean _tmp5_ = FALSE; #line 167 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = TRUE; #line 167 "/home/jens/Source/shotwell/src/db/TagTable.vala" while (TRUE) { #line 1589 "TagTable.c" sqlite3_stmt* _tmp6_ = NULL; gint _tmp7_ = 0; gint _tmp8_ = 0; TagRow* row = NULL; TagRow* _tmp11_ = NULL; TagRow* _tmp12_ = NULL; sqlite3_stmt* _tmp13_ = NULL; gint64 _tmp14_ = 0LL; TagRow* _tmp15_ = NULL; sqlite3_stmt* _tmp16_ = NULL; const gchar* _tmp17_ = NULL; gchar* _tmp18_ = NULL; TagRow* _tmp19_ = NULL; sqlite3_stmt* _tmp20_ = NULL; const gchar* _tmp21_ = NULL; GeeSet* _tmp22_ = NULL; TagRow* _tmp23_ = NULL; sqlite3_stmt* _tmp24_ = NULL; gint64 _tmp25_ = 0LL; GeeList* _tmp26_ = NULL; TagRow* _tmp27_ = NULL; #line 167 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (!_tmp5_) { #line 1613 "TagTable.c" } #line 167 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = FALSE; #line 168 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = stmt; #line 168 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = sqlite3_step (_tmp6_); #line 168 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp7_; #line 169 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = res; #line 169 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp8_ == SQLITE_DONE) { #line 170 "/home/jens/Source/shotwell/src/db/TagTable.vala" break; #line 1629 "TagTable.c" } else { gint _tmp9_ = 0; #line 171 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = res; #line 171 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp9_ != SQLITE_ROW) { #line 1636 "TagTable.c" gint _tmp10_ = 0; #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = res; #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_throw_error ("TagTable.get_all_rows", _tmp10_, &_inner_error_); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_propagate_error (error, _inner_error_); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (rows); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 1654 "TagTable.c" } else { #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (rows); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 172 "/home/jens/Source/shotwell/src/db/TagTable.vala" return NULL; #line 1666 "TagTable.c" } } } } #line 175 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = tag_row_new (); #line 175 "/home/jens/Source/shotwell/src/db/TagTable.vala" row = _tmp11_; #line 176 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = row; #line 176 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = stmt; #line 176 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = sqlite3_column_int64 (_tmp13_, 0); #line 176 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_id_init (&_tmp12_->tag_id, _tmp14_); #line 177 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_ = row; #line 177 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = stmt; #line 177 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_ = sqlite3_column_text (_tmp16_, 1); #line 177 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp18_ = g_strdup (_tmp17_); #line 177 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (_tmp15_->name); #line 177 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_->name = _tmp18_; #line 178 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp19_ = row; #line 178 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp20_ = stmt; #line 178 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp21_ = sqlite3_column_text (_tmp20_, 2); #line 178 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp22_ = tag_table_unserialize_source_ids (self, _tmp21_); #line 178 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (_tmp19_->source_id_list); #line 178 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp19_->source_id_list = _tmp22_; #line 179 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp23_ = row; #line 179 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp24_ = stmt; #line 179 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp25_ = sqlite3_column_int64 (_tmp24_, 3); #line 179 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp23_->time_created = (time_t) _tmp25_; #line 181 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp26_ = rows; #line 181 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp27_ = row; #line 181 "/home/jens/Source/shotwell/src/db/TagTable.vala" gee_collection_add (G_TYPE_CHECK_INSTANCE_CAST (_tmp26_, GEE_TYPE_COLLECTION, GeeCollection), _tmp27_); #line 167 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tag_row_unref0 (row); #line 1723 "TagTable.c" } } #line 184 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = rows; #line 184 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 184 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 1732 "TagTable.c" } void tag_table_rename (TagTable* self, TagID* tag_id, const gchar* new_name, GError** error) { TagID _tmp0_ = {0}; gint64 _tmp1_ = 0LL; const gchar* _tmp2_ = NULL; GError * _inner_error_ = NULL; #line 187 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (IS_TAG_TABLE (self)); #line 187 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (tag_id != NULL); #line 187 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (new_name != NULL); #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = *tag_id; #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp1_ = _tmp0_.id; #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = new_name; #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_update_text_by_id_2 (G_TYPE_CHECK_INSTANCE_CAST (self, TYPE_DATABASE_TABLE, DatabaseTable), _tmp1_, "name", _tmp2_, &_inner_error_); #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_propagate_error (error, _inner_error_); #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1763 "TagTable.c" } else { #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 188 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1771 "TagTable.c" } } } void tag_table_set_tagged_sources (TagTable* self, TagID* tag_id, GeeCollection* source_ids, GError** error) { sqlite3_stmt* stmt = NULL; gint res = 0; sqlite3* _tmp0_ = NULL; sqlite3_stmt* _tmp1_ = NULL; gint _tmp2_ = 0; gint _tmp3_ = 0; sqlite3_stmt* _tmp4_ = NULL; GeeCollection* _tmp5_ = NULL; gchar* _tmp6_ = NULL; GDestroyNotify _tmp7_ = NULL; gint _tmp8_ = 0; gint _tmp9_ = 0; sqlite3_stmt* _tmp10_ = NULL; TagID _tmp11_ = {0}; gint64 _tmp12_ = 0LL; gint _tmp13_ = 0; gint _tmp14_ = 0; sqlite3_stmt* _tmp15_ = NULL; gint _tmp16_ = 0; gint _tmp17_ = 0; GError * _inner_error_ = NULL; #line 191 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (IS_TAG_TABLE (self)); #line 191 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (tag_id != NULL); #line 191 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_if_fail (GEE_IS_COLLECTION (source_ids)); #line 193 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = database_table_db; #line 193 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = sqlite3_prepare_v2 (_tmp0_, "UPDATE TagTable SET photo_id_list=? WHERE id=?", -1, &_tmp1_, NULL); #line 193 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 193 "/home/jens/Source/shotwell/src/db/TagTable.vala" stmt = _tmp1_; #line 193 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp2_; #line 194 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = res; #line 194 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp3_ == SQLITE_OK, "res == Sqlite.OK"); #line 196 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = stmt; #line 196 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = source_ids; #line 196 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = tag_table_serialize_source_ids (self, _tmp5_); #line 196 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = g_free; #line 196 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = sqlite3_bind_text (_tmp4_, 1, _tmp6_, -1, _tmp7_); #line 196 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp8_; #line 197 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = res; #line 197 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp9_ == SQLITE_OK, "res == Sqlite.OK"); #line 198 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = stmt; #line 198 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = *tag_id; #line 198 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = _tmp11_.id; #line 198 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = sqlite3_bind_int64 (_tmp10_, 2, _tmp12_); #line 198 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp13_; #line 199 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = res; #line 199 "/home/jens/Source/shotwell/src/db/TagTable.vala" _vala_assert (_tmp14_ == SQLITE_OK, "res == Sqlite.OK"); #line 201 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_ = stmt; #line 201 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = sqlite3_step (_tmp15_); #line 201 "/home/jens/Source/shotwell/src/db/TagTable.vala" res = _tmp16_; #line 202 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_ = res; #line 202 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp17_ != SQLITE_DONE) { #line 1859 "TagTable.c" gint _tmp18_ = 0; #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp18_ = res; #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" database_table_throw_error ("TagTable.set_tagged_photos", _tmp18_, &_inner_error_); #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (G_UNLIKELY (_inner_error_ != NULL)) { #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_inner_error_->domain == DATABASE_ERROR) { #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_propagate_error (error, _inner_error_); #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1875 "TagTable.c" } else { #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_clear_error (&_inner_error_); #line 203 "/home/jens/Source/shotwell/src/db/TagTable.vala" return; #line 1885 "TagTable.c" } } } #line 191 "/home/jens/Source/shotwell/src/db/TagTable.vala" _sqlite3_finalize0 (stmt); #line 1891 "TagTable.c" } static gchar* tag_table_serialize_source_ids (TagTable* self, GeeCollection* source_ids) { gchar* result = NULL; GeeCollection* _tmp0_ = NULL; GString* _result_ = NULL; GString* _tmp1_ = NULL; const gchar* _tmp11_ = NULL; GString* _tmp12_ = NULL; gssize _tmp13_ = 0L; gchar* _tmp16_ = NULL; #line 206 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (IS_TAG_TABLE (self), NULL); #line 206 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail ((source_ids == NULL) || GEE_IS_COLLECTION (source_ids), NULL); #line 207 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = source_ids; #line 207 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp0_ == NULL) { #line 208 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = NULL; #line 208 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 1916 "TagTable.c" } #line 210 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp1_ = g_string_new (""); #line 210 "/home/jens/Source/shotwell/src/db/TagTable.vala" _result_ = _tmp1_; #line 1922 "TagTable.c" { GeeIterator* _source_id_it = NULL; GeeCollection* _tmp2_ = NULL; GeeIterator* _tmp3_ = NULL; #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = source_ids; #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp3_ = gee_iterable_iterator (G_TYPE_CHECK_INSTANCE_CAST (_tmp2_, GEE_TYPE_ITERABLE, GeeIterable)); #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _source_id_it = _tmp3_; #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" while (TRUE) { #line 1935 "TagTable.c" GeeIterator* _tmp4_ = NULL; gboolean _tmp5_ = FALSE; gchar* source_id = NULL; GeeIterator* _tmp6_ = NULL; gpointer _tmp7_ = NULL; GString* _tmp8_ = NULL; const gchar* _tmp9_ = NULL; GString* _tmp10_ = NULL; #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = _source_id_it; #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = gee_iterator_next (_tmp4_); #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (!_tmp5_) { #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" break; #line 1952 "TagTable.c" } #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = _source_id_it; #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = gee_iterator_get (_tmp6_); #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" source_id = (gchar*) _tmp7_; #line 213 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = _result_; #line 213 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = source_id; #line 213 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_string_append (_tmp8_, _tmp9_); #line 214 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = _result_; #line 214 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_string_append (_tmp10_, ","); #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (source_id); #line 1972 "TagTable.c" } #line 212 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_object_unref0 (_source_id_it); #line 1976 "TagTable.c" } #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = _result_; #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = _tmp12_->len; #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp13_ != ((gssize) 0)) { #line 1984 "TagTable.c" GString* _tmp14_ = NULL; const gchar* _tmp15_ = NULL; #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = _result_; #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp15_ = _tmp14_->str; #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = _tmp15_; #line 1993 "TagTable.c" } else { #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = NULL; #line 1997 "TagTable.c" } #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = g_strdup (_tmp11_); #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = _tmp16_; #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_string_free0 (_result_); #line 217 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 2007 "TagTable.c" } static gchar string_get (const gchar* self, glong index) { gchar result = '\0'; glong _tmp0_ = 0L; gchar _tmp1_ = '\0'; #line 1086 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" g_return_val_if_fail (self != NULL, '\0'); #line 1087 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp0_ = index; #line 1087 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" _tmp1_ = ((gchar*) self)[_tmp0_]; #line 1087 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" result = _tmp1_; #line 1087 "/usr/share/vala-0.32/vapi/glib-2.0.vapi" return result; #line 2025 "TagTable.c" } static GeeSet* tag_table_unserialize_source_ids (TagTable* self, const gchar* text_list) { GeeSet* result = NULL; GeeSet* _result_ = NULL; GeeHashSet* _tmp0_ = NULL; const gchar* _tmp1_ = NULL; gchar** split = NULL; const gchar* _tmp2_ = NULL; gchar** _tmp3_ = NULL; gchar** _tmp4_ = NULL; gint split_length1 = 0; gint _split_size_ = 0; gchar** _tmp5_ = NULL; gint _tmp5__length1 = 0; #line 220 "/home/jens/Source/shotwell/src/db/TagTable.vala" g_return_val_if_fail (IS_TAG_TABLE (self), NULL); #line 221 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp0_ = gee_hash_set_new (G_TYPE_STRING, (GBoxedCopyFunc) g_strdup, g_free, NULL, NULL, NULL, NULL, NULL, NULL); #line 221 "/home/jens/Source/shotwell/src/db/TagTable.vala" _result_ = G_TYPE_CHECK_INSTANCE_CAST (_tmp0_, GEE_TYPE_SET, GeeSet); #line 223 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp1_ = text_list; #line 223 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp1_ == NULL) { #line 224 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = _result_; #line 224 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 2056 "TagTable.c" } #line 226 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp2_ = text_list; #line 226 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp4_ = _tmp3_ = g_strsplit (_tmp2_, ",", 0); #line 226 "/home/jens/Source/shotwell/src/db/TagTable.vala" split = _tmp4_; #line 226 "/home/jens/Source/shotwell/src/db/TagTable.vala" split_length1 = _vala_array_length (_tmp3_); #line 226 "/home/jens/Source/shotwell/src/db/TagTable.vala" _split_size_ = split_length1; #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5_ = split; #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp5__length1 = split_length1; #line 2072 "TagTable.c" { gchar** token_collection = NULL; gint token_collection_length1 = 0; gint _token_collection_size_ = 0; gint token_it = 0; #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" token_collection = _tmp5_; #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" token_collection_length1 = _tmp5__length1; #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" for (token_it = 0; token_it < _tmp5__length1; token_it = token_it + 1) { #line 2084 "TagTable.c" gchar* _tmp6_ = NULL; gchar* token = NULL; #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp6_ = g_strdup (token_collection[token_it]); #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" token = _tmp6_; #line 2091 "TagTable.c" { const gchar* _tmp7_ = NULL; gboolean _tmp8_ = FALSE; const gchar* _tmp9_ = NULL; gchar _tmp10_ = '\0'; gboolean _tmp11_ = FALSE; #line 228 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp7_ = token; #line 228 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp8_ = is_string_empty (_tmp7_); #line 228 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp8_) { #line 229 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (token); #line 229 "/home/jens/Source/shotwell/src/db/TagTable.vala" continue; #line 2108 "TagTable.c" } #line 236 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp9_ = token; #line 236 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp10_ = string_get (_tmp9_, (glong) 0); #line 236 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp11_ = g_ascii_isdigit (_tmp10_); #line 236 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp11_) { #line 2118 "TagTable.c" GeeSet* _tmp12_ = NULL; const gchar* _tmp13_ = NULL; gint64 _tmp14_ = 0LL; PhotoID _tmp15_ = {0}; gchar* _tmp16_ = NULL; gchar* _tmp17_ = NULL; #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp12_ = _result_; #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp13_ = token; #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp14_ = parse_int64 (_tmp13_, 10); #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" photo_id_init (&_tmp15_, _tmp14_); #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp16_ = photo_id_upgrade_photo_id_to_source_id (&_tmp15_); #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp17_ = _tmp16_; #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" gee_collection_add (G_TYPE_CHECK_INSTANCE_CAST (_tmp12_, GEE_TYPE_COLLECTION, GeeCollection), _tmp17_); #line 238 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (_tmp17_); #line 2141 "TagTable.c" } else { const gchar* _tmp18_ = NULL; gchar _tmp19_ = '\0'; gboolean _tmp20_ = FALSE; #line 239 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp18_ = token; #line 239 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp19_ = string_get (_tmp18_, (glong) 0); #line 239 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp20_ = g_ascii_isalpha (_tmp19_); #line 239 "/home/jens/Source/shotwell/src/db/TagTable.vala" if (_tmp20_) { #line 2154 "TagTable.c" GeeSet* _tmp21_ = NULL; const gchar* _tmp22_ = NULL; #line 241 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp21_ = _result_; #line 241 "/home/jens/Source/shotwell/src/db/TagTable.vala" _tmp22_ = token; #line 241 "/home/jens/Source/shotwell/src/db/TagTable.vala" gee_collection_add (G_TYPE_CHECK_INSTANCE_CAST (_tmp21_, GEE_TYPE_COLLECTION, GeeCollection), _tmp22_); #line 2163 "TagTable.c" } } #line 227 "/home/jens/Source/shotwell/src/db/TagTable.vala" _g_free0 (token); #line 2168 "TagTable.c" } } } #line 245 "/home/jens/Source/shotwell/src/db/TagTable.vala" result = _result_; #line 245 "/home/jens/Source/shotwell/src/db/TagTable.vala" split = (_vala_array_free (split, split_length1, (GDestroyNotify) g_free), NULL); #line 245 "/home/jens/Source/shotwell/src/db/TagTable.vala" return result; #line 2178 "TagTable.c" } static void tag_table_class_init (TagTableClass * klass) { #line 32 "/home/jens/Source/shotwell/src/db/TagTable.vala" tag_table_parent_class = g_type_class_peek_parent (klass); #line 32 "/home/jens/Source/shotwell/src/db/TagTable.vala" ((DatabaseTableClass *) klass)->finalize = tag_table_finalize; #line 2187 "TagTable.c" } static void tag_table_instance_init (TagTable * self) { } static void tag_table_finalize (DatabaseTable* obj) { TagTable * self; #line 32 "/home/jens/Source/shotwell/src/db/TagTable.vala" self = G_TYPE_CHECK_INSTANCE_CAST (obj, TYPE_TAG_TABLE, TagTable); #line 32 "/home/jens/Source/shotwell/src/db/TagTable.vala" DATABASE_TABLE_CLASS (tag_table_parent_class)->finalize (obj); #line 2201 "TagTable.c" } GType tag_table_get_type (void) { static volatile gsize tag_table_type_id__volatile = 0; if (g_once_init_enter (&tag_table_type_id__volatile)) { static const GTypeInfo g_define_type_info = { sizeof (TagTableClass), (GBaseInitFunc) NULL, (GBaseFinalizeFunc) NULL, (GClassInitFunc) tag_table_class_init, (GClassFinalizeFunc) NULL, NULL, sizeof (TagTable), 0, (GInstanceInitFunc) tag_table_instance_init, NULL }; GType tag_table_type_id; tag_table_type_id = g_type_register_static (TYPE_DATABASE_TABLE, "TagTable", &g_define_type_info, 0); g_once_init_leave (&tag_table_type_id__volatile, tag_table_type_id); } return tag_table_type_id__volatile; } static void _vala_array_destroy (gpointer array, gint array_length, GDestroyNotify destroy_func) { if ((array != NULL) && (destroy_func != NULL)) { int i; for (i = 0; i < array_length; i = i + 1) { if (((gpointer*) array)[i] != NULL) { destroy_func (((gpointer*) array)[i]); } } } } static void _vala_array_free (gpointer array, gint array_length, GDestroyNotify destroy_func) { _vala_array_destroy (array, array_length, destroy_func); g_free (array); } static gint _vala_array_length (gpointer array) { int length; length = 0; if (array) { while (((gpointer*) array)[length]) { length++; } } return length; }