diff options
Diffstat (limited to 'gtk/gtkfontbutton.c')
-rw-r--r-- | gtk/gtkfontbutton.c | 133 |
1 files changed, 92 insertions, 41 deletions
diff --git a/gtk/gtkfontbutton.c b/gtk/gtkfontbutton.c index e05223ca79..022b991122 100644 --- a/gtk/gtkfontbutton.c +++ b/gtk/gtkfontbutton.c @@ -61,7 +61,7 @@ struct _GtkFontButtonPrivate { gchar *title; - + gchar *fontname; guint use_font : 1; @@ -75,13 +75,14 @@ struct _GtkFontButtonPrivate GtkWidget *font_label; GtkWidget *size_label; - PangoFontFamily *font_family; - PangoFontFace *font_face; - gint font_size; - gchar *preview_text; - GtkFontFilterFunc font_filter; - gpointer font_filter_data; - GDestroyNotify font_filter_data_destroy; + PangoFontDescription *font_desc; + PangoFontFamily *font_family; + PangoFontFace *font_face; + gint font_size; + gchar *preview_text; + GtkFontFilterFunc font_filter; + gpointer font_filter_data; + GDestroyNotify font_filter_data_destroy; }; /* Signals */ @@ -245,6 +246,51 @@ gtk_font_button_font_chooser_set_filter_func (GtkFontChooser *chooser, } static void +gtk_font_button_take_font_desc (GtkFontButton *font_button, + PangoFontDescription *font_desc) +{ + GtkFontButtonPrivate *priv = font_button->priv; + GObject *object = G_OBJECT (font_button); + + if (priv->font_desc && font_desc && + pango_font_description_equal (priv->font_desc, font_desc)) + { + pango_font_description_free (font_desc); + return; + } + + g_object_freeze_notify (object); + + if (priv->font_desc) + pango_font_description_free (priv->font_desc); + if (font_desc) + priv->font_desc = font_desc; /* adopted */ + else + priv->font_desc = pango_font_description_from_string (_("Sans 12")); + + g_free (priv->fontname); + priv->fontname = pango_font_description_to_string (priv->font_desc); + + gtk_font_button_update_font_info (font_button); + + if (priv->font_dialog) + gtk_font_chooser_set_font_desc (GTK_FONT_CHOOSER (priv->font_dialog), + priv->font_desc); + + g_object_notify (G_OBJECT (font_button), "font"); + g_object_notify (G_OBJECT (font_button), "font-desc"); + g_object_notify (G_OBJECT (font_button), "font-name"); + + g_object_thaw_notify (object); +} + +static const PangoFontDescription * +gtk_font_button_get_font_desc (GtkFontButton *font_button) +{ + return font_button->priv->font_desc; +} + +static void gtk_font_button_font_chooser_notify (GObject *object, GParamSpec *pspec, gpointer user_data) @@ -417,7 +463,6 @@ gtk_font_button_init (GtkFontButton *font_button) GtkFontButtonPrivate); /* Initialize fields */ - font_button->priv->fontname = g_strdup (_("Sans 12")); font_button->priv->use_font = FALSE; font_button->priv->use_size = FALSE; font_button->priv->show_style = TRUE; @@ -432,10 +477,9 @@ gtk_font_button_init (GtkFontButton *font_button) font_button->priv->inside = gtk_font_button_create_inside (font_button); gtk_container_add (GTK_CONTAINER (font_button), font_button->priv->inside); - gtk_font_button_update_font_info (font_button); + gtk_font_button_take_font_desc (font_button, NULL); } - static void gtk_font_button_finalize (GObject *object) { @@ -447,7 +491,7 @@ gtk_font_button_finalize (GObject *object) g_free (font_button->priv->fontname); font_button->priv->fontname = NULL; - + g_free (font_button->priv->title); font_button->priv->title = NULL; @@ -464,6 +508,10 @@ gtk_font_button_finalize (GObject *object) g_object_unref (font_button->priv->font_face); font_button->priv->font_face = NULL; + if (font_button->priv->font_desc) + pango_font_description_free (font_button->priv->font_desc); + font_button->priv->font_desc = NULL; + G_OBJECT_CLASS (gtk_font_button_parent_class)->finalize (object); } @@ -486,6 +534,9 @@ gtk_font_button_set_property (GObject *object, case PROP_TITLE: gtk_font_button_set_title (font_button, g_value_get_string (value)); break; + case GTK_FONT_CHOOSER_PROP_FONT_DESC: + gtk_font_button_take_font_desc (font_button, g_value_dup_boxed (value)); + break; case GTK_FONT_CHOOSER_PROP_FONT: case PROP_FONT_NAME: gtk_font_button_set_font_name (font_button, g_value_get_string (value)); @@ -527,6 +578,9 @@ gtk_font_button_get_property (GObject *object, case PROP_TITLE: g_value_set_string (value, gtk_font_button_get_title (font_button)); break; + case GTK_FONT_CHOOSER_PROP_FONT_DESC: + g_value_set_boxed (value, gtk_font_button_get_font_desc (font_button)); + break; case GTK_FONT_CHOOSER_PROP_FONT: case PROP_FONT_NAME: g_value_set_string (value, gtk_font_button_get_font_name (font_button)); @@ -834,7 +888,7 @@ const gchar * gtk_font_button_get_font_name (GtkFontButton *font_button) { g_return_val_if_fail (GTK_IS_FONT_BUTTON (font_button), NULL); - + return font_button->priv->fontname; } @@ -845,8 +899,7 @@ gtk_font_button_get_font_name (GtkFontButton *font_button) * * Sets or updates the currently-displayed font in font picker dialog. * - * Returns: Return value of gtk_font_chooser_dialog_set_font_name() if the - * font chooser dialog exists, otherwise %FALSE. + * Returns: %TRUE * * Since: 2.4 */ @@ -854,26 +907,13 @@ gboolean gtk_font_button_set_font_name (GtkFontButton *font_button, const gchar *fontname) { - gchar *old_fontname; + PangoFontDescription *font_desc; g_return_val_if_fail (GTK_IS_FONT_BUTTON (font_button), FALSE); g_return_val_if_fail (fontname != NULL, FALSE); - - if (g_ascii_strcasecmp (font_button->priv->fontname, fontname)) - { - old_fontname = font_button->priv->fontname; - font_button->priv->fontname = g_strdup (fontname); - g_free (old_fontname); - } - - gtk_font_button_update_font_info (font_button); - - if (font_button->priv->font_dialog) - gtk_font_chooser_set_font (GTK_FONT_CHOOSER (font_button->priv->font_dialog), - font_button->priv->fontname); - g_object_notify (G_OBJECT (font_button), "font"); - g_object_notify (G_OBJECT (font_button), "font-name"); + font_desc = pango_font_description_from_string (fontname); + gtk_font_button_take_font_desc (font_button, font_desc); return TRUE; } @@ -936,7 +976,7 @@ gtk_font_button_clicked (GtkButton *button) if (!gtk_widget_get_visible (font_button->priv->font_dialog)) { font_dialog = GTK_FONT_CHOOSER (font_button->priv->font_dialog); - gtk_font_chooser_set_font (font_dialog, font_button->priv->fontname); + gtk_font_chooser_set_font_desc (font_dialog, font_button->priv->font_desc); } gtk_window_present (GTK_WINDOW (font_button->priv->font_dialog)); @@ -951,6 +991,7 @@ response_cb (GtkDialog *dialog, GtkFontButton *font_button = GTK_FONT_BUTTON (data); GtkFontButtonPrivate *priv = font_button->priv; GtkFontChooser *font_chooser; + GObject *object; gtk_widget_hide (font_button->priv->font_dialog); @@ -958,9 +999,16 @@ response_cb (GtkDialog *dialog, return; font_chooser = GTK_FONT_CHOOSER (priv->font_dialog); + object = G_OBJECT (font_chooser); + + g_object_freeze_notify (object); + + if (priv->font_desc) + pango_font_description_free (priv->font_desc); + priv->font_desc = gtk_font_chooser_get_font_desc (font_chooser); g_free (priv->fontname); - priv->fontname = gtk_font_chooser_get_font (font_chooser); + priv->fontname = pango_font_description_to_string (priv->font_desc); if (priv->font_family) g_object_unref (priv->font_family); @@ -980,8 +1028,11 @@ response_cb (GtkDialog *dialog, gtk_font_button_update_font_info (font_button); g_object_notify (G_OBJECT (font_button), "font"); + g_object_notify (G_OBJECT (font_button), "font-desc"); g_object_notify (G_OBJECT (font_button), "font-name"); - + + g_object_thaw_notify (object); + /* Emit font_set signal */ g_signal_emit (font_button, font_button_signals[FONT_SET], 0); } @@ -1032,8 +1083,8 @@ gtk_font_button_label_use_font (GtkFontButton *font_button) if (!font_button->priv->use_font) return; - desc = pango_font_description_from_string (font_button->priv->fontname); - + desc = pango_font_description_copy (font_button->priv->font_desc); + if (!font_button->priv->use_size) pango_font_description_unset_fields (desc, PANGO_FONT_MASK_SIZE); @@ -1055,12 +1106,14 @@ font_description_style_equal (const PangoFontDescription *a, static void gtk_font_button_update_font_info (GtkFontButton *font_button) { - PangoFontDescription *desc; + const PangoFontDescription *desc; const gchar *family; gchar *style; gchar *family_style; - - desc = pango_font_description_from_string (font_button->priv->fontname); + + desc = font_button->priv->font_desc; + g_assert (desc != NULL); + family = pango_font_description_get_family (desc); #if 0 @@ -1134,6 +1187,4 @@ gtk_font_button_update_font_info (GtkFontButton *font_button) } gtk_font_button_label_use_font (font_button); - - pango_font_description_free (desc); } |