Re-enable loading CSS file from preferences
authorP. F. Chimento <philip.chimento@gmail.com>
Wed, 22 Jun 2011 18:43:01 +0000 (20:43 +0200)
committerP. F. Chimento <philip.chimento@gmail.com>
Wed, 22 Jun 2011 18:43:01 +0000 (20:43 +0200)
player/player.c
player/player.h
player/preferences.c

index bedafea8be69a33ba996554b58131c64db65489e..10f45d53c4b724145163f66ea91c93e302d74553 100644 (file)
@@ -69,6 +69,21 @@ change_window_title(ChimaraGlk *glk, GParamSpec *pspec, GtkWindow *window)
        g_free(title);
 }
 
+static void
+on_css_changed(GSettings *prefs_settings, char *key, ChimaraPlayer *self)
+{
+       char *user_css;
+       g_settings_get(prefs_settings, "css-file", "ms", &user_css);
+       if(user_css) {
+               if(!chimara_glk_set_css_from_file(CHIMARA_GLK(self->glk), user_css, NULL)) {
+                       /* If the setting didn't point to a CSS file, fail silently and
+                        null the setting */
+                       g_settings_set(prefs_settings, "css-file", "ms", NULL);
+               }
+               g_free(user_css);
+       }
+}
+
 static void
 chimara_player_dispose(GObject *object)
 {
@@ -138,10 +153,14 @@ chimara_player_init(ChimaraPlayer *self)
                                 "ignore-errors", TRUE,
                                 /*"interpreter-number", CHIMARA_IF_ZMACHINE_TANDY_COLOR,*/
                                 NULL);
+
+       /* Set the CSS styles for the interpreter */
        char *default_css = get_data_file_path("style.css");
        if( !chimara_glk_set_css_from_file(CHIMARA_GLK(self->glk), default_css, &error) ) {
                error_dialog(GTK_WINDOW(self), error, "Couldn't open default CSS file: ");
        }
+       g_free(default_css);
+       on_css_changed(theapp->prefs_settings, "css-file", self);
        
        /* DON'T UNCOMMENT THIS your eyes will burn
         but it is a good test of programmatically altering just one style
@@ -174,6 +193,7 @@ chimara_player_init(ChimaraPlayer *self)
        gtk_builder_connect_signals(builder, self);
        g_signal_connect(self->glk, "notify::program-name", G_CALLBACK(change_window_title), self);
        g_signal_connect(self->glk, "notify::story-name", G_CALLBACK(change_window_title), self);
+       g_signal_connect(theapp->prefs_settings, "changed::css-file", G_CALLBACK(on_css_changed), self);
 
        g_object_unref(builder);
        g_object_unref(uimanager);
@@ -189,6 +209,13 @@ chimara_player_new(void)
                NULL));
 }
 
+void
+chimara_player_set_user_css_file(ChimaraPlayer *self, const char *filename)
+{
+       chimara_glk_set_css_to_default(CHIMARA_GLK(self->glk));
+       chimara_glk_set_css_from_file(CHIMARA_GLK(self->glk), filename, NULL);
+}
+
 /* GLADE CALLBACKS */
 
 #if 0
index 4b6a604dc8500251354da56d7ee0195df4ab70a3..f777b879da48719370ffd782140f19494b3e44f4 100644 (file)
@@ -57,6 +57,7 @@ typedef struct _ChimaraPlayerClass {
 
 GType chimara_player_get_type(void) G_GNUC_CONST;
 GtkWidget *chimara_player_new(void);
+void chimara_player_set_user_css_file(ChimaraPlayer *player, const char *filename);
 
 G_END_DECLS
 
index 03e171e2cdd22e408d637e526b134281f32aeb41..df1edc62789d17bcce9df607a90cf360dce6ebe7 100644 (file)
@@ -229,17 +229,12 @@ chimara_prefs_init(ChimaraPrefs *self)
                gtk_file_chooser_set_filename(blorb_chooser, filename);
                g_free(filename);
        }
+
        g_settings_get(theapp->prefs_settings, "css-file", "ms", &filename);
-       //if(filename) {
-       //      if(!chimara_glk_set_css_from_file(glk, filename, NULL)) {
-       //              /* If the setting didn't point to a CSS file, fail silently and
-       //               null the setting */
-       //              g_settings_set(theapp->prefs_settings, "css-file", "ms", NULL);
-       //      } else {
-       //              gtk_file_chooser_set_filename(css_chooser, filename);
-       //      }
-       //      g_free(filename);
-       //}
+       if(filename) {
+               gtk_file_chooser_set_filename(css_chooser, filename);
+               g_free(filename);
+       }
 
        /* Populate the list of available interpreters */
        GtkListStore *interp_list = GTK_LIST_STORE( load_object(builder, "available_interpreters") );
@@ -411,16 +406,10 @@ on_font_set(GtkFontButton *button, ChimaraGlk *glk)
 void
 on_css_filechooser_file_set(GtkFileChooserButton *button, ChimaraGlk *glk)
 {
-       //GError *error = NULL;
-       //ChimaraApp *theapp = chimara_app_get();
-       //char *filename = gtk_file_chooser_get_filename( GTK_FILE_CHOOSER(button) );
-       //if(!chimara_glk_set_css_from_file(glk, filename, &error)) {
-       //      error_dialog(NULL, error, "There was a problem reading the CSS file: ");
-       //      g_settings_set(theapp->prefs_settings, "css-file", "ms", NULL);
-       //} else {
-       //      g_settings_set(theapp->prefs_settings, "css-file", "ms", filename);
-       //}
-       //g_free(filename);
+       ChimaraApp *theapp = chimara_app_get();
+       char *filename = gtk_file_chooser_get_filename( GTK_FILE_CHOOSER(button) );
+       g_settings_set(theapp->prefs_settings, "css-file", "ms", filename);
+       g_free(filename);
 }
 
 void