diff options
author | Benjamin Otte <otte@redhat.com> | 2010-09-26 00:55:48 +0200 |
---|---|---|
committer | Benjamin Otte <otte@redhat.com> | 2010-09-26 15:11:46 +0200 |
commit | c34c05217c4fc539b4e52d22f635774b00f5bfbe (patch) | |
tree | 990d33260c9d9a4100a89be33bbbdd5192afbf57 /gtk | |
parent | 41e6da407547820d2e0fc5f4ddcfcc5352d8b1b5 (diff) | |
download | gtk+-c34c05217c4fc539b4e52d22f635774b00f5bfbe.tar.gz |
accellabel: Remove gtk_widget_is_drawable() check from draw vfunc
Diffstat (limited to 'gtk')
-rw-r--r-- | gtk/gtkaccellabel.c | 135 |
1 files changed, 65 insertions, 70 deletions
diff --git a/gtk/gtkaccellabel.c b/gtk/gtkaccellabel.c index 41a28b5d74..673c8a64ff 100644 --- a/gtk/gtkaccellabel.c +++ b/gtk/gtkaccellabel.c @@ -383,85 +383,80 @@ gtk_accel_label_draw (GtkWidget *widget, GtkAccelLabel *accel_label = GTK_ACCEL_LABEL (widget); GtkMisc *misc = GTK_MISC (accel_label); GtkTextDirection direction; + guint ac_width; + GtkAllocation allocation; + GtkRequisition requisition; direction = gtk_widget_get_direction (widget); + ac_width = gtk_accel_label_get_accel_width (accel_label); + gtk_widget_get_allocation (widget, &allocation); + gtk_widget_get_preferred_size (widget, &requisition, NULL); - if (gtk_widget_is_drawable (widget)) + if (allocation.width >= requisition.width + ac_width) { - guint ac_width; - GtkAllocation allocation; - GtkRequisition requisition; - - ac_width = gtk_accel_label_get_accel_width (accel_label); - gtk_widget_get_allocation (widget, &allocation); - gtk_widget_get_preferred_size (widget, &requisition, NULL); - - if (allocation.width >= requisition.width + ac_width) - { - PangoLayout *label_layout; - PangoLayout *accel_layout; - GtkLabel *label = GTK_LABEL (widget); - - gint x; - gint y; - gint xpad; - - label_layout = gtk_label_get_layout (GTK_LABEL (accel_label)); - - cairo_save (cr); - - /* XXX: Mad hack: We modify the label's width so it renders - * properly in its draw function that we chain to. */ - if (direction == GTK_TEXT_DIR_RTL) - cairo_translate (cr, ac_width, 0); - if (gtk_label_get_ellipsize (label)) - pango_layout_set_width (label_layout, - pango_layout_get_width (label_layout) - - ac_width * PANGO_SCALE); - - allocation.width -= ac_width; - gtk_widget_set_allocation (widget, &allocation); - if (GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw) - GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw (widget, - cr); - allocation.width += ac_width; - gtk_widget_set_allocation (widget, &allocation); - if (gtk_label_get_ellipsize (label)) - pango_layout_set_width (label_layout, - pango_layout_get_width (label_layout) - + ac_width * PANGO_SCALE); - - cairo_restore (cr); - - gtk_misc_get_padding (misc, &xpad, NULL); - - if (direction == GTK_TEXT_DIR_RTL) - x = xpad; - else - x = gtk_widget_get_allocated_width (widget) - xpad - ac_width; + PangoLayout *label_layout; + PangoLayout *accel_layout; + GtkLabel *label = GTK_LABEL (widget); + + gint x; + gint y; + gint xpad; + + label_layout = gtk_label_get_layout (GTK_LABEL (accel_label)); + + cairo_save (cr); + + /* XXX: Mad hack: We modify the label's width so it renders + * properly in its draw function that we chain to. */ + if (direction == GTK_TEXT_DIR_RTL) + cairo_translate (cr, ac_width, 0); + if (gtk_label_get_ellipsize (label)) + pango_layout_set_width (label_layout, + pango_layout_get_width (label_layout) + - ac_width * PANGO_SCALE); + + allocation.width -= ac_width; + gtk_widget_set_allocation (widget, &allocation); + if (GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw) + GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw (widget, + cr); + allocation.width += ac_width; + gtk_widget_set_allocation (widget, &allocation); + if (gtk_label_get_ellipsize (label)) + pango_layout_set_width (label_layout, + pango_layout_get_width (label_layout) + + ac_width * PANGO_SCALE); + + cairo_restore (cr); + + gtk_misc_get_padding (misc, &xpad, NULL); + + if (direction == GTK_TEXT_DIR_RTL) + x = xpad; + else + x = gtk_widget_get_allocated_width (widget) - xpad - ac_width; - gtk_label_get_layout_offsets (GTK_LABEL (accel_label), NULL, &y); + gtk_label_get_layout_offsets (GTK_LABEL (accel_label), NULL, &y); - accel_layout = gtk_widget_create_pango_layout (widget, gtk_accel_label_get_string (accel_label)); + accel_layout = gtk_widget_create_pango_layout (widget, gtk_accel_label_get_string (accel_label)); - y += get_first_baseline (label_layout) - get_first_baseline (accel_layout) - allocation.y; + y += get_first_baseline (label_layout) - get_first_baseline (accel_layout) - allocation.y; - gtk_paint_layout (gtk_widget_get_style (widget), - cr, - gtk_widget_get_state (widget), - FALSE, - widget, - "accellabel", - x, y, - accel_layout); + gtk_paint_layout (gtk_widget_get_style (widget), + cr, + gtk_widget_get_state (widget), + FALSE, + widget, + "accellabel", + x, y, + accel_layout); - g_object_unref (accel_layout); - } - else - { - if (GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw) - GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw (widget, cr); - } + g_object_unref (accel_layout); + } + else + { + if (GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw) + GTK_WIDGET_CLASS (gtk_accel_label_parent_class)->draw (widget, cr); } return FALSE; |