From bfdd4be4b263a5e1deaeac52519a301ce28cdaf1 Mon Sep 17 00:00:00 2001 From: Sebastian Ramacher Date: Thu, 8 Feb 2018 22:07:47 +0100 Subject: [PATCH] Avoid explicit iterator Signed-off-by: Sebastian Ramacher --- zathura/database-sqlite.c | 18 ++---------------- zathura/plugin.c | 11 ++++++++--- 2 files changed, 10 insertions(+), 19 deletions(-) diff --git a/zathura/database-sqlite.c b/zathura/database-sqlite.c index 4d1b146..34a48c1 100644 --- a/zathura/database-sqlite.c +++ b/zathura/database-sqlite.c @@ -529,14 +529,9 @@ sqlite_save_jumplist(zathura_database_t* db, const char* file, girara_list_t* ju return true; } - girara_list_iterator_t* cur = girara_list_iterator(jumplist); bool status = true; - - while (true) { - zathura_jump_t* jump = girara_list_iterator_data(cur); - + GIRARA_LIST_FOREACH_BODY(jumplist, zathura_jump_t*, jump, stmt = prepare_statement(priv->session, SQL_INSERT_JUMP); - if (stmt == NULL) { status = false; break; @@ -546,7 +541,6 @@ sqlite_save_jumplist(zathura_database_t* db, const char* file, girara_list_t* ju sqlite3_bind_int(stmt, 2, jump->page) != SQLITE_OK || sqlite3_bind_double(stmt, 3, jump->x) != SQLITE_OK || sqlite3_bind_double(stmt, 4, jump->y) != SQLITE_OK) { - sqlite3_finalize(stmt); girara_error("Failed to bind arguments."); status = false; @@ -560,15 +554,7 @@ sqlite_save_jumplist(zathura_database_t* db, const char* file, girara_list_t* ju status = false; break; } - - if (girara_list_iterator_has_next(cur) == true) { - girara_list_iterator_next(cur); - } else { - break; - } - } - - girara_list_iterator_free(cur); + ); if (status == false) { sqlite3_exec(priv->session, "ROLLBACK;", NULL, 0, NULL); diff --git a/zathura/plugin.c b/zathura/plugin.c index 69fa7d4..0fe9449 100644 --- a/zathura/plugin.c +++ b/zathura/plugin.c @@ -281,13 +281,18 @@ plugin_mapping_new(zathura_plugin_manager_t* plugin_manager, const gchar* type, g_return_val_if_fail(type != NULL, false); g_return_val_if_fail(plugin != NULL, false); - GIRARA_LIST_FOREACH_BODY_WITH_ITER(plugin_manager->type_plugin_mapping, zathura_type_plugin_mapping_t*, iter, mapping, + bool already_registered = false; + GIRARA_LIST_FOREACH_BODY(plugin_manager->type_plugin_mapping, zathura_type_plugin_mapping_t*, mapping, if (g_content_type_equals(type, mapping->type)) { - girara_list_iterator_free(iter); - return false; + already_registered = true; + break; } ); + if (already_registered == true) { + return false; + } + zathura_type_plugin_mapping_t* mapping = g_try_malloc0(sizeof(zathura_type_plugin_mapping_t)); if (mapping == NULL) { return false;