summaryrefslogtreecommitdiff
path: root/gtk/gtkcheckbutton.c
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2015-12-16 13:11:24 -0500
committerMatthias Clasen <mclasen@redhat.com>2015-12-16 13:11:24 -0500
commit0291978acc10a8cc4bcff8dbc2600703facd3a0e (patch)
treef1374bc8e9d622cfa79947eb16f8f0fb32e5ffd1 /gtk/gtkcheckbutton.c
parentbb67a06bd6eb200694b41513d1213367364fe7d4 (diff)
downloadgtk+-0291978acc10a8cc4bcff8dbc2600703facd3a0e.tar.gz
check button: Deprecate indicator-size
CSS min-width/min-height can do just the same. We still fall back to the indicator-size style property if the CSS properties are not set.
Diffstat (limited to 'gtk/gtkcheckbutton.c')
-rw-r--r--gtk/gtkcheckbutton.c33
1 files changed, 25 insertions, 8 deletions
diff --git a/gtk/gtkcheckbutton.c b/gtk/gtkcheckbutton.c
index 4d875e33b9..95a58629b1 100644
--- a/gtk/gtkcheckbutton.c
+++ b/gtk/gtkcheckbutton.c
@@ -37,6 +37,7 @@
#include "gtkcsscustomgadgetprivate.h"
#include "gtkcontainerprivate.h"
#include "gtkstylecontextprivate.h"
+#include "gtkcssnumbervalueprivate.h"
#include "gtkradiobutton.h"
@@ -215,6 +216,13 @@ gtk_check_button_class_init (GtkCheckButtonClass *class)
widget_class->state_flags_changed = gtk_check_button_state_flags_changed;
widget_class->direction_changed = gtk_check_button_direction_changed;
+ /**
+ * GtkCheckButton:indicator-size:
+ *
+ * The size of the indicator.
+ *
+ * Deprecated: 3.20: Use CSS min-width and min-height on the indicator node.
+ */
gtk_widget_class_install_style_property (widget_class,
g_param_spec_int ("indicator-size",
P_("Indicator Size"),
@@ -222,7 +230,7 @@ gtk_check_button_class_init (GtkCheckButtonClass *class)
0,
G_MAXINT,
INDICATOR_SIZE,
- GTK_PARAM_READABLE));
+ GTK_PARAM_READABLE|G_PARAM_DEPRECATED));
/**
* GtkCheckButton:indicator-spacing:
@@ -521,15 +529,24 @@ gtk_check_button_measure_check (GtkCssGadget *gadget,
int *natural_baseline,
gpointer unused)
{
- GtkWidget *widget;
- gint indicator_size;
+ gdouble min_size;
+ guint property;
- widget = gtk_css_gadget_get_owner (gadget);
- gtk_widget_style_get (widget,
- "indicator-size", &indicator_size,
- NULL);
+ if (orientation == GTK_ORIENTATION_HORIZONTAL)
+ property = GTK_CSS_PROPERTY_MIN_WIDTH;
+ else
+ property = GTK_CSS_PROPERTY_MIN_HEIGHT;
- *minimum = *natural = indicator_size;
+ min_size = _gtk_css_number_value_get (gtk_css_style_get_value (gtk_css_gadget_get_style (gadget), property), 100);
+ if (min_size > 0.0)
+ *minimum = *natural = 0;
+ else
+ {
+ gtk_widget_style_get (gtk_css_gadget_get_owner (gadget),
+ "indicator-size", minimum,
+ NULL);
+ *natural = *minimum;
+ }
}
static void