[gtk+/portal-race: 58/129] GtkAccelLabel: Add use-underline property
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/portal-race: 58/129] GtkAccelLabel: Add use-underline property
- Date: Mon, 3 Jul 2017 00:48:51 +0000 (UTC)
commit 3c8c9015add5cdda8939c15bbe5afba7064b6150
Author: Timm Bäder <mail baedert org>
Date: Fri Jun 16 15:22:04 2017 +0200
GtkAccelLabel: Add use-underline property
gtk/gtkaccellabel.c | 44 +++++++++++++++++++++++++++++++++++++++++++-
gtk/gtkaccellabel.h | 8 ++++++++
2 files changed, 51 insertions(+), 1 deletions(-)
---
diff --git a/gtk/gtkaccellabel.c b/gtk/gtkaccellabel.c
index 6aed168..bb5cac8 100644
--- a/gtk/gtkaccellabel.c
+++ b/gtk/gtkaccellabel.c
@@ -115,6 +115,7 @@ enum {
PROP_ACCEL_CLOSURE,
PROP_ACCEL_WIDGET,
PROP_LABEL,
+ PROP_USE_UNDERLINE,
LAST_PROP
};
@@ -240,6 +241,13 @@ gtk_accel_label_class_init (GtkAccelLabelClass *class)
"",
GTK_PARAM_READWRITE);
+ props[PROP_USE_UNDERLINE] =
+ g_param_spec_boolean ("use-underline",
+ P_("Use underline"),
+ P_("If set, an underline in the text indicates the next character should be used
for the mnemonic accelerator key"),
+ FALSE,
+ GTK_PARAM_READWRITE|G_PARAM_EXPLICIT_NOTIFY);
+
g_object_class_install_properties (gobject_class, LAST_PROP, props);
gtk_widget_class_set_css_name (widget_class, "accellabel");
@@ -266,6 +274,9 @@ gtk_accel_label_set_property (GObject *object,
case PROP_LABEL:
gtk_accel_label_set_label (accel_label, g_value_get_string (value));
break;
+ case PROP_USE_UNDERLINE:
+ gtk_accel_label_set_use_underline (accel_label, g_value_get_boolean (value));
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -293,6 +304,9 @@ gtk_accel_label_get_property (GObject *object,
case PROP_LABEL:
g_value_set_string (value, gtk_accel_label_get_label (accel_label));
break;
+ case PROP_USE_UNDERLINE:
+ g_value_set_boolean (value, gtk_accel_label_get_use_underline (accel_label));
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -317,7 +331,6 @@ gtk_accel_label_init (GtkAccelLabel *accel_label)
priv->text_label = gtk_label_new ("");
gtk_widget_set_hexpand (priv->text_label, TRUE);
gtk_label_set_xalign (GTK_LABEL (priv->text_label), 0.0f);
- gtk_label_set_use_underline (GTK_LABEL (priv->text_label), TRUE);
priv->accel_label = g_object_new (GTK_TYPE_LABEL,
"css-name", "accelerator",
NULL);
@@ -992,3 +1005,32 @@ gtk_accel_label_get_label (GtkAccelLabel *accel_label)
return gtk_label_get_label (GTK_LABEL (priv->text_label));
}
+
+
+void
+gtk_accel_label_set_use_underline (GtkAccelLabel *accel_label,
+ gboolean setting)
+{
+ GtkAccelLabelPrivate *priv = gtk_accel_label_get_instance_private (accel_label);
+
+ g_return_if_fail (GTK_IS_ACCEL_LABEL (accel_label));
+
+ setting = !!setting;
+
+ if (setting != gtk_label_get_use_underline (GTK_LABEL (priv->text_label)))
+ {
+ gtk_label_set_use_underline (GTK_LABEL (priv->text_label), setting);
+
+ g_object_notify_by_pspec (G_OBJECT (accel_label), props[PROP_USE_UNDERLINE]);
+ }
+}
+
+gboolean
+gtk_accel_label_get_use_underline (GtkAccelLabel *accel_label)
+{
+ GtkAccelLabelPrivate *priv = gtk_accel_label_get_instance_private (accel_label);
+
+ g_return_val_if_fail (GTK_IS_ACCEL_LABEL (accel_label), FALSE);
+
+ return gtk_label_get_use_underline (GTK_LABEL (priv->text_label));
+}
diff --git a/gtk/gtkaccellabel.h b/gtk/gtkaccellabel.h
index 678b081..d10004c 100644
--- a/gtk/gtkaccellabel.h
+++ b/gtk/gtkaccellabel.h
@@ -111,6 +111,14 @@ void gtk_accel_label_set_label (GtkAccelLabel *accel_label,
GDK_AVAILABLE_IN_3_92
const char * gtk_accel_label_get_label (GtkAccelLabel *accel_label);
+GDK_AVAILABLE_IN_3_92
+void gtk_accel_label_set_use_underline (GtkAccelLabel *accel_label,
+ gboolean setting);
+
+GDK_AVAILABLE_IN_3_92
+gboolean gtk_accel_label_get_use_underline (GtkAccelLabel *accel_label);
+
+
/* private */
gchar * _gtk_accel_label_class_get_accelerator_label (GtkAccelLabelClass *klass,
guint accelerator_key,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]