/* Pango * querymodules.c: * * Copyright (C) 1999 Red Hat Software * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ #include #include #include #include "pango.h" #include "pango-utils.h" #include #include #include #include void query_module (const char *dir, const char *name) { void (*list) (PangoEngineInfo **engines, gint *n_engines); PangoEngine *(*load) (const gchar *id); void (*unload) (PangoEngine *engine); GModule *module; gchar *path; if (name[0] == G_DIR_SEPARATOR) path = g_strdup (name); else path = g_strconcat (dir, G_DIR_SEPARATOR_S, name, NULL); module = g_module_open (path, 0); if (!module) fprintf(stderr, "Cannot load module %s: %s\n", path, g_module_error()); if (module && g_module_symbol (module, "script_engine_list", (gpointer)&list) && g_module_symbol (module, "script_engine_load", (gpointer)&load) && g_module_symbol (module, "script_engine_unload", (gpointer)&unload)) { gint i,j; PangoEngineInfo *engines; gint n_engines; (*list) (&engines, &n_engines); for (i=0; id_name); if (len > 3 && strcmp (dent->d_name + len - 3, ".so") == 0) query_module (dirs[i], dent->d_name); } closedir (dir); } } } else { getcwd (cwd, PATH_MAX); for (i=1; i