/* GIMP - The GNU Image Manipulation Program * Copyright (C) 1995 Spencer Kimball and Peter Mattis * * gimppluginmanager-help-domain.c * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "config.h" #include #include #include "plug-in-types.h" #include "gimppluginmanager.h" #include "gimppluginmanager-help-domain.h" typedef struct _GimpPlugInHelpDomain GimpPlugInHelpDomain; struct _GimpPlugInHelpDomain { GFile *file; gchar *domain_name; gchar *domain_uri; }; void gimp_plug_in_manager_help_domain_exit (GimpPlugInManager *manager) { GSList *list; g_return_if_fail (GIMP_IS_PLUG_IN_MANAGER (manager)); for (list = manager->help_domains; list; list = list->next) { GimpPlugInHelpDomain *domain = list->data; g_object_unref (domain->file); g_free (domain->domain_name); g_free (domain->domain_uri); g_slice_free (GimpPlugInHelpDomain, domain); } g_slist_free (manager->help_domains); manager->help_domains = NULL; } void gimp_plug_in_manager_add_help_domain (GimpPlugInManager *manager, GFile *file, const gchar *domain_name, const gchar *domain_uri) { GimpPlugInHelpDomain *domain; g_return_if_fail (GIMP_IS_PLUG_IN_MANAGER (manager)); g_return_if_fail (G_IS_FILE (file)); g_return_if_fail (domain_name != NULL); domain = g_slice_new (GimpPlugInHelpDomain); domain->file = g_object_ref (file); domain->domain_name = g_strdup (domain_name); domain->domain_uri = g_strdup (domain_uri); manager->help_domains = g_slist_prepend (manager->help_domains, domain); #ifdef VERBOSE g_print ("added help domain \"%s\" for base uri \"%s\"\n", domain->domain_name ? domain->domain_name : "(null)", domain->domain_uri ? domain->domain_uri : "(null)"); #endif } const gchar * gimp_plug_in_manager_get_help_domain (GimpPlugInManager *manager, GFile *file, const gchar **domain_uri) { GSList *list; g_return_val_if_fail (GIMP_IS_PLUG_IN_MANAGER (manager), NULL); g_return_val_if_fail (file == NULL || G_IS_FILE (file), NULL); if (domain_uri) *domain_uri = NULL; /* A NULL prog_name is GIMP itself, return the default domain */ if (! file) return NULL; for (list = manager->help_domains; list; list = list->next) { GimpPlugInHelpDomain *domain = list->data; if (domain && domain->file && g_file_equal (domain->file, file)) { if (domain_uri && domain->domain_uri) *domain_uri = domain->domain_uri; return domain->domain_name; } } return NULL; } gint gimp_plug_in_manager_get_help_domains (GimpPlugInManager *manager, gchar ***help_domains, gchar ***help_uris) { gint n_domains; g_return_val_if_fail (GIMP_IS_PLUG_IN_MANAGER (manager), 0); g_return_val_if_fail (help_domains != NULL, 0); g_return_val_if_fail (help_uris != NULL, 0); n_domains = g_slist_length (manager->help_domains); if (n_domains > 0) { GSList *list; gint i; *help_domains = g_new0 (gchar *, n_domains + 1); *help_uris = g_new0 (gchar *, n_domains + 1); for (list = manager->help_domains, i = 0; list; list = list->next, i++) { GimpPlugInHelpDomain *domain = list->data; (*help_domains)[i] = g_strdup (domain->domain_name); (*help_uris)[i] = g_strdup (domain->domain_uri); } } else { *help_domains = NULL; *help_uris = NULL; } return n_domains; }