Remove use of FOREACH macros

This commit is contained in:
Sebastian Ramacher 2023-12-03 23:32:59 +01:00
parent cb11a67add
commit 61d6ff288f

View file

@ -207,22 +207,19 @@ zathura_plugin_manager_load(zathura_plugin_manager_t* plugin_manager)
return girara_list_size(plugin_manager->plugins) > 0; return girara_list_size(plugin_manager->plugins) > 0;
} }
zathura_plugin_t* zathura_plugin_t* zathura_plugin_manager_get_plugin(zathura_plugin_manager_t* plugin_manager, const char* type) {
zathura_plugin_manager_get_plugin(zathura_plugin_manager_t* plugin_manager, const char* type)
{
if (plugin_manager == NULL || plugin_manager->type_plugin_mapping == NULL || type == NULL) { if (plugin_manager == NULL || plugin_manager->type_plugin_mapping == NULL || type == NULL) {
return NULL; return NULL;
} }
zathura_plugin_t* plugin = NULL; for (size_t idx = 0; idx != girara_list_size(plugin_manager->type_plugin_mapping); ++idx) {
GIRARA_LIST_FOREACH_BODY(plugin_manager->type_plugin_mapping, zathura_type_plugin_mapping_t*, mapping, zathura_type_plugin_mapping_t* mapping = girara_list_nth(plugin_manager->type_plugin_mapping, idx);
if (g_content_type_equals(type, mapping->type)) { if (g_content_type_equals(type, mapping->type)) {
plugin = mapping->plugin; return mapping->plugin;
break; }
} }
);
return plugin; return NULL;
} }
girara_list_t* girara_list_t*
@ -260,26 +257,22 @@ zathura_plugin_manager_free(zathura_plugin_manager_t* plugin_manager)
g_free(plugin_manager); g_free(plugin_manager);
} }
static bool static bool register_plugin(zathura_plugin_manager_t* plugin_manager, zathura_plugin_t* plugin) {
register_plugin(zathura_plugin_manager_t* plugin_manager, zathura_plugin_t* plugin) if (plugin == NULL || plugin->content_types == NULL || plugin_manager == NULL || plugin_manager->plugins == NULL) {
{
if (plugin == NULL
|| plugin->content_types == NULL
|| plugin_manager == NULL
|| plugin_manager->plugins == NULL) {
girara_error("plugin: could not register"); girara_error("plugin: could not register");
return false; return false;
} }
bool at_least_one = false; bool at_least_one = false;
GIRARA_LIST_FOREACH_BODY(plugin->content_types, gchar*, type, for (size_t idx = 0; idx != girara_list_size(plugin->content_types); ++idx) {
gchar* type = girara_list_nth(plugin->content_types, idx);
if (plugin_mapping_new(plugin_manager, type, plugin) == false) { if (plugin_mapping_new(plugin_manager, type, plugin) == false) {
girara_error("plugin: filetype already registered: %s", type); girara_error("plugin: filetype already registered: %s", type);
} else { } else {
girara_debug("plugin: filetype mapping added: %s", type); girara_debug("plugin: filetype mapping added: %s", type);
at_least_one = true; at_least_one = true;
} }
); }
if (at_least_one == true) { if (at_least_one == true) {
girara_list_append(plugin_manager->plugins, plugin); girara_list_append(plugin_manager->plugins, plugin);
@ -288,24 +281,17 @@ register_plugin(zathura_plugin_manager_t* plugin_manager, zathura_plugin_t* plug
return at_least_one; return at_least_one;
} }
static bool static bool plugin_mapping_new(zathura_plugin_manager_t* plugin_manager, const gchar* type, zathura_plugin_t* plugin) {
plugin_mapping_new(zathura_plugin_manager_t* plugin_manager, const gchar* type, zathura_plugin_t* plugin)
{
g_return_val_if_fail(plugin_manager != NULL, false); g_return_val_if_fail(plugin_manager != NULL, false);
g_return_val_if_fail(type != NULL, false); g_return_val_if_fail(type != NULL, false);
g_return_val_if_fail(plugin != NULL, false); g_return_val_if_fail(plugin != NULL, false);
bool already_registered = false; for (size_t idx = 0; idx != girara_list_size(plugin_manager->type_plugin_mapping); ++idx) {
GIRARA_LIST_FOREACH_BODY(plugin_manager->type_plugin_mapping, zathura_type_plugin_mapping_t*, mapping, zathura_type_plugin_mapping_t* mapping = girara_list_nth(plugin_manager->type_plugin_mapping, idx);
if (g_content_type_equals(type, mapping->type)) { if (g_content_type_equals(type, mapping->type)) {
already_registered = true;
break;
}
);
if (already_registered == true) {
return false; return false;
} }
}
zathura_type_plugin_mapping_t* mapping = g_try_malloc0(sizeof(zathura_type_plugin_mapping_t)); zathura_type_plugin_mapping_t* mapping = g_try_malloc0(sizeof(zathura_type_plugin_mapping_t));
if (mapping == NULL) { if (mapping == NULL) {