forked from AuroraMiddleware/gtk
feature a new commandline option --gtk-with-module=<module> that allows
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org> * gtk/gtkmain.c (gtk_init): feature a new commandline option --gtk-with-module=<module> that allows additional loading and initialization of modules (e.g. GLE).
This commit is contained in:
parent
7b9b0ab0fa
commit
2b7f8016b5
@ -1,3 +1,9 @@
|
||||
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* gtk/gtkmain.c (gtk_init): feature a new commandline option
|
||||
--gtk-with-module=<module> that allows additional loading and
|
||||
initialization of modules (e.g. GLE).
|
||||
|
||||
Mon Aug 17 01:40:00 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* configure.in: version bump to 1.1.1, binary age 0, interface age 0.
|
||||
|
@ -1,3 +1,9 @@
|
||||
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* gtk/gtkmain.c (gtk_init): feature a new commandline option
|
||||
--gtk-with-module=<module> that allows additional loading and
|
||||
initialization of modules (e.g. GLE).
|
||||
|
||||
Mon Aug 17 01:40:00 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* configure.in: version bump to 1.1.1, binary age 0, interface age 0.
|
||||
|
@ -1,3 +1,9 @@
|
||||
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* gtk/gtkmain.c (gtk_init): feature a new commandline option
|
||||
--gtk-with-module=<module> that allows additional loading and
|
||||
initialization of modules (e.g. GLE).
|
||||
|
||||
Mon Aug 17 01:40:00 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* configure.in: version bump to 1.1.1, binary age 0, interface age 0.
|
||||
|
@ -1,3 +1,9 @@
|
||||
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* gtk/gtkmain.c (gtk_init): feature a new commandline option
|
||||
--gtk-with-module=<module> that allows additional loading and
|
||||
initialization of modules (e.g. GLE).
|
||||
|
||||
Mon Aug 17 01:40:00 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* configure.in: version bump to 1.1.1, binary age 0, interface age 0.
|
||||
|
@ -1,3 +1,9 @@
|
||||
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* gtk/gtkmain.c (gtk_init): feature a new commandline option
|
||||
--gtk-with-module=<module> that allows additional loading and
|
||||
initialization of modules (e.g. GLE).
|
||||
|
||||
Mon Aug 17 01:40:00 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* configure.in: version bump to 1.1.1, binary age 0, interface age 0.
|
||||
|
@ -1,3 +1,9 @@
|
||||
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* gtk/gtkmain.c (gtk_init): feature a new commandline option
|
||||
--gtk-with-module=<module> that allows additional loading and
|
||||
initialization of modules (e.g. GLE).
|
||||
|
||||
Mon Aug 17 01:40:00 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* configure.in: version bump to 1.1.1, binary age 0, interface age 0.
|
||||
|
@ -1,3 +1,9 @@
|
||||
Mon Aug 17 03:47:55 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* gtk/gtkmain.c (gtk_init): feature a new commandline option
|
||||
--gtk-with-module=<module> that allows additional loading and
|
||||
initialization of modules (e.g. GLE).
|
||||
|
||||
Mon Aug 17 01:40:00 1998 Tim Janik <timj@gtk.org>
|
||||
|
||||
* configure.in: version bump to 1.1.1, binary age 0, interface age 0.
|
||||
|
@ -20,6 +20,7 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <gmodule.h>
|
||||
#include "gtkbutton.h"
|
||||
#include "gtkfeatures.h"
|
||||
#include "gtkhscrollbar.h"
|
||||
@ -233,6 +234,7 @@ void
|
||||
gtk_init (int *argc,
|
||||
char ***argv)
|
||||
{
|
||||
GSList *gtk_modinit_funcs = NULL;
|
||||
gchar *current_locale;
|
||||
|
||||
if (gtk_initialized)
|
||||
@ -307,6 +309,48 @@ gtk_init (int *argc,
|
||||
}
|
||||
(*argv)[i] = NULL;
|
||||
}
|
||||
else if (strcmp ("--gtk-with-module", (*argv)[i]) == 0 ||
|
||||
strncmp ("--gtk-with-module=", (*argv)[i], 18) == 0)
|
||||
{
|
||||
GModule *module = NULL;
|
||||
GtkModuleInitFunc modinit_func = NULL;
|
||||
gchar *module_name = (*argv)[i] + 17;
|
||||
|
||||
if (*module_name == '=')
|
||||
module_name++;
|
||||
else
|
||||
{
|
||||
(*argv)[i] = NULL;
|
||||
i += 1;
|
||||
module_name = (*argv)[i];
|
||||
}
|
||||
if (module_name[0] == '/' ||
|
||||
(module_name[0] == 'l' &&
|
||||
module_name[1] == 'i' &&
|
||||
module_name[2] == 'b'))
|
||||
module_name = g_strdup (module_name);
|
||||
else
|
||||
module_name = g_strconcat ("lib", module_name, ".so");
|
||||
(*argv)[i] = NULL;
|
||||
|
||||
if (g_module_supported ())
|
||||
{
|
||||
module = g_module_open (module_name, G_MODULE_BIND_LAZY);
|
||||
if (module &&
|
||||
g_module_symbol (module, "gtk_module_init", (gpointer*) &modinit_func) &&
|
||||
modinit_func)
|
||||
gtk_modinit_funcs = g_slist_prepend (gtk_modinit_funcs, modinit_func);
|
||||
}
|
||||
if (!modinit_func)
|
||||
{
|
||||
g_warning ("Failed to load module \"%s\": %s",
|
||||
module ? g_module_name (module) : module_name,
|
||||
g_module_error ());
|
||||
if (module)
|
||||
g_module_close (module);
|
||||
}
|
||||
g_free (module_name);
|
||||
}
|
||||
else if (strcmp ("--g-fatal-warnings", (*argv)[i]) == 0)
|
||||
{
|
||||
GLogLevelFlags fatal_levels;
|
||||
@ -425,6 +469,25 @@ gtk_init (int *argc,
|
||||
/* Set the 'initialized' flag.
|
||||
*/
|
||||
gtk_initialized = TRUE;
|
||||
|
||||
/* initialize modules
|
||||
*/
|
||||
if (gtk_modinit_funcs)
|
||||
{
|
||||
GSList *slist;
|
||||
|
||||
slist = gtk_modinit_funcs;
|
||||
while (slist)
|
||||
{
|
||||
GtkModuleInitFunc modinit;
|
||||
|
||||
modinit = slist->data;
|
||||
modinit (argc, argv);
|
||||
slist = slist->next;
|
||||
}
|
||||
|
||||
g_slist_free (gtk_modinit_funcs);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -34,6 +34,8 @@ extern "C" {
|
||||
#define GTK_PRIORITY_DEFAULT 0
|
||||
#define GTK_PRIORITY_LOW 10
|
||||
|
||||
typedef void (*GtkModuleInitFunc) (gint *argc,
|
||||
gchar ***argv);
|
||||
typedef gint (*GtkKeySnoopFunc) (GtkWidget *grab_widget,
|
||||
GdkEventKey *event,
|
||||
gpointer func_data);
|
||||
|
Loading…
Reference in New Issue
Block a user