[gtk-engines] mist: Fix for GTK3 Cairo changes
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk-engines] mist: Fix for GTK3 Cairo changes
- Date: Sun, 26 Sep 2010 13:25:59 +0000 (UTC)
commit e7bbcde41aa1e50b0f50ebb131ca07fd27e099b2
Author: Benjamin Otte <otte redhat com>
Date: Mon Aug 30 13:41:50 2010 +0200
mist: Fix for GTK3 Cairo changes
engines/mist/src/mist-style.c | 185 +++++++++--------------------------------
1 files changed, 40 insertions(+), 145 deletions(-)
---
diff --git a/engines/mist/src/mist-style.c b/engines/mist/src/mist-style.c
index cb524e9..6669739 100644
--- a/engines/mist/src/mist-style.c
+++ b/engines/mist/src/mist-style.c
@@ -118,9 +118,8 @@ mist_draw_border (GtkStyle *style,
static void
mist_style_draw_hline(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x1,
@@ -132,12 +131,9 @@ mist_style_draw_hline(GtkStyle *style,
int thickness_light;
int thickness_dark;
int i;
- cairo_t *cr;
CHECK_ARGS
- cr = ge_gdk_drawable_to_cairo (window, area);
-
if (CHECK_DETAIL(detail, "hseparator")
|| CHECK_DETAIL(detail, "menuitem")
|| CHECK_DETAIL(detail, "slider")
@@ -181,15 +177,12 @@ mist_style_draw_hline(GtkStyle *style,
cairo_stroke (cr);
}
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_vline(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int y1,
@@ -201,12 +194,9 @@ mist_style_draw_vline(GtkStyle *style,
int thickness_light;
int thickness_dark;
int i;
- cairo_t *cr;
CHECK_ARGS
- cr = ge_gdk_drawable_to_cairo (window, area);
-
if (CHECK_DETAIL(detail, "vseparator")
|| CHECK_DETAIL(detail, "toolbar")
|| CHECK_DETAIL(detail, "slider")
@@ -250,16 +240,13 @@ mist_style_draw_vline(GtkStyle *style,
cairo_stroke (cr);
}
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_shadow(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -268,18 +255,14 @@ mist_style_draw_shadow(GtkStyle *style,
int height)
{
MistStyle *mist_style = MIST_STYLE (style);
- cairo_t *cr;
CHECK_ARGS
- SANITIZE_SIZE
shadow_type = mist_get_shadow_type (style, detail, shadow_type);
if (shadow_type == GTK_SHADOW_NONE)
return;
- cr = ge_gdk_drawable_to_cairo (window, area);
-
if (state_type == GTK_STATE_INSENSITIVE) {
shadow_type = GTK_SHADOW_ETCHED_IN;
}
@@ -294,16 +277,13 @@ mist_style_draw_shadow(GtkStyle *style,
mist_draw_border (style, cr, state_type,
shadow_type,x, y, width, height);
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_diamond(GtkStyle * style,
- GdkWindow * window,
+ cairo_t * cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle * area,
GtkWidget * widget,
const char *detail,
int x,
@@ -315,16 +295,12 @@ mist_style_draw_diamond(GtkStyle * style,
int half_width;
int half_height;
- cairo_t *cr;
CHECK_ARGS
- SANITIZE_SIZE
half_width = width / 2;
half_height = height / 2;
- cr = ge_gdk_drawable_to_cairo (window, area);
-
switch (shadow_type) {
case GTK_SHADOW_IN:
ge_cairo_line(cr, &mist_style->color_cube.light[state_type],
@@ -407,16 +383,13 @@ mist_style_draw_diamond(GtkStyle * style,
default:
break;
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_box(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -427,10 +400,8 @@ mist_style_draw_box(GtkStyle *style,
MistStyle *mist_style = MIST_STYLE (style);
CairoColor *light, *dark;
- cairo_t *cr;
CHECK_ARGS
- SANITIZE_SIZE
if (CHECK_DETAIL(detail, "menuitem") && state_type == GTK_STATE_PRELIGHT) {
state_type = GTK_STATE_SELECTED;
@@ -439,12 +410,10 @@ mist_style_draw_box(GtkStyle *style,
light = &mist_style->color_cube.light[state_type];
dark = &mist_style->color_cube.dark[state_type];
- cr = ge_gdk_drawable_to_cairo (window, area);
-
if (CHECK_DETAIL(detail, "optionmenutab")) {
ge_cairo_line(cr, dark, x - 5, y, x - 5, y + height);
- gtk_paint_arrow (style, window, state_type, shadow_type, area,
+ gtk_paint_arrow (style, cr, state_type, shadow_type,
widget, detail, GTK_ARROW_DOWN, TRUE,
x + 1, y + 1, width - 2, height - 2);
} else if (CHECK_DETAIL(detail, "trough")) {
@@ -518,9 +487,9 @@ mist_style_draw_box(GtkStyle *style,
}
}
- gtk_style_apply_default_background(style, window,
- widget && !gtk_widget_get_has_window (widget),
- state_type, area,
+ gtk_style_apply_default_background(style, cr,
+ gtk_widget_get_window (widget),
+ state_type,
x, y, width, height);
shadow_type = mist_get_shadow_type (style, detail, shadow_type);
@@ -534,16 +503,13 @@ mist_style_draw_box(GtkStyle *style,
x, y, width, height);
}
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_check(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -552,11 +518,8 @@ mist_style_draw_check(GtkStyle *style,
int height)
{
MistStyle *mist_style = MIST_STYLE (style);
- cairo_t *cr;
- SANITIZE_SIZE
-
- cr = ge_gdk_drawable_to_cairo (window, area);
+ CHECK_ARGS
ge_cairo_set_color(cr, &mist_style->color_cube.base[state_type == GTK_STATE_INSENSITIVE ? GTK_STATE_INSENSITIVE : GTK_STATE_NORMAL ]);
cairo_rectangle(cr, x + 1, y + 1, width - 3, height - 3);
@@ -596,11 +559,6 @@ mist_style_draw_check(GtkStyle *style,
gdk_cairo_set_source_color (cr,
&style->base[GTK_STATE_SELECTED]);
- if (area) {
- gdk_cairo_rectangle (cr, area);
- cairo_clip (cr);
- }
-
cairo_mask (cr, pattern);
cairo_rectangle (cr, x + 2, y + 2, width - 5, height - 5);
cairo_fill (cr);
@@ -610,16 +568,13 @@ mist_style_draw_check(GtkStyle *style,
#undef gray50_width
#undef gray50_height
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_option(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -628,11 +583,8 @@ mist_style_draw_option(GtkStyle *style,
int height)
{
MistStyle *mist_style = MIST_STYLE (style);
- cairo_t *cr;
-
- SANITIZE_SIZE
- cr = ge_gdk_drawable_to_cairo (window, area);
+ CHECK_ARGS
cairo_arc(cr, x + floor(width/2), y + floor(height/2), floor(width/2) - 0.5, 0 , 2 * G_PI);
ge_cairo_set_color(cr, &mist_style->color_cube.dark[state_type == GTK_STATE_INSENSITIVE ? GTK_STATE_INSENSITIVE : GTK_STATE_NORMAL]);
@@ -674,16 +626,13 @@ mist_style_draw_option(GtkStyle *style,
cairo_arc(cr, x + floor(width/2), y + floor(height/2), floor((width - 7)/2) + 1, 0 , 2 * G_PI);
cairo_fill (cr);
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_shadow_gap(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -698,20 +647,14 @@ mist_style_draw_shadow_gap(GtkStyle *style,
CairoColor *color1 = NULL;
CairoColor *color2 = NULL;
- cairo_t *cr;
gint start;
- g_return_if_fail (window != NULL);
+ CHECK_ARGS
- SANITIZE_SIZE
shadow_type = mist_get_shadow_type (style, detail, shadow_type);
- cr = ge_gdk_drawable_to_cairo (window, area);
-
switch (shadow_type) {
case GTK_SHADOW_NONE:
- /* need to destroy the cairo context. */
- cairo_destroy (cr);
return;
case GTK_SHADOW_IN:
color1 = &mist_style->color_cube.dark[state_type];
@@ -751,16 +694,13 @@ mist_style_draw_shadow_gap(GtkStyle *style,
cairo_clip (cr);
cairo_new_path (cr);
ge_cairo_simple_border (cr, color1, color2, x, y, width, height, FALSE);
-
- cairo_destroy(cr);
}
static void
mist_style_draw_box_gap(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -771,24 +711,23 @@ mist_style_draw_box_gap(GtkStyle *style,
int gap_x,
int gap_width)
{
- SANITIZE_SIZE
+ CHECK_ARGS
- gtk_style_apply_default_background(style, window,
- widget && !gtk_widget_get_has_window (widget),
- state_type, area,
+ gtk_style_apply_default_background(style, cr,
+ gtk_widget_get_window (widget),
+ state_type,
x, y, width, height);
- mist_style_draw_shadow_gap (style, window, state_type, shadow_type,
- area, widget, detail, x, y, width, height,
+ mist_style_draw_shadow_gap (style, cr, state_type, shadow_type,
+ widget, detail, x, y, width, height,
gap_side, gap_x, gap_width);
}
static void
mist_style_draw_extension(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -797,34 +736,21 @@ mist_style_draw_extension(GtkStyle *style,
int height,
GtkPositionType gap_side)
{
- cairo_t *canvas;
CairoColor *background, *light, *dark;
CHECK_ARGS
- SANITIZE_SIZE
-
background = &MIST_STYLE(style)->color_cube.bg[state_type];
light = &MIST_STYLE(style)->color_cube.light[state_type];
dark = &MIST_STYLE(style)->color_cube.dark[state_type];
- canvas = ge_gdk_drawable_to_cairo (window, area);
-
- if ((!style->bg_pixmap[state_type]) || GDK_IS_PIXMAP(window))
- {
- ge_cairo_set_color(canvas, background);
-
- cairo_rectangle(canvas, x, y, width, height);
- cairo_fill(canvas);
- } else {
- gtk_style_apply_default_background
- (style, window,
- widget && !gtk_widget_get_has_window (widget),
- state_type, area, x, y, width, height);
- }
+ gtk_style_apply_default_background
+ (style, cr,
+ gtk_widget_get_window (widget),
+ state_type, x, y, width, height);
- cairo_rectangle (canvas, x, y, width, height);
- cairo_clip (canvas);
+ cairo_rectangle (cr, x, y, width, height);
+ cairo_clip (cr);
switch(gap_side) {
case GTK_POS_BOTTOM:
@@ -843,16 +769,14 @@ mist_style_draw_extension(GtkStyle *style,
break;
}
- ge_cairo_simple_border (canvas, light, dark, x, y, width, height, FALSE);
- cairo_destroy(canvas);
+ ge_cairo_simple_border (cr, light, dark, x, y, width, height, FALSE);
}
static void
mist_style_draw_handle(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
GtkShadowType shadow_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
@@ -866,13 +790,11 @@ mist_style_draw_handle(GtkStyle *style,
CairoColor *light, *dark;
GdkRectangle dest;
int modx, mody;
- cairo_t *cr;
CHECK_ARGS
- SANITIZE_SIZE
if (!ge_is_panel_widget_item (widget) && !ge_object_is_a ((GObject*)widget, "PanelToplevel"))
- gtk_paint_box(style, window, state_type, shadow_type, area, widget,
+ gtk_paint_box(style, cr, state_type, shadow_type, widget,
detail, x, y, width, height);
light = &mist_style->color_cube.light[state_type];
@@ -895,8 +817,6 @@ mist_style_draw_handle(GtkStyle *style,
modx = 0; mody = 4;
}
- cr = ge_gdk_drawable_to_cairo (window, &dest);
-
mist_dot(cr,
light, dark,
x + width / 2 - modx,
@@ -909,15 +829,12 @@ mist_style_draw_handle(GtkStyle *style,
light, dark,
x + width / 2 + modx,
y + height / 2 + mody);
-
- cairo_destroy(cr);
}
static void
mist_style_draw_resize_grip(GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
GdkWindowEdge edge,
@@ -932,10 +849,8 @@ mist_style_draw_resize_grip(GtkStyle *style,
int xi, yi;
int max_x, max_y;
int threshold;
- cairo_t *cr;
CHECK_ARGS
- SANITIZE_SIZE
switch (edge) {
case GDK_WINDOW_EDGE_NORTH_WEST:
@@ -1003,8 +918,9 @@ mist_style_draw_resize_grip(GtkStyle *style,
g_assert_not_reached ();
}
- gtk_style_apply_default_background (style, window, FALSE,
- state_type, area,
+ gtk_style_apply_default_background (style, cr,
+ gtk_widget_get_window (widget),
+ state_type,
x, y, width, height);
light = &mist_style->color_cube.light[state_type];
@@ -1015,8 +931,6 @@ mist_style_draw_resize_grip(GtkStyle *style,
threshold = max_x;
- cr = ge_gdk_drawable_to_cairo (window, area);
-
for (xi = 0; xi <= max_x; xi++) {
for (yi = 0; yi <= max_y; yi++) {
gboolean draw_dot;
@@ -1052,42 +966,28 @@ mist_style_draw_resize_grip(GtkStyle *style,
}
}
}
-
- cairo_destroy(cr);
}
static void
mist_style_draw_layout (GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
gboolean use_text,
- GdkRectangle *area,
GtkWidget *widget,
const char *detail,
int x,
int y,
PangoLayout *layout)
{
- cairo_t *cr;
-
CHECK_ARGS
- cr = gdk_cairo_create (window);
-
if (use_text)
gdk_cairo_set_source_color (cr, &style->text[state_type]);
else
gdk_cairo_set_source_color (cr, &style->fg[state_type]);
- if (area) {
- gdk_cairo_rectangle (cr, area);
- cairo_clip (cr);
- }
-
ge_cairo_transform_for_layout (cr, layout, x, y);
pango_cairo_show_layout (cr, layout);
-
- cairo_destroy (cr);
}
static GdkPixbuf *
@@ -1168,8 +1068,8 @@ mist_style_render_icon (GtkStyle *style,
if (widget && gtk_widget_has_screen (widget)) {
screen = gtk_widget_get_screen (widget);
settings = gtk_settings_get_for_screen (screen);
- } else if (style->colormap) {
- screen = gdk_colormap_get_screen (style->colormap);
+ } else if (style->visual) {
+ screen = gdk_visual_get_screen (style->visual);
settings = gtk_settings_get_for_screen (screen);
} else {
settings = gtk_settings_get_default ();
@@ -1218,9 +1118,8 @@ mist_style_render_icon (GtkStyle *style,
static void
mist_style_draw_focus (GtkStyle *style,
- GdkWindow *window,
+ cairo_t *cr,
GtkStateType state_type,
- GdkRectangle *area,
GtkWidget *widget,
const gchar *detail,
gint x,
@@ -1230,12 +1129,9 @@ mist_style_draw_focus (GtkStyle *style,
{
MistStyle *mist_style = MIST_STYLE (style);
CairoColor *dark;
- cairo_t *cr;
CHECK_ARGS
- SANITIZE_SIZE
- cr = ge_gdk_drawable_to_cairo (window, area);
cairo_translate (cr, 0.5, 0.5);
width--; height--;
@@ -1243,7 +1139,6 @@ mist_style_draw_focus (GtkStyle *style,
ge_cairo_set_color (cr, dark);
cairo_rectangle (cr, x, y, width, height);
cairo_stroke (cr);
- cairo_destroy (cr);
}
static void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]