X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=player%2Fmain.c;h=70bad3b3941ae4062058548fec4631e0a942cccc;hb=39b9e14c0e3c11a4b6df8c22ac4a554e2aae9720;hp=962ca30e0ba3f05198a9f55d163f56a2e8646769;hpb=422727d2d79580db18947a004ca6759b745e871e;p=projects%2Fchimara%2Fchimara.git diff --git a/player/main.c b/player/main.c index 962ca30..70bad3b 100644 --- a/player/main.c +++ b/player/main.c @@ -40,21 +40,30 @@ #include #include +/* Use a custom GSettings backend for our preferences file */ +#define G_SETTINGS_ENABLE_BACKEND +#include + #include "error.h" #include #include +#include "preferences.h" + /* Static global pointers to widgets */ -static GtkBuilder *builder = NULL; static GtkUIManager *uimanager = NULL; static GtkWidget *window = NULL; static GtkWidget *glk = NULL; /* Global global pointers */ +GtkBuilder *builder = NULL; GtkWidget *aboutwindow = NULL; GtkWidget *prefswindow = NULL; +GtkWidget *toolbar = NULL; +GSettings *prefs_settings = NULL; +GSettings *state_settings = NULL; -static GObject * +GObject * load_object(const gchar *name) { GObject *retval; @@ -108,39 +117,16 @@ create_window(void) aboutwindow = GTK_WIDGET(load_object("aboutwindow")); prefswindow = GTK_WIDGET(load_object("prefswindow")); GtkActionGroup *actiongroup = GTK_ACTION_GROUP(load_object("actiongroup")); + GtkToggleAction *toolbar_action = GTK_TOGGLE_ACTION(load_object("toolbar")); - /* Add all the actions to the action group. This for-loop is a temporary fix - and can be removed once Glade supports adding actions and accelerators to an - action group. */ - const gchar *actions[] = { - "game", "", - "open", "O", - "recent", "", - "stop", "", - "quit_chimara", NULL, /* NULL means use stock accelerator */ - "command", "", - "undo", "Z", - "save", NULL, - "restore", "R", - "restart", "", - "quit", "", - "edit", "", - "copy", NULL, - "paste", NULL, - "preferences", "", - "help", "", - "about", "", - NULL - }; const gchar **ptr; - for(ptr = actions; *ptr; ptr += 2) - gtk_action_group_add_action_with_accel(actiongroup, GTK_ACTION(load_object(ptr[0])), ptr[1]); GtkRecentFilter *filter = gtk_recent_filter_new(); /* TODO: Use mimetypes and construct the filter dynamically depending on what plugins are installed */ const gchar *patterns[] = { "*.z[1-8]", "*.[zg]lb", "*.[zg]blorb", "*.ulx", "*.blb", "*.blorb", NULL }; + for(ptr = patterns; *ptr; ptr++) gtk_recent_filter_add_pattern(filter, *ptr); GtkRecentChooser *recent = GTK_RECENT_CHOOSER(load_object("recent")); @@ -159,14 +145,17 @@ create_window(void) } #endif /* DEBUG */ } - + glk = chimara_if_new(); - g_object_set(glk, "ignore-errors", TRUE, NULL); + g_object_set(glk, + "ignore-errors", TRUE, + /*"interpreter-number", CHIMARA_IF_ZMACHINE_TANDY_COLOR,*/ + NULL); if( !chimara_glk_set_css_from_file(CHIMARA_GLK(glk), PACKAGE_DATA_DIR "/style.css", &error) ) { #ifdef DEBUG g_error_free(error); error = NULL; - if( !chimara_glk_set_css_from_file(CHIMARA_GLK(glk), PACKAGE_SRC_DIR "/macstyle.css", &error) ) { + if( !chimara_glk_set_css_from_file(CHIMARA_GLK(glk), PACKAGE_SRC_DIR "/style.css", &error) ) { #endif /* DEBUG */ error_dialog(NULL, error, "Couldn't open CSS file: "); return; @@ -174,6 +163,24 @@ create_window(void) } #endif /* DEBUG */ } + chimara_if_set_preferred_interpreter(CHIMARA_IF(glk), + CHIMARA_IF_FORMAT_Z5, + CHIMARA_IF_INTERPRETER_FROTZ); + chimara_if_set_preferred_interpreter(CHIMARA_IF(glk), + CHIMARA_IF_FORMAT_Z6, + CHIMARA_IF_INTERPRETER_NITFOL); + chimara_if_set_preferred_interpreter(CHIMARA_IF(glk), + CHIMARA_IF_FORMAT_Z8, + CHIMARA_IF_INTERPRETER_FROTZ); + chimara_if_set_preferred_interpreter(CHIMARA_IF(glk), + CHIMARA_IF_FORMAT_Z_BLORB, + CHIMARA_IF_INTERPRETER_FROTZ); + chimara_if_set_preferred_interpreter(CHIMARA_IF(glk), + CHIMARA_IF_FORMAT_GLULX, + CHIMARA_IF_INTERPRETER_GLULXE); + chimara_if_set_preferred_interpreter(CHIMARA_IF(glk), + CHIMARA_IF_FORMAT_GLULX_BLORB, + CHIMARA_IF_INTERPRETER_GLULXE); /* DON'T UNCOMMENT THIS your eyes will burn but it is a good test of programmatically altering just one style @@ -189,7 +196,12 @@ create_window(void) gtk_ui_manager_insert_action_group(uimanager, actiongroup, 0); GtkWidget *menubar = gtk_ui_manager_get_widget(uimanager, "/menubar"); - GtkWidget *toolbar = gtk_ui_manager_get_widget(uimanager, "/toolbar"); + toolbar = gtk_ui_manager_get_widget(uimanager, "/toolbar"); + gtk_widget_set_no_show_all(toolbar, TRUE); + if(gtk_toggle_action_get_active(toolbar_action)) + gtk_widget_show(toolbar); + else + gtk_widget_hide(toolbar); gtk_box_pack_end(vbox, glk, TRUE, TRUE, 0); gtk_box_pack_start(vbox, menubar, FALSE, FALSE, 0); @@ -198,6 +210,9 @@ create_window(void) gtk_builder_connect_signals(builder, glk); g_signal_connect(glk, "notify::program-name", G_CALLBACK(change_window_title), window); g_signal_connect(glk, "notify::story-name", G_CALLBACK(change_window_title), window); + + /* Create preferences window */ + preferences_create(CHIMARA_GLK(glk)); } int @@ -216,12 +231,20 @@ main(int argc, char *argv[]) gdk_threads_init(); gtk_init(&argc, &argv); + /* Initialize settings file */ + gchar *keyfile = g_build_filename(g_get_home_dir(), ".chimara", NULL); + GSettingsBackend *backend = g_keyfile_settings_backend_new(keyfile, "/org/chimara-if/player/", NULL); + prefs_settings = g_settings_new_with_backend("org.chimara-if.player.preferences", backend); + state_settings = g_settings_new_with_backend("org.chimara-if.player.state", backend); + create_window(); gtk_widget_show_all(window); - g_object_unref( G_OBJECT(builder) ); g_object_unref( G_OBJECT(uimanager) ); + if(argc == 3) { + g_object_set(glk, "graphics-file", argv[2], NULL); + } if(argc >= 2) { if( !chimara_if_run_game(CHIMARA_IF(glk), argv[1], &error) ) { error_dialog(GTK_WINDOW(window), error, "Error starting Glk library: "); @@ -236,5 +259,7 @@ main(int argc, char *argv[]) chimara_glk_stop(CHIMARA_GLK(glk)); chimara_glk_wait(CHIMARA_GLK(glk)); + g_object_unref( G_OBJECT(builder) ); + return 0; }