X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=src%2Fmain.c;h=978f788252eb5cb6c533aa5b063219510cc830e5;hb=46974bb948c0a7ca82b476a578b6199e438bab41;hp=30a7bdfed65ee3ee4c4cab9663c2ec200ac9ccfd;hpb=199d247c0c2155c1c8fca97fcc6087efdd29e482;p=rodin%2Fchimara.git diff --git a/src/main.c b/src/main.c index 30a7bdf..978f788 100644 --- a/src/main.c +++ b/src/main.c @@ -36,60 +36,48 @@ #include #include +#include +#include #include #include "callbacks.h" #include "error.h" +#include "event.h" +#include "abort.h" #include "glk.h" +#include "chimara-glk.h" -/* - * Standard gettext macros. - */ -#ifdef ENABLE_NLS -# include -# undef _ -# define _(String) dgettext (PACKAGE, String) -# ifdef gettext_noop -# define N_(String) gettext_noop (String) -# else -# define N_(String) (String) -# endif -#else -# define textdomain(String) (String) -# define gettext(String) (String) -# define dgettext(Domain,Message) (Message) -# define dcgettext(Domain,Message,Type) (Message) -# define bindtextdomain(Domain,Directory) (Domain) -# define _(String) (String) -# define N_(String) (String) -#endif - -#include "callbacks.h" - -/* The global builder object to be used to request handles to widgets */ +/* Global pointers to widgets */ GtkBuilder *builder = NULL; - -GtkWidget* +GtkWidget *window = NULL; +GtkWidget *glk = NULL; + +static void create_window(void) { - GtkWidget *window; - if( (window = GTK_WIDGET(gtk_builder_get_object(builder, "gargoyle-gtk"))) == NULL ) { error_dialog(NULL, NULL, "Error while getting main window object"); - return NULL; + return; } gtk_builder_connect_signals(builder, NULL); - return window; -} + glk = chimara_glk_new(); + + GtkBox *vbox = GTK_BOX( gtk_builder_get_object(builder, "vbox") ); + if(vbox == NULL) + { + error_dialog(NULL, NULL, "Could not find vbox"); + return; + } + gtk_box_pack_end(vbox, glk, TRUE, TRUE, 0); +} int main(int argc, char *argv[]) { GError *error = NULL; - GtkWidget *window; #ifdef ENABLE_NLS bindtextdomain(GETTEXT_PACKAGE, PACKAGE_LOCALE_DIR); @@ -97,21 +85,36 @@ main(int argc, char *argv[]) textdomain(GETTEXT_PACKAGE); #endif + if( !g_thread_supported() ) + g_thread_init(NULL); + + gdk_threads_init(); + gtk_set_locale(); gtk_init(&argc, &argv); builder = gtk_builder_new(); - if( !gtk_builder_add_from_file(builder, "gargoyle-gtk.ui", &error) ) { + if( !gtk_builder_add_from_file(builder, "chimara.ui", &error) ) { error_dialog(NULL, error, "Error while building interface: "); return 1; } - window = create_window(); - gtk_widget_show(window); - - glk_main(); + create_window(); + gtk_widget_show_all(window); g_object_unref( G_OBJECT(builder) ); + if( !chimara_glk_run(CHIMARA_GLK(glk), &error) ) { + error_dialog(GTK_WINDOW(window), error, "Error starting Glk library: "); + return 1; + } + + gdk_threads_enter(); + gtk_main(); + gdk_threads_leave(); + + signal_abort(); + chimara_glk_wait(CHIMARA_GLK(glk)); + return 0; }