gtk+ r19455 - in trunk: . modules/engines/ms-windows



Author: bratsche
Date: Fri Feb  1 23:25:18 2008
New Revision: 19455
URL: http://svn.gnome.org/viewvc/gtk+?rev=19455&view=rev

Log:
2008-02-01  Cody Russell  <cody jhu edu>

        * modules/engines/ms-windows/xp_theme.[ch]
        * modules/engines/ms-windows/xp_theme_defs.h
        * modules/engines/ms-windows/msw_rc_style.c
        * modules/engines/ms-windows/msw_theme_main.c
        * modules/engines/ms-windows/msw_style.c: Re-indented and generally
        attempted to stylize more like the rest of the gtk+ stack's code.



Modified:
   trunk/ChangeLog
   trunk/modules/engines/ms-windows/msw_rc_style.c
   trunk/modules/engines/ms-windows/msw_style.c
   trunk/modules/engines/ms-windows/msw_theme_main.c
   trunk/modules/engines/ms-windows/xp_theme.c
   trunk/modules/engines/ms-windows/xp_theme.h
   trunk/modules/engines/ms-windows/xp_theme_defs.h

Modified: trunk/modules/engines/ms-windows/msw_rc_style.c
==============================================================================
--- trunk/modules/engines/ms-windows/msw_rc_style.c	(original)
+++ trunk/modules/engines/ms-windows/msw_rc_style.c	Fri Feb  1 23:25:18 2008
@@ -32,45 +32,45 @@
 GType msw_type_rc_style = 0;
 
 void
-msw_rc_style_register_type (GTypeModule * module)
+msw_rc_style_register_type (GTypeModule *module)
 {
-    static const GTypeInfo object_info = {
-	sizeof (MswRcStyleClass),
-	(GBaseInitFunc) NULL,
-	(GBaseFinalizeFunc) NULL,
-	(GClassInitFunc) msw_rc_style_class_init,
-	NULL,			/* class_finalize */
-	NULL,			/* class_data */
-	sizeof (MswRcStyle),
-	0,			/* n_preallocs */
-	(GInstanceInitFunc) msw_rc_style_init,
-    };
-
-    msw_type_rc_style = g_type_module_register_type (module,
-						     GTK_TYPE_RC_STYLE,
-						     "MswRcStyle",
-						     &object_info, 0);
+  static const GTypeInfo object_info = {
+    sizeof (MswRcStyleClass),
+    (GBaseInitFunc) NULL,
+    (GBaseFinalizeFunc) NULL,
+    (GClassInitFunc) msw_rc_style_class_init,
+    NULL,			/* class_finalize */
+    NULL,			/* class_data */
+    sizeof (MswRcStyle),
+    0,				/* n_preallocs */
+    (GInstanceInitFunc) msw_rc_style_init,
+  };
+
+  msw_type_rc_style = g_type_module_register_type (module,
+						   GTK_TYPE_RC_STYLE,
+						   "MswRcStyle",
+						   &object_info, 0);
 }
 
 static void
-msw_rc_style_init (MswRcStyle * style)
+msw_rc_style_init (MswRcStyle *style)
 {
 }
 
 static void
-msw_rc_style_class_init (MswRcStyleClass * klass)
+msw_rc_style_class_init (MswRcStyleClass *klass)
 {
-    GtkRcStyleClass *rc_style_class = GTK_RC_STYLE_CLASS (klass);
+  GtkRcStyleClass *rc_style_class = GTK_RC_STYLE_CLASS (klass);
 
-    parent_class = g_type_class_peek_parent (klass);
+  parent_class = g_type_class_peek_parent (klass);
 
-    rc_style_class->create_style = msw_rc_style_create_style;
+  rc_style_class->create_style = msw_rc_style_create_style;
 }
 
 /* Create an empty style suitable to this RC style
  */
 static GtkStyle *
-msw_rc_style_create_style (GtkRcStyle * rc_style)
+msw_rc_style_create_style (GtkRcStyle *rc_style)
 {
-    return g_object_new (MSW_TYPE_STYLE, NULL);
+  return g_object_new (MSW_TYPE_STYLE, NULL);
 }

Modified: trunk/modules/engines/ms-windows/msw_style.c
==============================================================================
--- trunk/modules/engines/ms-windows/msw_style.c	(original)
+++ trunk/modules/engines/ms-windows/msw_style.c	Fri Feb  1 23:25:18 2008
@@ -44,8 +44,11 @@
 
 #include "gdk/win32/gdkwin32.h"
 
-static HDC get_window_dc(GtkStyle * style, GdkWindow * window, GtkStateType state_type, gint x, gint y, gint width, gint height, RECT *rect);
-static void release_window_dc(GtkStyle * style, GdkWindow * window, GtkStateType state_type);
+static HDC get_window_dc (GtkStyle *style, GdkWindow *window,
+			  GtkStateType state_type, gint x, gint y, gint width,
+			  gint height, RECT *rect);
+static void release_window_dc (GtkStyle *style, GdkWindow *window,
+			       GtkStateType state_type);
 
 
 /* Default values, not normally used
@@ -61,147 +64,150 @@
 
 typedef enum
 {
-    CHECK_AA,
-    CHECK_BASE,
-    CHECK_BLACK,
-    CHECK_DARK,
-    CHECK_LIGHT,
-    CHECK_MID,
-    CHECK_TEXT,
-    CHECK_INCONSISTENT,
-    RADIO_BASE,
-    RADIO_BLACK,
-    RADIO_DARK,
-    RADIO_LIGHT,
-    RADIO_MID,
-    RADIO_TEXT
+  CHECK_AA,
+  CHECK_BASE,
+  CHECK_BLACK,
+  CHECK_DARK,
+  CHECK_LIGHT,
+  CHECK_MID,
+  CHECK_TEXT,
+  CHECK_INCONSISTENT,
+  RADIO_BASE,
+  RADIO_BLACK,
+  RADIO_DARK,
+  RADIO_LIGHT,
+  RADIO_MID,
+  RADIO_TEXT
 } Part;
 
 #define PART_SIZE 13
 
 static const guint8 check_aa_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
-    0x00, 0x00, 0x00,
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+  0x00, 0x00, 0x00,
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
 };
 static const guint8 check_base_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0xfc, 0x07, 0xfc, 0x07, 0xfc, 0x07, 0xfc, 0x07,
-    0xfc, 0x07, 0xfc,
-    0x07, 0xfc, 0x07, 0xfc, 0x07, 0xfc, 0x07, 0x00, 0x00, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0xfc, 0x07, 0xfc, 0x07, 0xfc, 0x07, 0xfc, 0x07,
+  0xfc, 0x07, 0xfc,
+  0x07, 0xfc, 0x07, 0xfc, 0x07, 0xfc, 0x07, 0x00, 0x00, 0x00, 0x00
 };
 static const guint8 check_black_bits[] = {
-    0x00, 0x00, 0xfe, 0x0f, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00,
-    0x02, 0x00, 0x02,
-    0x00, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00, 0x00
+  0x00, 0x00, 0xfe, 0x0f, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00,
+  0x02, 0x00, 0x02,
+  0x00, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00, 0x00
 };
 static const guint8 check_dark_bits[] = {
-    0xff, 0x1f, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00,
-    0x01, 0x00, 0x01,
-    0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00
+  0xff, 0x1f, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00,
+  0x01, 0x00, 0x01,
+  0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00
 };
 static const guint8 check_light_bits[] = {
-    0x00, 0x00, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10,
-    0x00, 0x10, 0x00,
-    0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0xfe, 0x1f
+  0x00, 0x00, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10,
+  0x00, 0x10, 0x00,
+  0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0x00, 0x10, 0xfe, 0x1f
 };
 static const guint8 check_mid_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x08, 0x00, 0x08, 0x00, 0x08,
-    0x00, 0x08, 0x00,
-    0x08, 0x00, 0x08, 0x00, 0x08, 0x00, 0x08, 0xfc, 0x0f, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x08, 0x00, 0x08, 0x00, 0x08,
+  0x00, 0x08, 0x00,
+  0x08, 0x00, 0x08, 0x00, 0x08, 0x00, 0x08, 0xfc, 0x0f, 0x00, 0x00
 };
 static const guint8 check_text_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x03, 0x88, 0x03,
-    0xd8, 0x01, 0xf8,
-    0x00, 0x70, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x03, 0x88, 0x03,
+  0xd8, 0x01, 0xf8,
+  0x00, 0x70, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
 };
 static const char check_inconsistent_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf0, 0x03, 0xf0,
-    0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
+    0xf0, 0x03, 0xf0,
+  0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
 };
 static const guint8 radio_base_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0xf0, 0x01, 0xf8, 0x03, 0xfc, 0x07, 0xfc, 0x07,
-    0xfc, 0x07, 0xfc,
-    0x07, 0xfc, 0x07, 0xf8, 0x03, 0xf0, 0x01, 0x00, 0x00, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0xf0, 0x01, 0xf8, 0x03, 0xfc, 0x07, 0xfc, 0x07,
+  0xfc, 0x07, 0xfc,
+  0x07, 0xfc, 0x07, 0xf8, 0x03, 0xf0, 0x01, 0x00, 0x00, 0x00, 0x00
 };
 static const guint8 radio_black_bits[] = {
-    0x00, 0x00, 0xf0, 0x01, 0x0c, 0x02, 0x04, 0x00, 0x02, 0x00, 0x02, 0x00,
-    0x02, 0x00, 0x02,
-    0x00, 0x02, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+  0x00, 0x00, 0xf0, 0x01, 0x0c, 0x02, 0x04, 0x00, 0x02, 0x00, 0x02, 0x00,
+  0x02, 0x00, 0x02,
+  0x00, 0x02, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
 };
 static const guint8 radio_dark_bits[] = {
-    0xf0, 0x01, 0x0c, 0x06, 0x02, 0x00, 0x02, 0x00, 0x01, 0x00, 0x01, 0x00,
-    0x01, 0x00, 0x01,
-    0x00, 0x01, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00
+  0xf0, 0x01, 0x0c, 0x06, 0x02, 0x00, 0x02, 0x00, 0x01, 0x00, 0x01, 0x00,
+  0x01, 0x00, 0x01,
+  0x00, 0x01, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00
 };
 static const guint8 radio_light_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x08, 0x00, 0x10, 0x00, 0x10,
-    0x00, 0x10, 0x00,
-    0x10, 0x00, 0x10, 0x00, 0x08, 0x00, 0x08, 0x0c, 0x06, 0xf0, 0x01
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x08, 0x00, 0x10, 0x00, 0x10,
+  0x00, 0x10, 0x00,
+  0x10, 0x00, 0x10, 0x00, 0x08, 0x00, 0x08, 0x0c, 0x06, 0xf0, 0x01
 };
 static const guint8 radio_mid_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x04, 0x00, 0x04, 0x00, 0x08, 0x00, 0x08,
-    0x00, 0x08, 0x00,
-    0x08, 0x00, 0x08, 0x00, 0x04, 0x0c, 0x06, 0xf0, 0x01, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x04, 0x00, 0x04, 0x00, 0x08, 0x00, 0x08,
+  0x00, 0x08, 0x00,
+  0x08, 0x00, 0x08, 0x00, 0x04, 0x0c, 0x06, 0xf0, 0x01, 0x00, 0x00
 };
 static const guint8 radio_text_bits[] = {
-    0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xe0, 0x00, 0xf0, 0x01,
-    0xf0, 0x01, 0xf0,
-    0x01, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
+  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xe0, 0x00, 0xf0, 0x01,
+  0xf0, 0x01, 0xf0,
+  0x01, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
 };
 
 static struct
 {
-    const guint8 *bits;
-    GdkBitmap *bmap;
-} parts[] =
-{
-    {check_aa_bits, NULL},
-    {check_base_bits, NULL},
-    {check_black_bits, NULL},
-    {check_dark_bits, NULL},
-    {check_light_bits, NULL},
-    {check_mid_bits, NULL},
-    {check_text_bits, NULL},
-    {check_inconsistent_bits, NULL},
-    {radio_base_bits, NULL},
-    {radio_black_bits, NULL},
-    {radio_dark_bits, NULL},
-    {radio_light_bits, NULL},
-    {radio_mid_bits, NULL},
-    {radio_text_bits, NULL}
+  const guint8 *bits;
+  GdkBitmap *bmap;
+} parts[] = {
+  { check_aa_bits, NULL           },
+  { check_base_bits, NULL         },
+  { check_black_bits, NULL        },
+  { check_dark_bits, NULL         },
+  { check_light_bits, NULL        },
+  { check_mid_bits, NULL          },
+  { check_text_bits, NULL         },
+  { check_inconsistent_bits, NULL },
+  { radio_base_bits, NULL         },
+  { radio_black_bits, NULL        },
+  { radio_dark_bits, NULL         },
+  { radio_light_bits, NULL        },
+  { radio_mid_bits, NULL          },
+  { radio_text_bits, NULL         }
 };
 
 static gboolean
-get_system_font (XpThemeClass klazz, XpThemeFont type, LOGFONT * out_lf)
+get_system_font (XpThemeClass klazz, XpThemeFont type, LOGFONT *out_lf)
 {
 #if 0
-    /* TODO: this causes crashes later because the font name is in UCS2, and
-       the pango fns don't deal with that gracefully */
-    if (xp_theme_get_system_font (klazz, type, out_lf))
-	return TRUE;
-    else
+  /* TODO: this causes crashes later because the font name is in UCS2, and
+     the pango fns don't deal with that gracefully */
+  if (xp_theme_get_system_font (klazz, type, out_lf))
+    {
+      return TRUE;
+    }
+  else
 #endif
-	{
-	    NONCLIENTMETRICS ncm;
+    {
+      NONCLIENTMETRICS ncm;
 
-	    ncm.cbSize = sizeof (NONCLIENTMETRICS);
+      ncm.cbSize = sizeof (NONCLIENTMETRICS);
 
-	    if (SystemParametersInfo (SPI_GETNONCLIENTMETRICS,
-				      sizeof (NONCLIENTMETRICS), &ncm, 0))
-		{
-		    if (type == XP_THEME_FONT_CAPTION)
-			*out_lf = ncm.lfCaptionFont;
-		    else if (type == XP_THEME_FONT_MENU)
-			*out_lf = ncm.lfMenuFont;
-		    else if (type == XP_THEME_FONT_STATUS)
-			*out_lf = ncm.lfStatusFont;
-		    else
-			*out_lf = ncm.lfMessageFont;
+      if (SystemParametersInfo (SPI_GETNONCLIENTMETRICS,
+				sizeof (NONCLIENTMETRICS), &ncm, 0))
+	{
+	  if (type == XP_THEME_FONT_CAPTION)
+	    *out_lf = ncm.lfCaptionFont;
+	  else if (type == XP_THEME_FONT_MENU)
+	    *out_lf = ncm.lfMenuFont;
+	  else if (type == XP_THEME_FONT_STATUS)
+	    *out_lf = ncm.lfStatusFont;
+	  else
+	    *out_lf = ncm.lfMessageFont;
 
-		    return TRUE;
-		}
+	  return TRUE;
 	}
-    return FALSE;
+    }
+
+  return FALSE;
 }
 
 /***************************** BEGIN STOLEN FROM PANGO *****************************/
@@ -241,176 +247,198 @@
 
 struct name_header
 {
-    guint16 format_selector;
-    guint16 num_records;
-    guint16 string_storage_offset;
+  guint16 format_selector;
+  guint16 num_records;
+  guint16 string_storage_offset;
 };
 
 struct name_record
 {
-    guint16 platform_id;
-    guint16 encoding_id;
-    guint16 language_id;
-    guint16 name_id;
-    guint16 string_length;
-    guint16 string_offset;
+  guint16 platform_id;
+  guint16 encoding_id;
+  guint16 language_id;
+  guint16 name_id;
+  guint16 string_length;
+  guint16 string_offset;
 };
 
 static gboolean
 pango_win32_get_name_header (HDC hdc, struct name_header *header)
 {
-    if (GetFontData (hdc, NAME, 0, header, sizeof (*header)) !=
-	sizeof (*header))
-	return FALSE;
-
-    header->num_records = GUINT16_FROM_BE (header->num_records);
-    header->string_storage_offset =
-	GUINT16_FROM_BE (header->string_storage_offset);
+  if (GetFontData (hdc, NAME, 0, header, sizeof (*header)) != sizeof (*header))
+    return FALSE;
 
-    return TRUE;
+  header->num_records = GUINT16_FROM_BE (header->num_records);
+  header->string_storage_offset = GUINT16_FROM_BE (header->string_storage_offset);
+
+  return TRUE;
 }
 
 static gboolean
 pango_win32_get_name_record (HDC hdc, gint i, struct name_record *record)
 {
-    if (GetFontData (hdc, NAME, 6 + i * sizeof (*record),
-		     record, sizeof (*record)) != sizeof (*record))
-	return FALSE;
-
-    record->platform_id = GUINT16_FROM_BE (record->platform_id);
-    record->encoding_id = GUINT16_FROM_BE (record->encoding_id);
-    record->language_id = GUINT16_FROM_BE (record->language_id);
-    record->name_id = GUINT16_FROM_BE (record->name_id);
-    record->string_length = GUINT16_FROM_BE (record->string_length);
-    record->string_offset = GUINT16_FROM_BE (record->string_offset);
+  if (GetFontData (hdc, NAME, 6 + i * sizeof (*record),
+		   record, sizeof (*record)) != sizeof (*record))
+    {
+      return FALSE;
+    }
 
-    return TRUE;
+  record->platform_id = GUINT16_FROM_BE (record->platform_id);
+  record->encoding_id = GUINT16_FROM_BE (record->encoding_id);
+  record->language_id = GUINT16_FROM_BE (record->language_id);
+  record->name_id = GUINT16_FROM_BE (record->name_id);
+  record->string_length = GUINT16_FROM_BE (record->string_length);
+  record->string_offset = GUINT16_FROM_BE (record->string_offset);
+
+  return TRUE;
 }
 
 static gchar *
-get_family_name (LOGFONT * lfp, HDC pango_win32_hdc)
+get_family_name (LOGFONT *lfp, HDC pango_win32_hdc)
 {
-    HFONT hfont;
-    HFONT oldhfont;
+  HFONT hfont;
+  HFONT oldhfont;
+
+  struct name_header header;
+  struct name_record record;
+
+  gint unicode_ix = -1, mac_ix = -1, microsoft_ix = -1;
+  gint name_ix;
+  gchar *codeset;
 
-    struct name_header header;
-    struct name_record record;
+  gchar *string = NULL;
+  gchar *name;
 
-    gint unicode_ix = -1, mac_ix = -1, microsoft_ix = -1;
-    gint name_ix;
-    gchar *codeset;
+  size_t i, l, nbytes;
 
-    gchar *string = NULL;
-    gchar *name;
+  /* If lfFaceName is ASCII, assume it is the common (English) name for the
+     font. Is this valid? Do some TrueType fonts have different names in
+     French, German, etc, and does the system return these if the locale is
+     set to use French, German, etc? */
+  l = strlen (lfp->lfFaceName);
+  for (i = 0; i < l; i++)
+    {
+      if (lfp->lfFaceName[i] < ' ' || lfp->lfFaceName[i] > '~')
+	{
+	  break;
+	}
+    }
 
-    size_t i, l, nbytes;
+  if (i == l)
+    return g_strdup (lfp->lfFaceName);
 
-    /* If lfFaceName is ASCII, assume it is the common (English) name for the
-       font. Is this valid? Do some TrueType fonts have different names in
-       French, German, etc, and does the system return these if the locale is
-       set to use French, German, etc? */
-    l = strlen (lfp->lfFaceName);
-    for (i = 0; i < l; i++)
-	if (lfp->lfFaceName[i] < ' ' || lfp->lfFaceName[i] > '~')
-	    break;
+  if ((hfont = CreateFontIndirect (lfp)) == NULL)
+    goto fail0;
 
-    if (i == l)
-	return g_strdup (lfp->lfFaceName);
+  if ((oldhfont = (HFONT) SelectObject (pango_win32_hdc, hfont)) == NULL)
+    goto fail1;
 
-    if ((hfont = CreateFontIndirect (lfp)) == NULL)
-	goto fail0;
+  if (!pango_win32_get_name_header (pango_win32_hdc, &header))
+    goto fail2;
 
-    if ((oldhfont = (HFONT) SelectObject (pango_win32_hdc, hfont)) == NULL)
-	goto fail1;
+  PING (("%d name records", header.num_records));
 
-    if (!pango_win32_get_name_header (pango_win32_hdc, &header))
+  for (i = 0; i < header.num_records; i++)
+    {
+      if (!pango_win32_get_name_record (pango_win32_hdc, i, &record))
 	goto fail2;
 
-    PING (("%d name records", header.num_records));
+      if ((record.name_id != 1 && record.name_id != 16) || record.string_length <= 0)
+	continue;
+
+      PING (("platform:%d encoding:%d language:%04x name_id:%d",
+	     record.platform_id, record.encoding_id, record.language_id,
+	     record.name_id));
 
-    for (i = 0; i < header.num_records; i++)
+      if (record.platform_id == APPLE_UNICODE_PLATFORM_ID ||
+	  record.platform_id == ISO_PLATFORM_ID)
+	{
+	  unicode_ix = i;
+	}
+      else if (record.platform_id == MACINTOSH_PLATFORM_ID && record.encoding_id == 0 &&	/* Roman
+												 */
+	       record.language_id == 0)	/* English */
+	{
+	  mac_ix = i;
+	}
+      else if (record.platform_id == MICROSOFT_PLATFORM_ID)
 	{
-	    if (!pango_win32_get_name_record (pango_win32_hdc, i, &record))
-		goto fail2;
+	  if ((microsoft_ix == -1 ||
+	       PRIMARYLANGID (record.language_id) == LANG_ENGLISH) &&
+	      (record.encoding_id == SYMBOL_ENCODING_ID ||
+	       record.encoding_id == UNICODE_ENCODING_ID ||
+	       record.encoding_id == UCS4_ENCODING_ID))
+	    {
+	      microsoft_ix = i;
+	    }
+	}
+    }
 
-	    if ((record.name_id != 1 && record.name_id != 16)
-		|| record.string_length <= 0)
-		continue;
+  if (microsoft_ix >= 0)
+    name_ix = microsoft_ix;
+  else if (mac_ix >= 0)
+    name_ix = mac_ix;
+  else if (unicode_ix >= 0)
+    name_ix = unicode_ix;
+  else
+    goto fail2;
 
-	    PING (("platform:%d encoding:%d language:%04x name_id:%d",
-		   record.platform_id, record.encoding_id, record.language_id,
-		   record.name_id));
+  if (!pango_win32_get_name_record (pango_win32_hdc, name_ix, &record))
+    goto fail2;
 
-	    if (record.platform_id == APPLE_UNICODE_PLATFORM_ID ||
-		record.platform_id == ISO_PLATFORM_ID)
-		unicode_ix = i;
-	    else if (record.platform_id == MACINTOSH_PLATFORM_ID && record.encoding_id == 0 &&	/* Roman
-												 */
-		     record.language_id == 0)	/* English */
-		mac_ix = i;
-	    else if (record.platform_id == MICROSOFT_PLATFORM_ID)
-		if ((microsoft_ix == -1 ||
-		     PRIMARYLANGID (record.language_id) == LANG_ENGLISH) &&
-		    (record.encoding_id == SYMBOL_ENCODING_ID ||
-		     record.encoding_id == UNICODE_ENCODING_ID ||
-		     record.encoding_id == UCS4_ENCODING_ID))
-		    microsoft_ix = i;
-	}
-
-    if (microsoft_ix >= 0)
-	name_ix = microsoft_ix;
-    else if (mac_ix >= 0)
-	name_ix = mac_ix;
-    else if (unicode_ix >= 0)
-	name_ix = unicode_ix;
-    else
-	goto fail2;
+  string = g_malloc (record.string_length + 1);
+  if (GetFontData (pango_win32_hdc, NAME,
+		   header.string_storage_offset + record.string_offset,
+		   string, record.string_length) != record.string_length)
+    goto fail2;
 
-    if (!pango_win32_get_name_record (pango_win32_hdc, name_ix, &record))
-	goto fail2;
+  string[record.string_length] = '\0';
 
-    string = g_malloc (record.string_length + 1);
-    if (GetFontData (pango_win32_hdc, NAME,
-		     header.string_storage_offset + record.string_offset,
-		     string, record.string_length) != record.string_length)
-	goto fail2;
+  if (name_ix == microsoft_ix)
+    {
+      if (record.encoding_id == SYMBOL_ENCODING_ID ||
+	  record.encoding_id == UNICODE_ENCODING_ID)
+	{
+	  codeset = "UTF-16BE";
+	}
+      else
+	{
+	  codeset = "UCS-4BE";
+	}
+    }
+  else if (name_ix == mac_ix)
+    {
+      codeset = "MacRoman";
+    }
+  else				/* name_ix == unicode_ix */
+    {
+      codeset = "UCS-4BE";
+    }
 
-    string[record.string_length] = '\0';
 
-    if (name_ix == microsoft_ix)
-	if (record.encoding_id == SYMBOL_ENCODING_ID ||
-	    record.encoding_id == UNICODE_ENCODING_ID)
-	    codeset = "UTF-16BE";
-	else
-	    codeset = "UCS-4BE";
-    else if (name_ix == mac_ix)
-	codeset = "MacRoman";
-    else			/* name_ix == unicode_ix */
-	codeset = "UCS-4BE";
-
-    name =
-	g_convert (string, record.string_length, "UTF-8", codeset, NULL,
-		   &nbytes, NULL);
-    if (name == NULL)
-	goto fail2;
-    g_free (string);
+  name = g_convert (string, record.string_length, "UTF-8", codeset, NULL,
+		    &nbytes, NULL);
+  if (name == NULL)
+    goto fail2;
 
-    PING (("%s", name));
+  g_free (string);
 
-    SelectObject (pango_win32_hdc, oldhfont);
-    DeleteObject (hfont);
+  PING (("%s", name));
 
-    return name;
+  SelectObject (pango_win32_hdc, oldhfont);
+  DeleteObject (hfont);
 
-  fail2:
-    g_free (string);
-    SelectObject (pango_win32_hdc, oldhfont);
+  return name;
 
-  fail1:
-    DeleteObject (hfont);
+fail2:
+  g_free (string);
+  SelectObject (pango_win32_hdc, oldhfont);
 
-  fail0:
-    return g_locale_to_utf8 (lfp->lfFaceName, -1, NULL, NULL, NULL);
+fail1:
+  DeleteObject (hfont);
+
+fail0:
+  return g_locale_to_utf8 (lfp->lfFaceName, -1, NULL, NULL, NULL);
 }
 
 /***************************** END STOLEN FROM PANGO *****************************/
@@ -419,78 +447,80 @@
 sys_font_to_pango_font (XpThemeClass klazz, XpThemeFont type, char *buf,
 			size_t bufsiz)
 {
-    HDC hDC;
-    HWND hwnd;
-    LOGFONT lf;
-    int pt_size;
-    const char *weight;
-    const char *style;
-    char *font;
+  HDC hDC;
+  HWND hwnd;
+  LOGFONT lf;
+  int pt_size;
+  const char *weight;
+  const char *style;
+  char *font;
 
-    if (get_system_font (klazz, type, &lf))
+  if (get_system_font (klazz, type, &lf))
+    {
+      switch (lf.lfWeight)
 	{
-	    switch (lf.lfWeight)
-		{
-		case FW_THIN:
-		case FW_EXTRALIGHT:
-		    weight = "Ultra-Light";
-		    break;
-
-		case FW_LIGHT:
-		    weight = "Light";
-		    break;
-
-		case FW_BOLD:
-		    weight = "Bold";
-		    break;
-
-		case FW_SEMIBOLD:
-		    weight = "Semi-Bold";
-		    break;
-
-		case FW_ULTRABOLD:
-		    weight = "Ultra-Bold";
-		    break;
-
-		case FW_HEAVY:
-		    weight = "Heavy";
-		    break;
-
-		default:
-		    weight = "";
-		    break;
-		}
+	case FW_THIN:
+	case FW_EXTRALIGHT:
+	  weight = "Ultra-Light";
+	  break;
+
+	case FW_LIGHT:
+	  weight = "Light";
+	  break;
+
+	case FW_BOLD:
+	  weight = "Bold";
+	  break;
+
+	case FW_SEMIBOLD:
+	  weight = "Semi-Bold";
+	  break;
+
+	case FW_ULTRABOLD:
+	  weight = "Ultra-Bold";
+	  break;
+
+	case FW_HEAVY:
+	  weight = "Heavy";
+	  break;
 
-	    if (lf.lfItalic)
-		style = "Italic";
-	    else
-		style = "";
-
-	    hwnd = GetDesktopWindow ();
-	    hDC = GetDC (hwnd);
-	    if (hDC)
-		{
-		    pt_size = -MulDiv (lf.lfHeight, 72,
-				       GetDeviceCaps (hDC, LOGPIXELSY));
-		}
-	    else
-		pt_size = 10;
+	default:
+	  weight = "";
+	  break;
+	}
 
-	    font = get_family_name (&lf, hDC);
+      if (lf.lfItalic)
+	style = "Italic";
+      else
+	style = "";
+
+      hwnd = GetDesktopWindow ();
+      hDC = GetDC (hwnd);
+      if (hDC)
+	{
+	  pt_size = -MulDiv (lf.lfHeight, 72,
+			     GetDeviceCaps (hDC, LOGPIXELSY));
+	}
+      else
+	{
+	  pt_size = 10;
+	}
 
-	    if (hDC)
-	      ReleaseDC (hwnd, hDC);
+      font = get_family_name (&lf, hDC);
 
-	    if(!(font && *font))
-	    	return NULL;
+      if (hDC)
+	ReleaseDC (hwnd, hDC);
 
-	    g_snprintf (buf, bufsiz, "%s %s %s %d", font, style, weight, pt_size);
-	    g_free (font);
+      if (!(font && *font))
+	return NULL;
 
-	    return buf;
-	}
+      g_snprintf (buf, bufsiz, "%s %s %s %d", font, style, weight, pt_size);
+      g_free (font);
 
-    return NULL;
+      return buf;
+    }
+
+  return NULL;
 }
 
 /* missing from ms's header files */
@@ -504,880 +534,878 @@
 #define XP_THEME_CLASS_TEXT XP_THEME_CLASS_BUTTON
 
 static void
-setup_menu_settings (GtkSettings * settings)
+setup_menu_settings (GtkSettings *settings)
 {
-    int menu_delay;
-    gboolean win95 = FALSE;
-    OSVERSIONINFOEX osvi;
-    GObjectClass *klazz = G_OBJECT_GET_CLASS (G_OBJECT (settings));
+  int menu_delay;
+  gboolean win95 = FALSE;
+  OSVERSIONINFOEX osvi;
+  GObjectClass *klazz = G_OBJECT_GET_CLASS (G_OBJECT (settings));
 
-    ZeroMemory (&osvi, sizeof (OSVERSIONINFOEX));
-    osvi.dwOSVersionInfoSize = sizeof (OSVERSIONINFOEX);
+  ZeroMemory (&osvi, sizeof (OSVERSIONINFOEX));
+  osvi.dwOSVersionInfoSize = sizeof (OSVERSIONINFOEX);
 
-    if (!GetVersionEx ((OSVERSIONINFO *) & osvi))
-	win95 = TRUE;		/* assume the worst */
+  if (!GetVersionEx ((OSVERSIONINFO *) & osvi))
+    win95 = TRUE;		/* assume the worst */
 
-    if (osvi.dwPlatformId == VER_PLATFORM_WIN32_WINDOWS)
-	if (osvi.dwMajorVersion == 4 && osvi.dwMinorVersion == 0)
-	    win95 = TRUE;
+  if (osvi.dwPlatformId == VER_PLATFORM_WIN32_WINDOWS)
+    {
+      if (osvi.dwMajorVersion == 4 && osvi.dwMinorVersion == 0)
+	{
+	  win95 = TRUE;
+	}
+    }
 
-    if (!win95)
+  if (!win95)
+    {
+      if (SystemParametersInfo (SPI_GETMENUSHOWDELAY, 0, &menu_delay, 0))
 	{
-	    if (SystemParametersInfo
-		(SPI_GETMENUSHOWDELAY, 0, &menu_delay, 0))
+	  if (klazz)
+	    {
+	      if (g_object_class_find_property
+		  (klazz, "gtk-menu-bar-popup-delay"))
 		{
-		    if (klazz)
-			{
-			    if (g_object_class_find_property
-				(klazz, "gtk-menu-bar-popup-delay"))
-				{
-				    g_object_set (settings,
-						  "gtk-menu-bar-popup-delay",
-						  0, NULL);
-				}
-			    if (g_object_class_find_property
-				(klazz, "gtk-menu-popup-delay"))
-				{
-				    g_object_set (settings,
-						  "gtk-menu-popup-delay",
-						  menu_delay, NULL);
-				}
-			    if (g_object_class_find_property
-				(klazz, "gtk-menu-popdown-delay"))
-				{
-				    g_object_set (settings,
-						  "gtk-menu-popdown-delay",
-						  menu_delay, NULL);
-				}
-			}
+		  g_object_set (settings,
+				"gtk-menu-bar-popup-delay", 0, NULL);
 		}
+	      if (g_object_class_find_property
+		  (klazz, "gtk-menu-popup-delay"))
+		{
+		  g_object_set (settings,
+				"gtk-menu-popup-delay", menu_delay, NULL);
+		}
+	      if (g_object_class_find_property
+		  (klazz, "gtk-menu-popdown-delay"))
+		{
+		  g_object_set (settings,
+				"gtk-menu-popdown-delay", menu_delay, NULL);
+		}
+	    }
 	}
+    }
 }
 
 void
 msw_style_setup_system_settings (void)
 {
-    GtkSettings *settings;
-    int cursor_blink_time;
+  GtkSettings *settings;
+  int cursor_blink_time;
 
-    settings = gtk_settings_get_default ();
-    if (!settings)
-	return;
+  settings = gtk_settings_get_default ();
+  if (!settings)
+    return;
 
-    cursor_blink_time = GetCaretBlinkTime ();
-    g_object_set (settings, "gtk-cursor-blink", cursor_blink_time > 0, NULL);
+  cursor_blink_time = GetCaretBlinkTime ();
+  g_object_set (settings, "gtk-cursor-blink", cursor_blink_time > 0, NULL);
 
-    if (cursor_blink_time > 0)
-	g_object_set (settings, "gtk-cursor-blink-time",
-		      2 * cursor_blink_time, NULL);
+  if (cursor_blink_time > 0)
+    {
+      g_object_set (settings, "gtk-cursor-blink-time",
+		    2 * cursor_blink_time, NULL);
+    }
 
-    g_object_set (settings, "gtk-double-click-distance",
-		  GetSystemMetrics (SM_CXDOUBLECLK), NULL);
-    g_object_set (settings, "gtk-double-click-time", GetDoubleClickTime (),
-		  NULL);
-    g_object_set (settings, "gtk-dnd-drag-threshold",
-		  GetSystemMetrics (SM_CXDRAG), NULL);
+  g_object_set (settings, "gtk-double-click-distance",
+		GetSystemMetrics (SM_CXDOUBLECLK), NULL);
+  g_object_set (settings, "gtk-double-click-time", GetDoubleClickTime (),
+		NULL);
+  g_object_set (settings, "gtk-dnd-drag-threshold",
+		GetSystemMetrics (SM_CXDRAG), NULL);
 
-    setup_menu_settings (settings);
+  setup_menu_settings (settings);
 
-    /*
-       http://developer.gnome.org/doc/API/2.0/gtk/GtkSettings.html
-       http://msdn.microsoft.com/library/default.asp?url=/library/en-us/sysinfo/base/systemparametersinfo.asp
-       http://msdn.microsoft.com/library/default.asp?url=/library/en-us/sysinfo/base/getsystemmetrics.asp */
+  /*
+     http://developer.gnome.org/doc/API/2.0/gtk/GtkSettings.html
+     http://msdn.microsoft.com/library/default.asp?url=/library/en-us/sysinfo/base/systemparametersinfo.asp
+     http://msdn.microsoft.com/library/default.asp?url=/library/en-us/sysinfo/base/getsystemmetrics.asp */
 }
 
 static void
-setup_system_font (GtkStyle * style)
+setup_system_font (GtkStyle *style)
 {
-    char buf[256], *font;	/* It's okay, lfFaceName is smaller than 32
+  char buf[256], *font;		/* It's okay, lfFaceName is smaller than 32
 				   chars */
 
-    if ((font = sys_font_to_pango_font (XP_THEME_CLASS_TEXT,
-					XP_THEME_FONT_MESSAGE,
-					buf, sizeof (buf))) != NULL)
+  if ((font = sys_font_to_pango_font (XP_THEME_CLASS_TEXT,
+				      XP_THEME_FONT_MESSAGE,
+				      buf, sizeof (buf))) != NULL)
+    {
+      if (style->font_desc)
 	{
-	    if (style->font_desc)
-		pango_font_description_free (style->font_desc);
-
-	    style->font_desc = pango_font_description_from_string (font);
+	  pango_font_description_free (style->font_desc);
 	}
+
+      style->font_desc = pango_font_description_from_string (font);
+    }
 }
 
 static void
 sys_color_to_gtk_color (XpThemeClass klazz, int id, GdkColor * pcolor)
 {
-    DWORD color;
+  DWORD color;
 
-    if (!xp_theme_get_system_color (klazz, id, &color))
-	color = GetSysColor (id);
+  if (!xp_theme_get_system_color (klazz, id, &color))
+    color = GetSysColor (id);
 
-    pcolor->pixel = color;
-    pcolor->red = (GetRValue (color) << 8) | GetRValue (color);
-    pcolor->green = (GetGValue (color) << 8) | GetGValue (color);
-    pcolor->blue = (GetBValue (color) << 8) | GetBValue (color);
+  pcolor->pixel = color;
+  pcolor->red = (GetRValue (color) << 8) | GetRValue (color);
+  pcolor->green = (GetGValue (color) << 8) | GetGValue (color);
+  pcolor->blue = (GetBValue (color) << 8) | GetBValue (color);
 }
 
 static int
 get_system_metric (XpThemeClass klazz, int id)
 {
-    int rval;
+  int rval;
 
-    if (!xp_theme_get_system_metric (klazz, id, &rval))
-	rval = GetSystemMetrics (id);
+  if (!xp_theme_get_system_metric (klazz, id, &rval))
+    rval = GetSystemMetrics (id);
 
-    return rval;
+  return rval;
 }
 
 static void
 setup_msw_rc_style (void)
 {
-    char buf[1024], font_buf[256], *font_ptr;
-    char menu_bar_prelight_str[128];
+  char buf[1024], font_buf[256], *font_ptr;
+  char menu_bar_prelight_str[128];
 
-    GdkColor menu_color;
-    GdkColor menu_text_color;
-    GdkColor tooltip_back;
-    GdkColor tooltip_fore;
-    GdkColor btn_fore;
-    GdkColor btn_face;
-    GdkColor progress_back;
-
-    GdkColor fg_prelight;
-    GdkColor bg_prelight;
-    GdkColor base_prelight;
-    GdkColor text_prelight;
-
-    /* Prelight */
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
-			    &fg_prelight);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT,
-			    &bg_prelight);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT,
-			    &base_prelight);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
-			    &text_prelight);
-
-    sys_color_to_gtk_color (XP_THEME_CLASS_MENU, COLOR_MENUTEXT,
-			    &menu_text_color);
-    sys_color_to_gtk_color (XP_THEME_CLASS_MENU, COLOR_MENU, &menu_color);
-
-    /* tooltips */
-    sys_color_to_gtk_color (XP_THEME_CLASS_TOOLTIP, COLOR_INFOTEXT,
-			    &tooltip_fore);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TOOLTIP, COLOR_INFOBK,
-			    &tooltip_back);
-
-    /* text on push buttons. TODO: button shadows, backgrounds, and
-       highlights */
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT, &btn_fore);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE, &btn_face);
-
-    /* progress bar background color */
-    sys_color_to_gtk_color (XP_THEME_CLASS_PROGRESS, COLOR_HIGHLIGHT,
-			    &progress_back);
-
-    /* Enable coloring for menus. */
-    font_ptr =
-	sys_font_to_pango_font (XP_THEME_CLASS_MENU, XP_THEME_FONT_MENU,
-				font_buf, sizeof (font_buf));
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-menu\" = \"msw-default\"\n" "{\n"
-		"GtkMenuItem::toggle-spacing = 8\n"
-		"fg[PRELIGHT] = { %d, %d, %d }\n"
-		"bg[PRELIGHT] = { %d, %d, %d }\n"
-		"text[PRELIGHT] = { %d, %d, %d }\n"
-		"base[PRELIGHT] = { %d, %d, %d }\n"
-		"fg[NORMAL] = { %d, %d, %d }\n"
-		"bg[NORMAL] = { %d, %d, %d }\n" "%s = \"%s\"\n"
-		"}widget_class \"*MenuItem*\" style \"msw-menu\"\n"
-		"widget_class \"*GtkMenu\" style \"msw-menu\"\n"
-		"widget_class \"*GtkMenuShell*\" style \"msw-menu\"\n",
-		fg_prelight.red, fg_prelight.green, fg_prelight.blue,
-		bg_prelight.red, bg_prelight.green, bg_prelight.blue,
-		text_prelight.red, text_prelight.green, text_prelight.blue,
-		base_prelight.red, base_prelight.green, base_prelight.blue,
-		menu_text_color.red, menu_text_color.green,
-		menu_text_color.blue, menu_color.red, menu_color.green,
-		menu_color.blue, (font_ptr ? "font_name" : "#"),
-		(font_ptr ? font_ptr : " font name should go here"));
-    gtk_rc_parse_string (buf);
-
-    if( xp_theme_is_active() ) {
-        *menu_bar_prelight_str = '\0';
-    }
-    else {
-        g_snprintf(menu_bar_prelight_str, sizeof(menu_bar_prelight_str),
-                    "fg[PRELIGHT] = { %d, %d, %d }\n", 
-                    menu_text_color.red, menu_text_color.green, menu_text_color.blue);
-    }
-
-    /* Enable coloring for menu bars. */
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-menu-bar\" = \"msw-menu\"\n"
-		"{\n"
-		"bg[NORMAL] = { %d, %d, %d }\n"
-                "%s"
-		"GtkMenuBar::shadow-type = %d\n"
-        /*
-          FIXME: This should be enabled once gtk+ support
-          GtkMenuBar::prelight-item style property.
-        */
-		/* "GtkMenuBar::prelight-item = 1\n" */
-		"}widget_class \"*MenuBar*\" style \"msw-menu-bar\"\n",
-		btn_face.red, btn_face.green, btn_face.blue,
-                menu_bar_prelight_str,
-                xp_theme_is_active() ? 0 : 2 );
-    gtk_rc_parse_string (buf);
-
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-toolbar\" = \"msw-default\"\n"
-		"{\n"
-		"GtkHandleBox::shadow-type = %s\n"
-		"GtkToolbar::shadow-type = %s\n"
-		"}widget_class \"*HandleBox*\" style \"msw-toolbar\"\n",
-		"etched-in", "etched-in");
-    gtk_rc_parse_string (buf);
-
-    /* enable tooltip fonts */
-    font_ptr =
-	sys_font_to_pango_font (XP_THEME_CLASS_STATUS, XP_THEME_FONT_STATUS,
-				font_buf, sizeof (font_buf));
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-tooltips-caption\" = \"msw-default\"\n"
-		"{fg[NORMAL] = { %d, %d, %d }\n" "%s = \"%s\"\n"
-		"}widget \"gtk-tooltips.GtkLabel\" style \"msw-tooltips-caption\"\n",
-		tooltip_fore.red, tooltip_fore.green, tooltip_fore.blue,
-		(font_ptr ? "font_name" : "#"),
-		(font_ptr ? font_ptr : " font name should go here"));
-    gtk_rc_parse_string (buf);
-
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-tooltips\" = \"msw-default\"\n"
-		"{bg[NORMAL] = { %d, %d, %d }\n"
-		"}widget \"gtk-tooltips*\" style \"msw-tooltips\"\n",
-		tooltip_back.red, tooltip_back.green, tooltip_back.blue);
-    gtk_rc_parse_string (buf);
-
-    /* enable font theming for status bars */
-    font_ptr =
-	sys_font_to_pango_font (XP_THEME_CLASS_STATUS, XP_THEME_FONT_STATUS,
-				font_buf, sizeof (font_buf));
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-status\" = \"msw-default\"\n" "{%s = \"%s\"\n"
-		"bg[NORMAL] = { %d, %d, %d }\n"
-		"}widget_class \"*Status*\" style \"msw-status\"\n",
-		(font_ptr ? "font_name" : "#"),
-		(font_ptr ? font_ptr : " font name should go here"),
-		btn_face.red, btn_face.green, btn_face.blue);
-    gtk_rc_parse_string (buf);
-
-    /* enable coloring for text on buttons TODO: use GetThemeMetric for the
-       border and outside border */
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-button\" = \"msw-default\"\n"
-		"{\n"
-		"bg[NORMAL] = { %d, %d, %d }\n"
-		"bg[PRELIGHT] = { %d, %d, %d }\n"
-		"bg[INSENSITIVE] = { %d, %d, %d }\n"
-		"fg[PRELIGHT] = { %d, %d, %d }\n"
-		"GtkButton::default-border = { 0, 0, 0, 0 }\n"
-		"GtkButton::default-outside-border = { 0, 0, 0, 0 }\n"
-		"GtkButton::child-displacement-x = 1\n"
-		"GtkButton::child-displacement-y = 1\n"
-		"GtkButton::focus-padding = %d\n"
-		"}widget_class \"*Button*\" style \"msw-button\"\n",
-		btn_face.red, btn_face.green, btn_face.blue,
-		btn_face.red, btn_face.green, btn_face.blue,
-		btn_face.red, btn_face.green, btn_face.blue,
-		btn_fore.red, btn_fore.green, btn_fore.blue,
-		xp_theme_is_active() ? 1 : 2 );
-    gtk_rc_parse_string (buf);
-
-    /* enable coloring for progress bars */
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-progress\" = \"msw-default\"\n"
-		"{bg[PRELIGHT] = { %d, %d, %d }\n"
-		"bg[NORMAL] = { %d, %d, %d }\n"
-		"}widget_class \"*Progress*\" style \"msw-progress\"\n",
-		progress_back.red,
-		progress_back.green,
-		progress_back.blue,
-		btn_face.red, btn_face.green, btn_face.blue);
-    gtk_rc_parse_string (buf);
-
-    /* scrollbar thumb width and height */
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-vscrollbar\" = \"msw-default\"\n"
-		"{GtkRange::slider-width = %d\n"
-		"GtkRange::stepper-size = %d\n"
-		"GtkRange::stepper-spacing = 0\n"
-		"GtkRange::trough_border = 0\n"
-		"GtkScale::slider-length = %d\n"
-		"GtkScrollbar::min-slider-length = 8\n"
-		"}widget_class \"*VScrollbar*\" style \"msw-vscrollbar\"\n"
-		"widget_class \"*VScale*\" style \"msw-vscrollbar\"\n",
-		GetSystemMetrics (SM_CYVTHUMB),
-		get_system_metric (XP_THEME_CLASS_SCROLLBAR, SM_CXVSCROLL),
-		11);
-    gtk_rc_parse_string (buf);
-
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-hscrollbar\" = \"msw-default\"\n"
-		"{GtkRange::slider-width = %d\n"
-		"GtkRange::stepper-size = %d\n"
-		"GtkRange::stepper-spacing = 0\n"
-		"GtkRange::trough_border = 0\n"
-		"GtkScale::slider-length = %d\n"
-		"GtkScrollbar::min-slider-length = 8\n"
-		"}widget_class \"*HScrollbar*\" style \"msw-hscrollbar\"\n"
-		"widget_class \"*HScale*\" style \"msw-hscrollbar\"\n",
-		GetSystemMetrics (SM_CXHTHUMB),
-		get_system_metric (XP_THEME_CLASS_SCROLLBAR, SM_CYHSCROLL),
-		11);
-    gtk_rc_parse_string (buf);
-
-    gtk_rc_parse_string (    
-                "style \"msw-scrolled-window\" = \"msw-default\"\n"
-                "{GtkScrolledWindow::scrollbars-within-bevel = 1}\n"
-                "class \"GtkScrolledWindow\" style \"msw-scrolled-window\"\n");
-
-    /* radio/check button sizes */
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-checkbutton\" = \"msw-button\"\n"
-		"{GtkCheckButton::indicator-size = 13\n"
-		"}widget_class \"*CheckButton*\" style \"msw-checkbutton\"\n"
-		"widget_class \"*RadioButton*\" style \"msw-checkbutton\"\n");
-    gtk_rc_parse_string (buf);
-
-    /* size of combo box toggle button */
-    g_snprintf (buf, sizeof(buf),
-		"style \"msw-combobox-button\" = \"msw-default\"\n"
-		"{\n"
-		"xthickness = 0\n"
-		"ythickness = 0\n"
-		"GtkButton::default-border = { 0, 0, 0, 0 }\n"
-		"GtkButton::default-outside-border = { 0, 0, 0, 0 }\n"
-		"GtkButton::child-displacement-x = 0\n"
-		"GtkButton::child-displacement-y = 0\n"
-		"GtkWidget::focus-padding = 0\n"
-		"GtkWidget::focus-line-width = 0\n"
-		"}\n"
-		"widget_class \"*ComboBox*ToggleButton*\" style \"msw-combobox-button\"\n");
-    gtk_rc_parse_string (buf);
-
-    g_snprintf (buf, sizeof(buf),
-		"style \"msw-combobox\" = \"msw-default\"\n"
-		"{\n"
-		"GtkComboBox::shadow-type = in\n"
-		"xthickness = %d\n"
-		"ythickness = %d\n"
-		"}\n"
-		"class \"GtkComboBox\" style \"msw-combobox\"\n",
-		GetSystemMetrics (SM_CXEDGE),
-		GetSystemMetrics (SM_CYEDGE));
-    gtk_rc_parse_string (buf);
-
-    /* size of tree view header */
-    g_snprintf (buf, sizeof(buf),
-	    "style \"msw-header-button\" = \"msw-default\"\n"
-	    "{\n"
-  	    "xthickness = 4\n"
-  	    "ythickness = %d\n"
-  	    "GtkButton::default-border = { 0, 0, 0, 0 }\n"
-  	    "GtkButton::default-outside-border = { 0, 0, 0, 0 }\n"
-  	    "GtkButton::child-displacement-x = 1\n"
-  	    "GtkButton::child-displacement-y = 1\n"
-  	    "GtkWidget::focus-padding = 0\n"
-  	    "GtkWidget::focus-line-width = 0\n"
-	    "}\n"
-	    "widget_class \"*TreeView*Button*\" style \"msw-header-button\"\n",
-            xp_theme_is_active() ? 2 : 0 );
-    gtk_rc_parse_string (buf);
-
-    /* FIXME: This should be enabled once gtk+ support GtkNotebok::prelight-tab */
-    /* enable prelight tab of GtkNotebook */
-    /*
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-notebook\" = \"msw-default\"\n"
-		"{GtkNotebook::prelight-tab=1\n"
-		"}widget_class \"*Notebook*\" style \"msw-notebook\"\n");
-    gtk_rc_parse_string (buf);
-    */
-
-    /* FIXME: This should be enabled once gtk+ support GtkTreeView::full-row-focus */
-    /*
-    g_snprintf (buf, sizeof (buf),
-		"style \"msw-treeview\" = \"msw-default\"\n"
-		"{GtkTreeView::full-row-focus=0\n"
-		"}widget_class \"*TreeView*\" style \"msw-treeview\"\n");
-    gtk_rc_parse_string (buf);
-    */
-}
-
-static void
-setup_system_styles (GtkStyle * style)
-{
-    int i;
-
-    /* Default background */
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
-			    &style->bg[GTK_STATE_NORMAL]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT,
-			    &style->bg[GTK_STATE_SELECTED]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
-			    &style->bg[GTK_STATE_INSENSITIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
-			    &style->bg[GTK_STATE_ACTIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
-			    &style->bg[GTK_STATE_PRELIGHT]);
-
-    /* Default base */
-    sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOW,
-			    &style->base[GTK_STATE_NORMAL]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT,
-			    &style->base[GTK_STATE_SELECTED]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
-			    &style->base[GTK_STATE_INSENSITIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
-			    &style->base[GTK_STATE_ACTIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOW,
-			    &style->base[GTK_STATE_PRELIGHT]);
-
-    /* Default text */
-    sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOWTEXT,
-			    &style->text[GTK_STATE_NORMAL]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
-			    &style->text[GTK_STATE_SELECTED]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_GRAYTEXT,
-			    &style->text[GTK_STATE_INSENSITIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT,
-			    &style->text[GTK_STATE_ACTIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOWTEXT,
-			    &style->text[GTK_STATE_PRELIGHT]);
-
-    /* Default foreground */
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT,
-			    &style->fg[GTK_STATE_NORMAL]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
-			    &style->fg[GTK_STATE_SELECTED]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_GRAYTEXT,
-			    &style->fg[GTK_STATE_INSENSITIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT,
-			    &style->fg[GTK_STATE_ACTIVE]);
-    sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOWTEXT,
-			    &style->fg[GTK_STATE_PRELIGHT]);
-
-    for (i = 0; i < 5; i++)
-	{
-	    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_3DSHADOW,
-				    &style->dark[i]);
-	    sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_3DHILIGHT,
-				    &style->light[i]);
-
-	    style->mid[i].red =
-		(style->light[i].red + style->dark[i].red) / 2;
-	    style->mid[i].green =
-		(style->light[i].green + style->dark[i].green) / 2;
-	    style->mid[i].blue =
-		(style->light[i].blue + style->dark[i].blue) / 2;
-
-	    style->text_aa[i].red =
-		(style->text[i].red + style->base[i].red) / 2;
-	    style->text_aa[i].green =
-		(style->text[i].green + style->base[i].green) / 2;
-	    style->text_aa[i].blue =
-		(style->text[i].blue + style->base[i].blue) / 2;
-	}
+  GdkColor menu_color;
+  GdkColor menu_text_color;
+  GdkColor tooltip_back;
+  GdkColor tooltip_fore;
+  GdkColor btn_fore;
+  GdkColor btn_face;
+  GdkColor progress_back;
+
+  GdkColor fg_prelight;
+  GdkColor bg_prelight;
+  GdkColor base_prelight;
+  GdkColor text_prelight;
+
+  /* Prelight */
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
+			  &fg_prelight);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT, &bg_prelight);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT,
+			  &base_prelight);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
+			  &text_prelight);
+
+  sys_color_to_gtk_color (XP_THEME_CLASS_MENU, COLOR_MENUTEXT,
+			  &menu_text_color);
+  sys_color_to_gtk_color (XP_THEME_CLASS_MENU, COLOR_MENU, &menu_color);
+
+  /* tooltips */
+  sys_color_to_gtk_color (XP_THEME_CLASS_TOOLTIP, COLOR_INFOTEXT,
+			  &tooltip_fore);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TOOLTIP, COLOR_INFOBK,
+			  &tooltip_back);
+
+  /* text on push buttons. TODO: button shadows, backgrounds, and
+     highlights */
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT, &btn_fore);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE, &btn_face);
+
+  /* progress bar background color */
+  sys_color_to_gtk_color (XP_THEME_CLASS_PROGRESS, COLOR_HIGHLIGHT,
+			  &progress_back);
+
+  /* Enable coloring for menus. */
+  font_ptr =
+    sys_font_to_pango_font (XP_THEME_CLASS_MENU, XP_THEME_FONT_MENU,
+			    font_buf, sizeof (font_buf));
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-menu\" = \"msw-default\"\n" "{\n"
+	      "GtkMenuItem::toggle-spacing = 8\n"
+	      "fg[PRELIGHT] = { %d, %d, %d }\n"
+	      "bg[PRELIGHT] = { %d, %d, %d }\n"
+	      "text[PRELIGHT] = { %d, %d, %d }\n"
+	      "base[PRELIGHT] = { %d, %d, %d }\n"
+	      "fg[NORMAL] = { %d, %d, %d }\n"
+	      "bg[NORMAL] = { %d, %d, %d }\n" "%s = \"%s\"\n"
+	      "}widget_class \"*MenuItem*\" style \"msw-menu\"\n"
+	      "widget_class \"*GtkMenu\" style \"msw-menu\"\n"
+	      "widget_class \"*GtkMenuShell*\" style \"msw-menu\"\n",
+	      fg_prelight.red, fg_prelight.green, fg_prelight.blue,
+	      bg_prelight.red, bg_prelight.green, bg_prelight.blue,
+	      text_prelight.red, text_prelight.green, text_prelight.blue,
+	      base_prelight.red, base_prelight.green, base_prelight.blue,
+	      menu_text_color.red, menu_text_color.green,
+	      menu_text_color.blue, menu_color.red, menu_color.green,
+	      menu_color.blue, (font_ptr ? "font_name" : "#"),
+	      (font_ptr ? font_ptr : " font name should go here"));
+  gtk_rc_parse_string (buf);
+
+  if (xp_theme_is_active ())
+    {
+      *menu_bar_prelight_str = '\0';
+    }
+  else
+    {
+      g_snprintf (menu_bar_prelight_str, sizeof (menu_bar_prelight_str),
+		  "fg[PRELIGHT] = { %d, %d, %d }\n",
+		  menu_text_color.red, menu_text_color.green,
+		  menu_text_color.blue);
+    }
+
+  /* Enable coloring for menu bars. */
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-menu-bar\" = \"msw-menu\"\n"
+	      "{\n"
+	      "bg[NORMAL] = { %d, %d, %d }\n"
+	      "%s" "GtkMenuBar::shadow-type = %d\n"
+	      /*
+	         FIXME: This should be enabled once gtk+ support
+	         GtkMenuBar::prelight-item style property.
+	       */
+	      /* "GtkMenuBar::prelight-item = 1\n" */
+	      "}widget_class \"*MenuBar*\" style \"msw-menu-bar\"\n",
+	      btn_face.red, btn_face.green, btn_face.blue,
+	      menu_bar_prelight_str, xp_theme_is_active ()? 0 : 2);
+  gtk_rc_parse_string (buf);
+
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-toolbar\" = \"msw-default\"\n"
+	      "{\n"
+	      "GtkHandleBox::shadow-type = %s\n"
+	      "GtkToolbar::shadow-type = %s\n"
+	      "}widget_class \"*HandleBox*\" style \"msw-toolbar\"\n",
+	      "etched-in", "etched-in");
+  gtk_rc_parse_string (buf);
+
+  /* enable tooltip fonts */
+  font_ptr = sys_font_to_pango_font (XP_THEME_CLASS_STATUS, XP_THEME_FONT_STATUS,
+				     font_buf, sizeof (font_buf));
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-tooltips-caption\" = \"msw-default\"\n"
+	      "{fg[NORMAL] = { %d, %d, %d }\n" "%s = \"%s\"\n"
+	      "}widget \"gtk-tooltips.GtkLabel\" style \"msw-tooltips-caption\"\n",
+	      tooltip_fore.red, tooltip_fore.green, tooltip_fore.blue,
+	      (font_ptr ? "font_name" : "#"),
+	      (font_ptr ? font_ptr : " font name should go here"));
+  gtk_rc_parse_string (buf);
+
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-tooltips\" = \"msw-default\"\n"
+	      "{bg[NORMAL] = { %d, %d, %d }\n"
+	      "}widget \"gtk-tooltips*\" style \"msw-tooltips\"\n",
+	      tooltip_back.red, tooltip_back.green, tooltip_back.blue);
+  gtk_rc_parse_string (buf);
+
+  /* enable font theming for status bars */
+  font_ptr = sys_font_to_pango_font (XP_THEME_CLASS_STATUS, XP_THEME_FONT_STATUS,
+				     font_buf, sizeof (font_buf));
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-status\" = \"msw-default\"\n" "{%s = \"%s\"\n"
+	      "bg[NORMAL] = { %d, %d, %d }\n"
+	      "}widget_class \"*Status*\" style \"msw-status\"\n",
+	      (font_ptr ? "font_name" : "#"),
+	      (font_ptr ? font_ptr : " font name should go here"),
+	      btn_face.red, btn_face.green, btn_face.blue);
+  gtk_rc_parse_string (buf);
+
+  /* enable coloring for text on buttons TODO: use GetThemeMetric for the
+     border and outside border */
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-button\" = \"msw-default\"\n"
+	      "{\n"
+	      "bg[NORMAL] = { %d, %d, %d }\n"
+	      "bg[PRELIGHT] = { %d, %d, %d }\n"
+	      "bg[INSENSITIVE] = { %d, %d, %d }\n"
+	      "fg[PRELIGHT] = { %d, %d, %d }\n"
+	      "GtkButton::default-border = { 0, 0, 0, 0 }\n"
+	      "GtkButton::default-outside-border = { 0, 0, 0, 0 }\n"
+	      "GtkButton::child-displacement-x = 1\n"
+	      "GtkButton::child-displacement-y = 1\n"
+	      "GtkButton::focus-padding = %d\n"
+	      "}widget_class \"*Button*\" style \"msw-button\"\n",
+	      btn_face.red, btn_face.green, btn_face.blue,
+	      btn_face.red, btn_face.green, btn_face.blue,
+	      btn_face.red, btn_face.green, btn_face.blue,
+	      btn_fore.red, btn_fore.green, btn_fore.blue,
+	      xp_theme_is_active ()? 1 : 2);
+  gtk_rc_parse_string (buf);
+
+  /* enable coloring for progress bars */
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-progress\" = \"msw-default\"\n"
+	      "{bg[PRELIGHT] = { %d, %d, %d }\n"
+	      "bg[NORMAL] = { %d, %d, %d }\n"
+	      "}widget_class \"*Progress*\" style \"msw-progress\"\n",
+	      progress_back.red,
+	      progress_back.green,
+	      progress_back.blue,
+	      btn_face.red, btn_face.green, btn_face.blue);
+  gtk_rc_parse_string (buf);
+
+  /* scrollbar thumb width and height */
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-vscrollbar\" = \"msw-default\"\n"
+	      "{GtkRange::slider-width = %d\n"
+	      "GtkRange::stepper-size = %d\n"
+	      "GtkRange::stepper-spacing = 0\n"
+	      "GtkRange::trough_border = 0\n"
+	      "GtkScale::slider-length = %d\n"
+	      "GtkScrollbar::min-slider-length = 8\n"
+	      "}widget_class \"*VScrollbar*\" style \"msw-vscrollbar\"\n"
+	      "widget_class \"*VScale*\" style \"msw-vscrollbar\"\n",
+	      GetSystemMetrics (SM_CYVTHUMB),
+	      get_system_metric (XP_THEME_CLASS_SCROLLBAR, SM_CXVSCROLL), 11);
+  gtk_rc_parse_string (buf);
+
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-hscrollbar\" = \"msw-default\"\n"
+	      "{GtkRange::slider-width = %d\n"
+	      "GtkRange::stepper-size = %d\n"
+	      "GtkRange::stepper-spacing = 0\n"
+	      "GtkRange::trough_border = 0\n"
+	      "GtkScale::slider-length = %d\n"
+	      "GtkScrollbar::min-slider-length = 8\n"
+	      "}widget_class \"*HScrollbar*\" style \"msw-hscrollbar\"\n"
+	      "widget_class \"*HScale*\" style \"msw-hscrollbar\"\n",
+	      GetSystemMetrics (SM_CXHTHUMB),
+	      get_system_metric (XP_THEME_CLASS_SCROLLBAR, SM_CYHSCROLL), 11);
+  gtk_rc_parse_string (buf);
+
+  gtk_rc_parse_string ("style \"msw-scrolled-window\" = \"msw-default\"\n"
+		       "{GtkScrolledWindow::scrollbars-within-bevel = 1}\n"
+		       "class \"GtkScrolledWindow\" style \"msw-scrolled-window\"\n");
+
+  /* radio/check button sizes */
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-checkbutton\" = \"msw-button\"\n"
+	      "{GtkCheckButton::indicator-size = 13\n"
+	      "}widget_class \"*CheckButton*\" style \"msw-checkbutton\"\n"
+	      "widget_class \"*RadioButton*\" style \"msw-checkbutton\"\n");
+  gtk_rc_parse_string (buf);
+
+  /* size of combo box toggle button */
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-combobox-button\" = \"msw-default\"\n"
+	      "{\n"
+	      "xthickness = 0\n"
+	      "ythickness = 0\n"
+	      "GtkButton::default-border = { 0, 0, 0, 0 }\n"
+	      "GtkButton::default-outside-border = { 0, 0, 0, 0 }\n"
+	      "GtkButton::child-displacement-x = 0\n"
+	      "GtkButton::child-displacement-y = 0\n"
+	      "GtkWidget::focus-padding = 0\n"
+	      "GtkWidget::focus-line-width = 0\n"
+	      "}\n"
+	      "widget_class \"*ComboBox*ToggleButton*\" style \"msw-combobox-button\"\n");
+  gtk_rc_parse_string (buf);
+
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-combobox\" = \"msw-default\"\n"
+	      "{\n"
+	      "GtkComboBox::shadow-type = in\n"
+	      "xthickness = %d\n"
+	      "ythickness = %d\n"
+	      "}\n"
+	      "class \"GtkComboBox\" style \"msw-combobox\"\n",
+	      GetSystemMetrics (SM_CXEDGE), GetSystemMetrics (SM_CYEDGE));
+  gtk_rc_parse_string (buf);
+
+  /* size of tree view header */
+  g_snprintf (buf, sizeof (buf),
+	      "style \"msw-header-button\" = \"msw-default\"\n"
+	      "{\n"
+	      "xthickness = 4\n"
+	      "ythickness = %d\n"
+	      "GtkButton::default-border = { 0, 0, 0, 0 }\n"
+	      "GtkButton::default-outside-border = { 0, 0, 0, 0 }\n"
+	      "GtkButton::child-displacement-x = 1\n"
+	      "GtkButton::child-displacement-y = 1\n"
+	      "GtkWidget::focus-padding = 0\n"
+	      "GtkWidget::focus-line-width = 0\n"
+	      "}\n"
+	      "widget_class \"*TreeView*Button*\" style \"msw-header-button\"\n",
+	      xp_theme_is_active ()? 2 : 0);
+  gtk_rc_parse_string (buf);
+
+  /* FIXME: This should be enabled once gtk+ support GtkNotebok::prelight-tab */
+  /* enable prelight tab of GtkNotebook */
+  /*
+     g_snprintf (buf, sizeof (buf),
+     "style \"msw-notebook\" = \"msw-default\"\n"
+     "{GtkNotebook::prelight-tab=1\n"
+     "}widget_class \"*Notebook*\" style \"msw-notebook\"\n");
+     gtk_rc_parse_string (buf);
+   */
+
+  /* FIXME: This should be enabled once gtk+ support GtkTreeView::full-row-focus */
+  /*
+     g_snprintf (buf, sizeof (buf),
+     "style \"msw-treeview\" = \"msw-default\"\n"
+     "{GtkTreeView::full-row-focus=0\n"
+     "}widget_class \"*TreeView*\" style \"msw-treeview\"\n");
+     gtk_rc_parse_string (buf);
+   */
+}
+
+static void
+setup_system_styles (GtkStyle *style)
+{
+  int i;
+
+  /* Default background */
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
+			  &style->bg[GTK_STATE_NORMAL]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT,
+			  &style->bg[GTK_STATE_SELECTED]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
+			  &style->bg[GTK_STATE_INSENSITIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
+			  &style->bg[GTK_STATE_ACTIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
+			  &style->bg[GTK_STATE_PRELIGHT]);
+
+  /* Default base */
+  sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOW,
+			  &style->base[GTK_STATE_NORMAL]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHT,
+			  &style->base[GTK_STATE_SELECTED]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
+			  &style->base[GTK_STATE_INSENSITIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNFACE,
+			  &style->base[GTK_STATE_ACTIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOW,
+			  &style->base[GTK_STATE_PRELIGHT]);
+
+  /* Default text */
+  sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOWTEXT,
+			  &style->text[GTK_STATE_NORMAL]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
+			  &style->text[GTK_STATE_SELECTED]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_GRAYTEXT,
+			  &style->text[GTK_STATE_INSENSITIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT,
+			  &style->text[GTK_STATE_ACTIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOWTEXT,
+			  &style->text[GTK_STATE_PRELIGHT]);
+
+  /* Default foreground */
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT,
+			  &style->fg[GTK_STATE_NORMAL]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_HIGHLIGHTTEXT,
+			  &style->fg[GTK_STATE_SELECTED]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_TEXT, COLOR_GRAYTEXT,
+			  &style->fg[GTK_STATE_INSENSITIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_BTNTEXT,
+			  &style->fg[GTK_STATE_ACTIVE]);
+  sys_color_to_gtk_color (XP_THEME_CLASS_WINDOW, COLOR_WINDOWTEXT,
+			  &style->fg[GTK_STATE_PRELIGHT]);
+
+  for (i = 0; i < 5; i++)
+    {
+      sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_3DSHADOW,
+			      &style->dark[i]);
+      sys_color_to_gtk_color (XP_THEME_CLASS_BUTTON, COLOR_3DHILIGHT,
+			      &style->light[i]);
+
+      style->mid[i].red = (style->light[i].red + style->dark[i].red) / 2;
+      style->mid[i].green =
+	(style->light[i].green + style->dark[i].green) / 2;
+      style->mid[i].blue = (style->light[i].blue + style->dark[i].blue) / 2;
+
+      style->text_aa[i].red = (style->text[i].red + style->base[i].red) / 2;
+      style->text_aa[i].green =
+	(style->text[i].green + style->base[i].green) / 2;
+      style->text_aa[i].blue =
+	(style->text[i].blue + style->base[i].blue) / 2;
+    }
 }
 
 static gboolean
-sanitize_size (GdkWindow * window, gint * width, gint * height)
+sanitize_size (GdkWindow *window, gint *width, gint *height)
 {
-    gboolean set_bg = FALSE;
+  gboolean set_bg = FALSE;
 
-    if ((*width == -1) && (*height == -1))
-	{
-	    set_bg = GDK_IS_WINDOW (window);
-	    gdk_drawable_get_size (window, width, height);
-	}
-    else if (*width == -1)
-	gdk_drawable_get_size (window, width, NULL);
-    else if (*height == -1)
-	gdk_drawable_get_size (window, NULL, height);
+  if ((*width == -1) && (*height == -1))
+    {
+      set_bg = GDK_IS_WINDOW (window);
+      gdk_drawable_get_size (window, width, height);
+    }
+  else if (*width == -1)
+    {
+      gdk_drawable_get_size (window, width, NULL);
+    }
+  else if (*height == -1)
+    {
+      gdk_drawable_get_size (window, NULL, height);
+    }
 
-    return set_bg;
+  return set_bg;
 }
 
 static XpThemeElement
-map_gtk_progress_bar_to_xp (GtkProgressBar * progress_bar, gboolean trough)
+map_gtk_progress_bar_to_xp (GtkProgressBar *progress_bar, gboolean trough)
 {
-    XpThemeElement ret;
+  XpThemeElement ret;
 
-    switch (progress_bar->orientation)
-	{
-	case GTK_PROGRESS_LEFT_TO_RIGHT:
-	case GTK_PROGRESS_RIGHT_TO_LEFT:
-	    ret = trough
-		? XP_THEME_ELEMENT_PROGRESS_TROUGH_H
-		: XP_THEME_ELEMENT_PROGRESS_BAR_H;
-	    break;
-	default:
-	    ret = trough
-		? XP_THEME_ELEMENT_PROGRESS_TROUGH_V
-		: XP_THEME_ELEMENT_PROGRESS_BAR_V;
-	    break;
-	}
-    return ret;
+  switch (progress_bar->orientation)
+    {
+    case GTK_PROGRESS_LEFT_TO_RIGHT:
+    case GTK_PROGRESS_RIGHT_TO_LEFT:
+      ret = trough
+	? XP_THEME_ELEMENT_PROGRESS_TROUGH_H
+	: XP_THEME_ELEMENT_PROGRESS_BAR_H;
+      break;
+
+    default:
+      ret = trough
+	? XP_THEME_ELEMENT_PROGRESS_TROUGH_V
+	: XP_THEME_ELEMENT_PROGRESS_BAR_V;
+      break;
+    }
+
+  return ret;
 }
 
 static gboolean
-is_combo_box_child (GtkWidget* w)
+is_combo_box_child (GtkWidget *w)
 {
-    GtkWidget* tmp;
+  GtkWidget *tmp;
 
-    if (w == NULL)
-	return FALSE;
+  if (w == NULL)
+    return FALSE;
 
-    for (tmp = w->parent; tmp; tmp = tmp->parent)
-	{
-	    if (GTK_IS_COMBO_BOX(tmp))
-		return TRUE;
-	}
+  for (tmp = w->parent; tmp; tmp = tmp->parent)
+    {
+      if (GTK_IS_COMBO_BOX (tmp))
+	return TRUE;
+    }
 
-    return FALSE;
+  return FALSE;
 }
 
 static gboolean
-combo_box_draw_arrow (GtkStyle * style,
-	    GdkWindow * window,
-	    GtkStateType state,
-	    GdkRectangle * area,
-	    GtkWidget * widget)
+combo_box_draw_arrow (GtkStyle *style,
+		      GdkWindow *window,
+		      GtkStateType state,
+		      GdkRectangle *area, GtkWidget *widget)
 {
-    if (xp_theme_is_active ())
-        return TRUE;
+  if (xp_theme_is_active ())
+    return TRUE;
 
-    if (widget && GTK_IS_TOGGLE_BUTTON(widget->parent) )
+  if (widget && GTK_IS_TOGGLE_BUTTON (widget->parent))
     {
-	DWORD border;
-        RECT rect;
-        HDC dc;
+      DWORD border;
+      RECT rect;
+      HDC dc;
 
-        dc = get_window_dc( style, window, state, area->x, area->y, area->width, area->height, &rect );
-	border = (GTK_TOGGLE_BUTTON(widget->parent)->active ? DFCS_PUSHED|DFCS_FLAT : 0);
+      dc = get_window_dc (style, window, state, area->x, area->y, area->width,
+			  area->height, &rect);
+      border = (GTK_TOGGLE_BUTTON (widget->parent)->
+		active ? DFCS_PUSHED | DFCS_FLAT : 0);
 
-        InflateRect( &rect, 1, 1 );
-        DrawFrameControl (dc, &rect, DFC_SCROLL, DFCS_SCROLLDOWN | border);
+      InflateRect (&rect, 1, 1);
+      DrawFrameControl (dc, &rect, DFC_SCROLL, DFCS_SCROLLDOWN | border);
 
-        release_window_dc( style, window, state );
-        return TRUE;
+      release_window_dc (style, window, state);
+
+      return TRUE;
     }
 
-    return FALSE;
+  return FALSE;
 }
 
 static void
-draw_part (GdkDrawable * drawable,
-	   GdkGC * gc, GdkRectangle * area, gint x, gint y, Part part)
+draw_part (GdkDrawable *drawable,
+	   GdkGC *gc, GdkRectangle *area, gint x, gint y, Part part)
 {
-    if (area)
-	gdk_gc_set_clip_rectangle (gc, area);
+  if (area)
+    gdk_gc_set_clip_rectangle (gc, area);
 
-    if (!parts[part].bmap)
-	parts[part].bmap = gdk_bitmap_create_from_data (drawable,
-							parts[part].bits,
-							PART_SIZE, PART_SIZE);
+  if (!parts[part].bmap)
+    {
+      parts[part].bmap = gdk_bitmap_create_from_data (drawable,
+						      parts[part].bits,
+						      PART_SIZE, PART_SIZE);
+    }
 
-    gdk_gc_set_ts_origin (gc, x, y);
-    gdk_gc_set_stipple (gc, parts[part].bmap);
-    gdk_gc_set_fill (gc, GDK_STIPPLED);
+  gdk_gc_set_ts_origin (gc, x, y);
+  gdk_gc_set_stipple (gc, parts[part].bmap);
+  gdk_gc_set_fill (gc, GDK_STIPPLED);
 
-    gdk_draw_rectangle (drawable, gc, TRUE, x, y, PART_SIZE, PART_SIZE);
+  gdk_draw_rectangle (drawable, gc, TRUE, x, y, PART_SIZE, PART_SIZE);
 
-    gdk_gc_set_fill (gc, GDK_SOLID);
+  gdk_gc_set_fill (gc, GDK_SOLID);
 
-    if (area)
-	gdk_gc_set_clip_rectangle (gc, NULL);
+  if (area)
+    gdk_gc_set_clip_rectangle (gc, NULL);
 }
 
 static void
-draw_check (GtkStyle * style,
-	    GdkWindow * window,
+draw_check (GtkStyle *style,
+	    GdkWindow *window,
 	    GtkStateType state,
 	    GtkShadowType shadow,
-	    GdkRectangle * area,
-	    GtkWidget * widget,
-	    const gchar * detail, gint x, gint y, gint width, gint height)
+	    GdkRectangle *area,
+	    GtkWidget *widget,
+	    const gchar *detail, gint x, gint y, gint width, gint height)
 {
-    x -= (1 + PART_SIZE - width) / 2;
-    y -= (1 + PART_SIZE - height) / 2;
+  x -= (1 + PART_SIZE - width) / 2;
+  y -= (1 + PART_SIZE - height) / 2;
 
-    if (detail && strcmp (detail, "check") == 0)	/* Menu item */
+  if (detail && strcmp (detail, "check") == 0)	/* Menu item */
+    {
+      if (shadow == GTK_SHADOW_IN)
 	{
-	    if (shadow == GTK_SHADOW_IN)
-		{
-		    draw_part (window, style->black_gc, area, x, y,
-			       CHECK_TEXT);
-		    draw_part (window, style->dark_gc[state], area, x, y,
-			       CHECK_AA);
-		}
+	  draw_part (window, style->black_gc, area, x, y, CHECK_TEXT);
+	  draw_part (window, style->dark_gc[state], area, x, y, CHECK_AA);
 	}
-    else
+    }
+  else
+    {
+      XpThemeElement theme_elt = XP_THEME_ELEMENT_CHECKBOX;
+      switch (shadow)
 	{
-	  XpThemeElement theme_elt = XP_THEME_ELEMENT_CHECKBOX;
-	  switch (shadow)
-	    {
-	    case GTK_SHADOW_ETCHED_IN:
-	      theme_elt = XP_THEME_ELEMENT_INCONSISTENT_CHECKBOX;
-	      break;
+	case GTK_SHADOW_ETCHED_IN:
+	  theme_elt = XP_THEME_ELEMENT_INCONSISTENT_CHECKBOX;
+	  break;
+
+	case GTK_SHADOW_IN:
+	  theme_elt = XP_THEME_ELEMENT_PRESSED_CHECKBOX;
+	  break;
 
-	    case GTK_SHADOW_IN:
-	      theme_elt = XP_THEME_ELEMENT_PRESSED_CHECKBOX;
-	      break;
+	default:
+	  break;
+	}
 
-	    default:
-	      break;
-	    }
+      if (!xp_theme_draw (window, theme_elt,
+			  style, x, y, width, height, state, area))
+	{
+	  if (detail && !strcmp (detail, "cellcheck"))
+	    state = GTK_STATE_NORMAL;
 
-	  if (!xp_theme_draw (window, theme_elt,
-			      style, x, y, width, height, state, area))
-		{
-                    if( detail && !strcmp(detail, "cellcheck") )
-                        state = GTK_STATE_NORMAL;
+	  draw_part (window, style->black_gc, area, x, y, CHECK_BLACK);
+	  draw_part (window, style->dark_gc[state], area, x, y, CHECK_DARK);
+	  draw_part (window, style->mid_gc[state], area, x, y, CHECK_MID);
+	  draw_part (window, style->light_gc[state], area, x, y, CHECK_LIGHT);
+	  draw_part (window, style->base_gc[state], area, x, y, CHECK_BASE);
 
-		    draw_part (window, style->black_gc, area, x, y,
-			       CHECK_BLACK);
-		    draw_part (window, style->dark_gc[state], area, x, y,
-			       CHECK_DARK);
-		    draw_part (window, style->mid_gc[state], area, x, y,
-			       CHECK_MID);
-		    draw_part (window, style->light_gc[state], area, x, y,
-			       CHECK_LIGHT);
-		    draw_part (window, style->base_gc[state], area, x, y,
-			       CHECK_BASE);
-
-		    if (shadow == GTK_SHADOW_IN)
-			{
-			    draw_part (window, style->text_gc[state], area, x,
-				       y, CHECK_TEXT);
-			    draw_part (window, style->text_aa_gc[state], area,
-				       x, y, CHECK_AA);
-			}
-		    else if (shadow == GTK_SHADOW_ETCHED_IN)
-		      {
-			draw_part (window, style->text_gc[state], area, x, y, CHECK_INCONSISTENT);
-			draw_part (window, style->text_aa_gc[state], area, x, y, CHECK_AA);
-		      }
-		}
+	  if (shadow == GTK_SHADOW_IN)
+	    {
+	      draw_part (window, style->text_gc[state], area, x,
+			 y, CHECK_TEXT);
+	      draw_part (window, style->text_aa_gc[state], area,
+			 x, y, CHECK_AA);
+	    }
+	  else if (shadow == GTK_SHADOW_ETCHED_IN)
+	    {
+	      draw_part (window, style->text_gc[state], area, x, y,
+			 CHECK_INCONSISTENT);
+	      draw_part (window, style->text_aa_gc[state], area, x, y,
+			 CHECK_AA);
+	    }
 	}
+    }
 }
 
 static void
-draw_expander (GtkStyle * style,
-	       GdkWindow * window,
+draw_expander (GtkStyle *style,
+	       GdkWindow *window,
 	       GtkStateType state,
-	       GdkRectangle * area,
-	       GtkWidget * widget,
-	       const gchar * detail,
+	       GdkRectangle *area,
+	       GtkWidget *widget,
+	       const gchar *detail,
 	       gint x, gint y, GtkExpanderStyle expander_style)
 {
-    gint expander_size;
-    gint expander_semi_size;
-    XpThemeElement xp_expander;
-
-    gtk_widget_style_get (widget, "expander_size", &expander_size, NULL);
-
-    switch (expander_style)
-	{
-	case GTK_EXPANDER_COLLAPSED:
-	case GTK_EXPANDER_SEMI_COLLAPSED:
-	    xp_expander = XP_THEME_ELEMENT_TREEVIEW_EXPANDER_CLOSED;
-	    break;
-	default:
-	    xp_expander = XP_THEME_ELEMENT_TREEVIEW_EXPANDER_OPENED;
-	    break;
-	}
+  gint expander_size;
+  gint expander_semi_size;
+  XpThemeElement xp_expander;
+
+  gtk_widget_style_get (widget, "expander_size", &expander_size, NULL);
+
+  switch (expander_style)
+    {
+    case GTK_EXPANDER_COLLAPSED:
+    case GTK_EXPANDER_SEMI_COLLAPSED:
+      xp_expander = XP_THEME_ELEMENT_TREEVIEW_EXPANDER_CLOSED;
+      break;
 
-    if ((expander_size % 2) == 0)
-	expander_size--;
+    default:
+      xp_expander = XP_THEME_ELEMENT_TREEVIEW_EXPANDER_OPENED;
+      break;
+    }
 
-    if (expander_size > 2)
-	expander_size -= 2;
+  if ((expander_size % 2) == 0)
+    expander_size--;
 
-    if (area)
-	gdk_gc_set_clip_rectangle (style->fg_gc[state], area);
+  if (expander_size > 2)
+    expander_size -= 2;
 
-    expander_semi_size = expander_size / 2;
-    x -= expander_semi_size;
-    y -= expander_semi_size;
+  if (area)
+    gdk_gc_set_clip_rectangle (style->fg_gc[state], area);
 
-    if (!xp_theme_draw (window, xp_expander, style,
-			x, y, expander_size, expander_size, state, area))
-	{
-        HDC dc;
-        RECT rect;
-        HPEN pen;
-        HGDIOBJ old_pen;
+  expander_semi_size = expander_size / 2;
+  x -= expander_semi_size;
+  y -= expander_semi_size;
 
-        dc = get_window_dc( style, window, state, x, y, expander_size, expander_size, &rect );
-        FrameRect( dc, &rect, GetSysColorBrush(COLOR_GRAYTEXT) );
-        InflateRect( &rect, -1, -1 );
-        FillRect( dc, &rect, GetSysColorBrush(state == GTK_STATE_INSENSITIVE ? COLOR_BTNFACE : COLOR_WINDOW) );
+  if (!xp_theme_draw (window, xp_expander, style,
+		      x, y, expander_size, expander_size, state, area))
+    {
+      HDC dc;
+      RECT rect;
+      HPEN pen;
+      HGDIOBJ old_pen;
 
-        InflateRect( &rect, -1, -1 );
+      dc = get_window_dc (style, window, state, x, y, expander_size,
+			  expander_size, &rect);
+      FrameRect (dc, &rect, GetSysColorBrush (COLOR_GRAYTEXT));
+      InflateRect (&rect, -1, -1);
+      FillRect (dc, &rect,
+		GetSysColorBrush (state ==
+				  GTK_STATE_INSENSITIVE ? COLOR_BTNFACE :
+				  COLOR_WINDOW));
 
-        pen = CreatePen( PS_SOLID, 1, GetSysColor(COLOR_WINDOWTEXT) );
-        old_pen = SelectObject( dc, pen );
+      InflateRect (&rect, -1, -1);
 
-        MoveToEx( dc, rect.left, rect.top - 2 + expander_semi_size, NULL );
-        LineTo( dc, rect.right, rect.top - 2 + expander_semi_size );
+      pen = CreatePen (PS_SOLID, 1, GetSysColor (COLOR_WINDOWTEXT));
+      old_pen = SelectObject (dc, pen);
 
-        if( expander_style == GTK_EXPANDER_COLLAPSED ||
-            expander_style == GTK_EXPANDER_SEMI_COLLAPSED )
-        {
-            MoveToEx( dc, rect.left - 2 + expander_semi_size, rect.top, NULL );
-            LineTo( dc, rect.left - 2 + expander_semi_size, rect.bottom );
-		}
+      MoveToEx (dc, rect.left, rect.top - 2 + expander_semi_size, NULL);
+      LineTo (dc, rect.right, rect.top - 2 + expander_semi_size);
 
-        SelectObject( dc, old_pen );
-	DeleteObject( pen );
-        release_window_dc( style, window, state );
+      if (expander_style == GTK_EXPANDER_COLLAPSED ||
+	  expander_style == GTK_EXPANDER_SEMI_COLLAPSED)
+	{
+	  MoveToEx (dc, rect.left - 2 + expander_semi_size, rect.top, NULL);
+	  LineTo (dc, rect.left - 2 + expander_semi_size, rect.bottom);
 	}
 
-    if (area)
-	gdk_gc_set_clip_rectangle (style->fg_gc[state], NULL);
+      SelectObject (dc, old_pen);
+      DeleteObject (pen);
+      release_window_dc (style, window, state);
+    }
+
+  if (area)
+    gdk_gc_set_clip_rectangle (style->fg_gc[state], NULL);
 }
 
 static void
-draw_option (GtkStyle * style,
-	     GdkWindow * window,
+draw_option (GtkStyle *style,
+	     GdkWindow *window,
 	     GtkStateType state,
 	     GtkShadowType shadow,
-	     GdkRectangle * area,
-	     GtkWidget * widget,
-	     const gchar * detail, gint x, gint y, gint width, gint height)
+	     GdkRectangle *area,
+	     GtkWidget *widget,
+	     const gchar *detail, gint x, gint y, gint width, gint height)
 {
-    x -= (1 + PART_SIZE - width) / 2;
-    y -= (1 + PART_SIZE - height) / 2;
+  x -= (1 + PART_SIZE - width) / 2;
+  y -= (1 + PART_SIZE - height) / 2;
 
-    if (detail && strcmp (detail, "option") == 0)	/* Menu item */
+  if (detail && strcmp (detail, "option") == 0)	/* Menu item */
+    {
+      if (shadow == GTK_SHADOW_IN)
 	{
-	    if (shadow == GTK_SHADOW_IN)
-		draw_part (window, style->fg_gc[state], area, x, y,
-			   RADIO_TEXT);
+	  draw_part (window, style->fg_gc[state], area, x, y, RADIO_TEXT);
 	}
-    else
+    }
+  else
+    {
+      if (xp_theme_draw (window, shadow == GTK_SHADOW_IN
+			 ? XP_THEME_ELEMENT_PRESSED_RADIO_BUTTON
+			 : XP_THEME_ELEMENT_RADIO_BUTTON,
+			 style, x, y, width, height, state, area))
 	{
-	    if (xp_theme_draw (window, shadow == GTK_SHADOW_IN
-			       ? XP_THEME_ELEMENT_PRESSED_RADIO_BUTTON
-			       : XP_THEME_ELEMENT_RADIO_BUTTON,
-			       style, x, y, width, height, state, area))
-		{
-		}
-	    else
-		{
-                    if( detail && !strcmp(detail, "cellradio") )
-                        state = GTK_STATE_NORMAL;
+	}
+      else
+	{
+	  if (detail && !strcmp (detail, "cellradio"))
+	    state = GTK_STATE_NORMAL;
 
-		    draw_part (window, style->black_gc, area, x, y,
-			       RADIO_BLACK);
-		    draw_part (window, style->dark_gc[state], area, x, y,
-			       RADIO_DARK);
-		    draw_part (window, style->mid_gc[state], area, x, y,
-			       RADIO_MID);
-		    draw_part (window, style->light_gc[state], area, x, y,
-			       RADIO_LIGHT);
-		    draw_part (window, style->base_gc[state], area, x, y,
-			       RADIO_BASE);
-
-		    if (shadow == GTK_SHADOW_IN)
-			draw_part (window, style->text_gc[state], area, x, y,
-				   RADIO_TEXT);
-		}
+	  draw_part (window, style->black_gc, area, x, y, RADIO_BLACK);
+	  draw_part (window, style->dark_gc[state], area, x, y, RADIO_DARK);
+	  draw_part (window, style->mid_gc[state], area, x, y, RADIO_MID);
+	  draw_part (window, style->light_gc[state], area, x, y, RADIO_LIGHT);
+	  draw_part (window, style->base_gc[state], area, x, y, RADIO_BASE);
+
+	  if (shadow == GTK_SHADOW_IN)
+	    draw_part (window, style->text_gc[state], area, x, y, RADIO_TEXT);
 	}
+    }
 }
 
 static void
-draw_varrow (GdkWindow * window,
-	     GdkGC * gc,
+draw_varrow (GdkWindow *window,
+	     GdkGC *gc,
 	     GtkShadowType shadow_type,
-	     GdkRectangle * area,
+	     GdkRectangle *area,
 	     GtkArrowType arrow_type, gint x, gint y, gint width, gint height)
 {
-    gint steps, extra;
-    gint y_start, y_increment;
-    gint i;
+  gint steps, extra;
+  gint y_start, y_increment;
+  gint i;
 
-    if (area)
-	gdk_gc_set_clip_rectangle (gc, area);
+  if (area)
+    gdk_gc_set_clip_rectangle (gc, area);
 
-    width = width + width % 2 - 1;	/* Force odd */
-    steps = 1 + width / 2;
-    extra = height - steps;
+  width = width + width % 2 - 1;	/* Force odd */
+  steps = 1 + width / 2;
+  extra = height - steps;
 
-    if (arrow_type == GTK_ARROW_DOWN)
-	{
-	    y_start = y;
-	    y_increment = 1;
-	}
-    else
-	{
-	    y_start = y + height - 1;
-	    y_increment = -1;
-	}
+  if (arrow_type == GTK_ARROW_DOWN)
+    {
+      y_start = y;
+      y_increment = 1;
+    }
+  else
+    {
+      y_start = y + height - 1;
+      y_increment = -1;
+    }
 
-    for (i = extra; i < height; i++)
-	{
-	    gdk_draw_line (window, gc,
-			   x + (i - extra), y_start + i * y_increment,
-			   x + width - (i - extra) - 1,
-			   y_start + i * y_increment);
-	}
+  for (i = extra; i < height; i++)
+    {
+      gdk_draw_line (window, gc,
+		     x + (i - extra), y_start + i * y_increment,
+		     x + width - (i - extra) - 1, y_start + i * y_increment);
+    }
 
-    if (area)
-	gdk_gc_set_clip_rectangle (gc, NULL);
+  if (area)
+    gdk_gc_set_clip_rectangle (gc, NULL);
 }
 
 static void
-draw_harrow (GdkWindow * window,
-	     GdkGC * gc,
+draw_harrow (GdkWindow *window,
+	     GdkGC *gc,
 	     GtkShadowType shadow_type,
-	     GdkRectangle * area,
+	     GdkRectangle *area,
 	     GtkArrowType arrow_type, gint x, gint y, gint width, gint height)
 {
-    gint steps, extra;
-    gint x_start, x_increment;
-    gint i;
+  gint steps, extra;
+  gint x_start, x_increment;
+  gint i;
 
-    if (area)
-	gdk_gc_set_clip_rectangle (gc, area);
+  if (area)
+    gdk_gc_set_clip_rectangle (gc, area);
 
-    height = height + height % 2 - 1;	/* Force odd */
-    steps = 1 + height / 2;
-    extra = width - steps;
+  height = height + height % 2 - 1;	/* Force odd */
+  steps = 1 + height / 2;
+  extra = width - steps;
 
-    if (arrow_type == GTK_ARROW_RIGHT)
-	{
-	    x_start = x;
-	    x_increment = 1;
-	}
-    else
-	{
-	    x_start = x + width - 1;
-	    x_increment = -1;
-	}
+  if (arrow_type == GTK_ARROW_RIGHT)
+    {
+      x_start = x;
+      x_increment = 1;
+    }
+  else
+    {
+      x_start = x + width - 1;
+      x_increment = -1;
+    }
 
-    for (i = extra; i < width; i++)
-	{
-	    gdk_draw_line (window, gc,
-			   x_start + i * x_increment, y + (i - extra),
-			   x_start + i * x_increment,
-			   y + height - (i - extra) - 1);
-	}
+  for (i = extra; i < width; i++)
+    {
+      gdk_draw_line (window, gc,
+		     x_start + i * x_increment, y + (i - extra),
+		     x_start + i * x_increment, y + height - (i - extra) - 1);
+    }
 
 
-    if (area)
-	gdk_gc_set_clip_rectangle (gc, NULL);
+  if (area)
+    gdk_gc_set_clip_rectangle (gc, NULL);
 }
 
 /* This function makes up for some brokeness in gtkrange.c
@@ -1388,894 +1416,985 @@
  * to the point we don't have room for full-sized steppers.
  */
 static void
-reverse_engineer_stepper_box (GtkWidget * range,
+reverse_engineer_stepper_box (GtkWidget *range,
 			      GtkArrowType arrow_type,
-			      gint * x, gint * y, gint * width, gint * height)
+			      gint *x, gint *y, gint *width, gint *height)
 {
-    gint slider_width = 14, stepper_size = 14;
-    gint box_width;
-    gint box_height;
+  gint slider_width = 14, stepper_size = 14;
+  gint box_width;
+  gint box_height;
 
-    if (range)
-	{
-	    gtk_widget_style_get (range,
-				  "slider_width", &slider_width,
-				  "stepper_size", &stepper_size, NULL);
-	}
+  if (range)
+    {
+      gtk_widget_style_get (range,
+			    "slider_width", &slider_width,
+			    "stepper_size", &stepper_size, NULL);
+    }
 
-    if (arrow_type == GTK_ARROW_UP || arrow_type == GTK_ARROW_DOWN)
-	{
-	    box_width = slider_width;
-	    box_height = stepper_size;
-	}
-    else
-	{
-	    box_width = stepper_size;
-	    box_height = slider_width;
-	}
+  if (arrow_type == GTK_ARROW_UP || arrow_type == GTK_ARROW_DOWN)
+    {
+      box_width = slider_width;
+      box_height = stepper_size;
+    }
+  else
+    {
+      box_width = stepper_size;
+      box_height = slider_width;
+    }
 
-    *x = *x - (box_width - *width) / 2;
-    *y = *y - (box_height - *height) / 2;
-    *width = box_width;
-    *height = box_height;
+  *x = *x - (box_width - *width) / 2;
+  *y = *y - (box_height - *height) / 2;
+  *width = box_width;
+  *height = box_height;
 }
 
 static XpThemeElement
 to_xp_arrow (GtkArrowType arrow_type)
 {
-    XpThemeElement xp_arrow;
+  XpThemeElement xp_arrow;
 
-    switch (arrow_type)
-	{
-	case GTK_ARROW_UP:
-	    xp_arrow = XP_THEME_ELEMENT_ARROW_UP;
-	    break;
-	case GTK_ARROW_DOWN:
-	    xp_arrow = XP_THEME_ELEMENT_ARROW_DOWN;
-	    break;
-	case GTK_ARROW_LEFT:
-	    xp_arrow = XP_THEME_ELEMENT_ARROW_LEFT;
-	    break;
-	default:
-	    xp_arrow = XP_THEME_ELEMENT_ARROW_RIGHT;
-	    break;
-	}
+  switch (arrow_type)
+    {
+    case GTK_ARROW_UP:
+      xp_arrow = XP_THEME_ELEMENT_ARROW_UP;
+      break;
+
+    case GTK_ARROW_DOWN:
+      xp_arrow = XP_THEME_ELEMENT_ARROW_DOWN;
+      break;
 
-    return xp_arrow;
+    case GTK_ARROW_LEFT:
+      xp_arrow = XP_THEME_ELEMENT_ARROW_LEFT;
+      break;
+
+    default:
+      xp_arrow = XP_THEME_ELEMENT_ARROW_RIGHT;
+      break;
+    }
+
+  return xp_arrow;
 }
 
 static void
-draw_arrow (GtkStyle * style,
-	    GdkWindow * window,
+draw_arrow (GtkStyle *style,
+	    GdkWindow *window,
 	    GtkStateType state,
 	    GtkShadowType shadow,
-	    GdkRectangle * area,
-	    GtkWidget * widget,
-	    const gchar * detail,
+	    GdkRectangle *area,
+	    GtkWidget *widget,
+	    const gchar *detail,
 	    GtkArrowType arrow_type,
 	    gboolean fill, gint x, gint y, gint width, gint height)
 {
-    const gchar *name;
-    HDC dc;
-    RECT rect;
+  const gchar *name;
+  HDC dc;
+  RECT rect;
 
-    name = gtk_widget_get_name (widget);
+  name = gtk_widget_get_name (widget);
 
-    sanitize_size (window, &width, &height);
+  sanitize_size (window, &width, &height);
 
-    if (GTK_IS_ARROW(widget) && is_combo_box_child(widget))
-        {
-	    if (combo_box_draw_arrow (style, window, state, area, widget))
-		{
-		    return;
-		}
-        }
+  if (GTK_IS_ARROW (widget) && is_combo_box_child (widget))
+    {
+      if (combo_box_draw_arrow (style, window, state, area, widget))
+	{
+	  return;
+	}
+    }
 
-    if (detail && strcmp (detail, "spinbutton") == 0)
+  if (detail && strcmp (detail, "spinbutton") == 0)
+    {
+      if (xp_theme_is_drawable (XP_THEME_ELEMENT_SPIN_BUTTON_UP))
 	{
-	    if (xp_theme_is_drawable (XP_THEME_ELEMENT_SPIN_BUTTON_UP))
-		{
-		    return;
-		}
+	  return;
+	}
 
-            width -= 2;
-            --height;
-            if( arrow_type == GTK_ARROW_DOWN )
-                ++y;
-	    ++x;
-
-            if( state == GTK_STATE_ACTIVE ) {
-                ++x;
-                ++y;
-		}
-	    draw_varrow (window, style->fg_gc[state], shadow, area,
-			 arrow_type, x, y, width, height);
-            return;
-	}
-    else if (detail && (!strcmp (detail, "vscrollbar")
-			|| !strcmp (detail, "hscrollbar")))
-	{
-	    gboolean is_disabled = FALSE;
-            UINT btn_type = 0;
-	    GtkScrollbar *scrollbar = GTK_SCROLLBAR (widget);
-
-	    gint box_x = x;
-	    gint box_y = y;
-	    gint box_width = width;
-	    gint box_height = height;
-
-	    reverse_engineer_stepper_box (widget, arrow_type,
-					  &box_x, &box_y, &box_width,
-					  &box_height);
-
-	    if (scrollbar->range.adjustment->page_size >=
-		(scrollbar->range.adjustment->upper -
-		 scrollbar->range.adjustment->lower))
-		is_disabled = TRUE;
-
-	    if (xp_theme_draw
-		(window, to_xp_arrow (arrow_type), style, box_x, box_y,
-		 box_width, box_height, state, area))
-		{
-		}
-	    else
-		{
-                switch (arrow_type)
-                {
-                case GTK_ARROW_UP:
-                    btn_type = DFCS_SCROLLUP;
-                    break;
-                case GTK_ARROW_DOWN:
-                    btn_type = DFCS_SCROLLDOWN;
-                    break;
-                case GTK_ARROW_LEFT:
-                    btn_type = DFCS_SCROLLLEFT;
-                    break;
-                case GTK_ARROW_RIGHT:
-                    btn_type = DFCS_SCROLLRIGHT;
-                    break;
-                case GTK_ARROW_NONE:
-					break;
-                }
-                if( state == GTK_STATE_INSENSITIVE )
-                    btn_type |= DFCS_INACTIVE;
-                if( widget ) {
-                    sanitize_size (window, &width, &height);
-
-                    dc = get_window_dc( style, window, state, 
-                                        box_x, box_y, box_width, box_height, &rect );
-                    DrawFrameControl( dc, &rect, DFC_SCROLL, 
-                        btn_type|(shadow == GTK_SHADOW_IN ? (DFCS_PUSHED|DFCS_FLAT) : 0) );
-                    release_window_dc( style, window, state );
-                }
-		}
+      width -= 2;
+      --height;
+      if (arrow_type == GTK_ARROW_DOWN)
+	++y;
+      ++x;
+
+      if (state == GTK_STATE_ACTIVE)
+	{
+	  ++x;
+	  ++y;
 	}
-    else
+
+      draw_varrow (window, style->fg_gc[state], shadow, area,
+		   arrow_type, x, y, width, height);
+
+      return;
+    }
+  else if (detail && (!strcmp (detail, "vscrollbar")
+		      || !strcmp (detail, "hscrollbar")))
+    {
+      gboolean is_disabled = FALSE;
+      UINT btn_type = 0;
+      GtkScrollbar *scrollbar = GTK_SCROLLBAR (widget);
+
+      gint box_x = x;
+      gint box_y = y;
+      gint box_width = width;
+      gint box_height = height;
+
+      reverse_engineer_stepper_box (widget, arrow_type,
+				    &box_x, &box_y, &box_width, &box_height);
+
+      if (scrollbar->range.adjustment->page_size >=
+	  (scrollbar->range.adjustment->upper -
+	   scrollbar->range.adjustment->lower))
 	{
-	    /* draw the toolbar chevrons - waiting for GTK 2.4 */
-	    if (name && !strcmp (name, "gtk-toolbar-arrow"))
-		{
-		    if (xp_theme_draw
-			(window, XP_THEME_ELEMENT_REBAR_CHEVRON, style, x, y,
-			 width, height, state, area))
-			return;
-		}
-	    /* probably a gtk combo box on a toolbar */
-	    else if (0		/* widget->parent && GTK_IS_BUTTON
+	  is_disabled = TRUE;
+	}
+
+      if (xp_theme_draw (window, to_xp_arrow (arrow_type), style, box_x, box_y,
+			 box_width, box_height, state, area))
+	{
+	}
+      else
+	{
+	  switch (arrow_type)
+	    {
+	    case GTK_ARROW_UP:
+	      btn_type = DFCS_SCROLLUP;
+	      break;
+
+	    case GTK_ARROW_DOWN:
+	      btn_type = DFCS_SCROLLDOWN;
+	      break;
+
+	    case GTK_ARROW_LEFT:
+	      btn_type = DFCS_SCROLLLEFT;
+	      break;
+
+	    case GTK_ARROW_RIGHT:
+	      btn_type = DFCS_SCROLLRIGHT;
+	      break;
+
+	    case GTK_ARROW_NONE:
+	      break;
+	    }
+
+	  if (state == GTK_STATE_INSENSITIVE)
+	    {
+	      btn_type |= DFCS_INACTIVE;
+	    }
+
+	  if (widget)
+	    {
+	      sanitize_size (window, &width, &height);
+
+	      dc = get_window_dc (style, window, state,
+				  box_x, box_y, box_width, box_height, &rect);
+	      DrawFrameControl (dc, &rect, DFC_SCROLL,
+				btn_type | (shadow ==
+					    GTK_SHADOW_IN ? (DFCS_PUSHED |
+							     DFCS_FLAT) : 0));
+	      release_window_dc (style, window, state);
+	    }
+	}
+    }
+  else
+    {
+      /* draw the toolbar chevrons - waiting for GTK 2.4 */
+      if (name && !strcmp (name, "gtk-toolbar-arrow"))
+	{
+	  if (xp_theme_draw
+	      (window, XP_THEME_ELEMENT_REBAR_CHEVRON, style, x, y,
+	       width, height, state, area))
+	    {
+	      return;
+	    }
+	}
+      /* probably a gtk combo box on a toolbar */
+      else if (0		/* widget->parent && GTK_IS_BUTTON
 				   (widget->parent) */ )
-		{
-		    if (xp_theme_draw
-			(window, XP_THEME_ELEMENT_COMBOBUTTON, style, x - 3,
-			 widget->allocation.y + 1, width + 5,
-			 widget->allocation.height - 4, state, area))
-			return;
-		}
+	{
+	  if (xp_theme_draw
+	      (window, XP_THEME_ELEMENT_COMBOBUTTON, style, x - 3,
+	       widget->allocation.y + 1, width + 5,
+	       widget->allocation.height - 4, state, area))
+	    {
+	      return;
+	    }
+	}
 
-	    if (arrow_type == GTK_ARROW_UP || arrow_type == GTK_ARROW_DOWN)
-		{
-		    x += (width - 7) / 2;
-		    y += (height - 5) / 2;
+      if (arrow_type == GTK_ARROW_UP || arrow_type == GTK_ARROW_DOWN)
+	{
+	  x += (width - 7) / 2;
+	  y += (height - 5) / 2;
 
-		    draw_varrow (window, style->fg_gc[state], shadow, area,
-				 arrow_type, x, y, 7, 5);
-		}
-	    else
-		{
-		    x += (width - 5) / 2;
-		    y += (height - 7) / 2;
+	  draw_varrow (window, style->fg_gc[state], shadow, area,
+		       arrow_type, x, y, 7, 5);
+	}
+      else
+	{
+	  x += (width - 5) / 2;
+	  y += (height - 7) / 2;
 
-		    draw_harrow (window, style->fg_gc[state], shadow, area,
-				 arrow_type, x, y, 5, 7);
-		}
+	  draw_harrow (window, style->fg_gc[state], shadow, area,
+		       arrow_type, x, y, 5, 7);
 	}
+    }
 }
 
 static void
-option_menu_get_props (GtkWidget * widget,
-		       GtkRequisition * indicator_size,
-		       GtkBorder * indicator_spacing)
+option_menu_get_props (GtkWidget *widget,
+		       GtkRequisition *indicator_size,
+		       GtkBorder *indicator_spacing)
 {
-    GtkRequisition *tmp_size = NULL;
-    GtkBorder *tmp_spacing = NULL;
+  GtkRequisition *tmp_size = NULL;
+  GtkBorder *tmp_spacing = NULL;
 
-    if (widget)
-	gtk_widget_style_get (widget,
-			      "indicator_size", &tmp_size,
-			      "indicator_spacing", &tmp_spacing, NULL);
+  if (widget)
+    gtk_widget_style_get (widget,
+			  "indicator_size", &tmp_size,
+			  "indicator_spacing", &tmp_spacing, NULL);
 
-    if (tmp_size)
-	{
-	    *indicator_size = *tmp_size;
-	    gtk_requisition_free (tmp_size);
-	}
-    else
-	*indicator_size = default_option_indicator_size;
+  if (tmp_size)
+    {
+      *indicator_size = *tmp_size;
+      gtk_requisition_free (tmp_size);
+    }
+  else
+    {
+      *indicator_size = default_option_indicator_size;
+    }
 
-    if (tmp_spacing)
-	{
-	    *indicator_spacing = *tmp_spacing;
-	    gtk_border_free (tmp_spacing);
-	}
-    else
-	*indicator_spacing = default_option_indicator_spacing;
+  if (tmp_spacing)
+    {
+      *indicator_spacing = *tmp_spacing;
+      gtk_border_free (tmp_spacing);
+    }
+  else
+    {
+      *indicator_spacing = default_option_indicator_spacing;
+    }
 }
 
 static gboolean
-is_toolbar_child (GtkWidget * wid)
+is_toolbar_child (GtkWidget *wid)
 {
-    while (wid)
-	{
-	    if (GTK_IS_TOOLBAR (wid) || GTK_IS_HANDLE_BOX (wid))
-		return TRUE;
-	    else
-		wid = wid->parent;
-	}
+  while (wid)
+    {
+      if (GTK_IS_TOOLBAR (wid) || GTK_IS_HANDLE_BOX (wid))
+	return TRUE;
+      else
+	wid = wid->parent;
+    }
 
-    return FALSE;
+  return FALSE;
 }
 
 static gboolean
-is_menu_tool_button_child (GtkWidget * wid)
+is_menu_tool_button_child (GtkWidget *wid)
 {
-    while (wid)
-	{
-	    if (GTK_IS_MENU_TOOL_BUTTON (wid) )
-		return TRUE;
-	    else
-		wid = wid->parent;
-	}
-    return FALSE;
+  while (wid)
+    {
+      if (GTK_IS_MENU_TOOL_BUTTON (wid))
+	return TRUE;
+      else
+	wid = wid->parent;
+    }
+  return FALSE;
 }
 
-HDC get_window_dc(GtkStyle * style, GdkWindow * window, GtkStateType state_type, gint x, gint y, gint width, gint height, RECT *rect)
+HDC
+get_window_dc (GtkStyle *style, GdkWindow *window, GtkStateType state_type,
+	       gint x, gint y, gint width, gint height, RECT *rect)
 {
-	int xoff, yoff;
-	GdkDrawable *drawable;
+  int xoff, yoff;
+  GdkDrawable *drawable;
 
-	if (!GDK_IS_WINDOW (window))
-		{
-		    xoff = 0;
-		    yoff = 0;
-		    drawable = window;
-		}
-	else
-		{
-		    gdk_window_get_internal_paint_info (window, &drawable, &xoff, &yoff);
-		}
+  if (!GDK_IS_WINDOW (window))
+    {
+      xoff = 0;
+      yoff = 0;
+      drawable = window;
+    }
+  else
+    {
+      gdk_window_get_internal_paint_info (window, &drawable, &xoff, &yoff);
+    }
 
-	rect->left = x - xoff;
-	rect->top = y - yoff;
-	rect->right = rect->left + width;
-    rect->bottom = rect->top + height;
+  rect->left = x - xoff;
+  rect->top = y - yoff;
+  rect->right = rect->left + width;
+  rect->bottom = rect->top + height;
 
-	return gdk_win32_hdc_get (drawable, style->dark_gc[state_type], 0);
+  return gdk_win32_hdc_get (drawable, style->dark_gc[state_type], 0);
 }
 
-void release_window_dc(GtkStyle * style, GdkWindow * window, GtkStateType state_type)
+void
+release_window_dc (GtkStyle *style, GdkWindow *window,
+		   GtkStateType state_type)
 {
-	GdkDrawable *drawable;
+  GdkDrawable *drawable;
 
-	if (!GDK_IS_WINDOW (window))
-		{
-		    drawable = window;
-		}
-	else
-		{
-		    gdk_window_get_internal_paint_info (window, &drawable, NULL, NULL);
-		}
+  if (!GDK_IS_WINDOW (window))
+    {
+      drawable = window;
+    }
+  else
+    {
+      gdk_window_get_internal_paint_info (window, &drawable, NULL, NULL);
+    }
 
-	gdk_win32_hdc_release (drawable, style->dark_gc[state_type], 0);
+  gdk_win32_hdc_release (drawable, style->dark_gc[state_type], 0);
 }
 
-static HPEN get_light_pen()
+static HPEN
+get_light_pen ()
 {
-    if( ! g_light_pen ) {
-    	g_light_pen = CreatePen( PS_SOLID|PS_INSIDEFRAME, 1, GetSysColor(COLOR_BTNHIGHLIGHT) );
+  if (!g_light_pen)
+    {
+      g_light_pen = CreatePen (PS_SOLID | PS_INSIDEFRAME, 1,
+			       GetSysColor (COLOR_BTNHIGHLIGHT));
     }
-    return g_light_pen;
+
+  return g_light_pen;
 }
 
-static HPEN get_dark_pen()
+static HPEN
+get_dark_pen ()
 {
-    if( ! g_dark_pen ) {
-    	g_dark_pen = CreatePen( PS_SOLID|PS_INSIDEFRAME, 1, GetSysColor(COLOR_BTNSHADOW) );
+  if (!g_dark_pen)
+    {
+      g_dark_pen = CreatePen (PS_SOLID | PS_INSIDEFRAME, 1,
+			      GetSysColor (COLOR_BTNSHADOW));
     }
-    return g_dark_pen;
+
+  return g_dark_pen;
 }
 
 static void
-draw_3d_border( HDC hdc, RECT* rc, gboolean sunken )
+draw_3d_border (HDC hdc, RECT *rc, gboolean sunken)
 {
-    HPEN pen1, pen2;
-    HGDIOBJ old_pen;
+  HPEN pen1, pen2;
+  HGDIOBJ old_pen;
 
-    if( sunken ){
-        pen1 = get_dark_pen();
-        pen2 = get_light_pen();
+  if (sunken)
+    {
+      pen1 = get_dark_pen ();
+      pen2 = get_light_pen ();
     }
-    else{
-        pen1 = get_light_pen();
-        pen2 = get_dark_pen();
+  else
+    {
+      pen1 = get_light_pen ();
+      pen2 = get_dark_pen ();
     }
 
-    MoveToEx( hdc, rc->left, rc->bottom - 1, NULL);
+  MoveToEx (hdc, rc->left, rc->bottom - 1, NULL);
 
-    old_pen = SelectObject( hdc, pen1 );
-    LineTo( hdc, rc->left, rc->top );
-    LineTo( hdc, rc->right-1, rc->top );
-    SelectObject( hdc, old_pen );
+  old_pen = SelectObject (hdc, pen1);
+  LineTo (hdc, rc->left, rc->top);
+  LineTo (hdc, rc->right - 1, rc->top);
+  SelectObject (hdc, old_pen);
 
-    old_pen = SelectObject( hdc, pen2 );
-    LineTo( hdc, rc->right-1, rc->bottom-1 );
-    LineTo( hdc, rc->left, rc->bottom-1 );
-    SelectObject( hdc, old_pen );
+  old_pen = SelectObject (hdc, pen2);
+  LineTo (hdc, rc->right - 1, rc->bottom - 1);
+  LineTo (hdc, rc->left, rc->bottom - 1);
+  SelectObject (hdc, old_pen);
 }
 
-static gboolean 
-draw_menu_item(GdkWindow* window, GtkWidget* widget, GtkStyle* style, 
-               gint x, gint y, gint width, gint height, 
-               GtkStateType state_type, GdkRectangle* area )
-{
-    GtkWidget* parent;
-    GtkMenuShell* bar;
-    HDC dc;
-    RECT rect;
+static gboolean
+draw_menu_item (GdkWindow *window, GtkWidget *widget, GtkStyle *style,
+		gint x, gint y, gint width, gint height,
+		GtkStateType state_type, GdkRectangle *area)
+{
+  GtkWidget *parent;
+  GtkMenuShell *bar;
+  HDC dc;
+  RECT rect;
 
-    if( (parent = gtk_widget_get_parent(widget))
-        && GTK_IS_MENU_BAR(parent)
-        && !xp_theme_is_active() )
+  if ((parent = gtk_widget_get_parent (widget))
+      && GTK_IS_MENU_BAR (parent) && !xp_theme_is_active ())
     {
-        bar = GTK_MENU_SHELL(parent);
+      bar = GTK_MENU_SHELL (parent);
+
+      dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
 
-        dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-        if( state_type == GTK_STATE_PRELIGHT ){
-            draw_3d_border( dc, &rect, bar->active );
-        }
-        release_window_dc( style, window, state_type );
-        return TRUE;
+      if (state_type == GTK_STATE_PRELIGHT)
+	{
+	  draw_3d_border (dc, &rect, bar->active);
+	}
+
+      release_window_dc (style, window, state_type);
+
+      return TRUE;
     }
-    return FALSE;
+
+  return FALSE;
 }
 
 static HBRUSH
-get_dither_brush( void )
+get_dither_brush (void)
 {
-    WORD pattern[8];
-    HBITMAP pattern_bmp;
-    int i;
-
-    if( g_dither_brush )
-        return g_dither_brush;
-    for ( i = 0; i < 8; i++ )
-        pattern[i] = (WORD)(0x5555 << (i & 1));
-    pattern_bmp = CreateBitmap(8, 8, 1, 1, &pattern);
-    if (pattern_bmp) {
-        g_dither_brush = CreatePatternBrush(pattern_bmp);
-        DeleteObject(pattern_bmp);
-    }
+  WORD pattern[8];
+  HBITMAP pattern_bmp;
+  int i;
+
+  if (g_dither_brush)
     return g_dither_brush;
+
+  for (i = 0; i < 8; i++)
+    {
+      pattern[i] = (WORD) (0x5555 << (i & 1));
+    }
+
+  pattern_bmp = CreateBitmap (8, 8, 1, 1, &pattern);
+
+  if (pattern_bmp)
+    {
+      g_dither_brush = CreatePatternBrush (pattern_bmp);
+      DeleteObject (pattern_bmp);
+    }
+
+  return g_dither_brush;
 }
 
-static gboolean 
-draw_tool_button(GdkWindow* window, GtkWidget* widget, GtkStyle* style, 
-                 gint x, gint y, gint width, gint height, 
-                 GtkStateType state_type, GdkRectangle* area )
-{
-    HDC dc;
-    RECT rect;
-    gboolean is_toggled = FALSE;
-
-    if ( xp_theme_is_active() ) {
-		return (xp_theme_draw (window, XP_THEME_ELEMENT_TOOLBAR_BUTTON, style,
-                               x, y, width, height, state_type, area) );
-    }
-
-    if( GTK_IS_TOGGLE_BUTTON(widget) ){
-        if( gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widget)) ) {
-            is_toggled = TRUE;
-        }
-    }
-
-    if( state_type != GTK_STATE_PRELIGHT
-        && state_type != GTK_STATE_ACTIVE && !is_toggled )
-        return FALSE;
-
-    dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-    if( state_type == GTK_STATE_PRELIGHT ){
-        if( is_toggled ) {
-            FillRect( dc, &rect, GetSysColorBrush(COLOR_BTNFACE));
-        }
-        draw_3d_border( dc, &rect, is_toggled);
-    }
-    else if ( state_type == GTK_STATE_ACTIVE ){
-        if( is_toggled && ! is_menu_tool_button_child(widget->parent) ){
-	    SetTextColor( dc, GetSysColor(COLOR_3DHILIGHT) );
-	    SetBkColor( dc, GetSysColor(COLOR_BTNFACE) );
-            FillRect( dc, &rect, get_dither_brush() );
-        }
-        draw_3d_border( dc, &rect, TRUE );
+static gboolean
+draw_tool_button (GdkWindow *window, GtkWidget *widget, GtkStyle *style,
+		  gint x, gint y, gint width, gint height,
+		  GtkStateType state_type, GdkRectangle *area)
+{
+  HDC dc;
+  RECT rect;
+  gboolean is_toggled = FALSE;
+
+  if (xp_theme_is_active ())
+    {
+      return (xp_theme_draw (window, XP_THEME_ELEMENT_TOOLBAR_BUTTON, style,
+			     x, y, width, height, state_type, area));
     }
-    release_window_dc( style, window, state_type );
-    return TRUE;
+
+  if (GTK_IS_TOGGLE_BUTTON (widget))
+    {
+      if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)))
+	{
+	  is_toggled = TRUE;
+	}
+    }
+
+  if (state_type != GTK_STATE_PRELIGHT
+      && state_type != GTK_STATE_ACTIVE && !is_toggled)
+    {
+      return FALSE;
+    }
+
+  dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+  if (state_type == GTK_STATE_PRELIGHT)
+    {
+      if (is_toggled)
+	{
+	  FillRect (dc, &rect, GetSysColorBrush (COLOR_BTNFACE));
+	}
+
+      draw_3d_border (dc, &rect, is_toggled);
+    }
+  else if (state_type == GTK_STATE_ACTIVE)
+    {
+      if (is_toggled && !is_menu_tool_button_child (widget->parent))
+	{
+	  SetTextColor (dc, GetSysColor (COLOR_3DHILIGHT));
+	  SetBkColor (dc, GetSysColor (COLOR_BTNFACE));
+	  FillRect (dc, &rect, get_dither_brush ());
+	}
+
+      draw_3d_border (dc, &rect, TRUE);
+    }
+
+  release_window_dc (style, window, state_type);
+
+  return TRUE;
 }
 
 static void
-draw_push_button( GdkWindow* window, GtkWidget* widget, GtkStyle* style, gint x, gint y,
-		  gint width, gint height, 
-		  GtkStateType state_type, gboolean is_default )
-{
-	HDC dc;
-	RECT rect;
-
-	dc = get_window_dc( style, window, state_type, 
-			x, y, width, height, &rect );
-        if( GTK_IS_TOGGLE_BUTTON(widget) )  {
-            if( state_type == GTK_STATE_PRELIGHT &&
-                gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(widget)) )
-            {
-                state_type = GTK_STATE_ACTIVE;
-            }
-        }
-
-	if( state_type == GTK_STATE_ACTIVE ) {
-            if( GTK_IS_TOGGLE_BUTTON(widget) ) {
-                DrawEdge( dc, &rect, EDGE_SUNKEN, BF_RECT|BF_ADJUST);
-                SetTextColor( dc, GetSysColor(COLOR_3DHILIGHT) );
-                SetBkColor( dc, GetSysColor(COLOR_BTNFACE) );
-                FillRect( dc, &rect, get_dither_brush() );
-            }
-            else {
-                FrameRect( dc, &rect, GetSysColorBrush(COLOR_WINDOWFRAME) );
-	        InflateRect( &rect, -1, -1 );
-                FrameRect( dc, &rect, GetSysColorBrush(COLOR_BTNSHADOW) );
-	        InflateRect( &rect, -1, -1 );
-                FillRect( dc, &rect, GetSysColorBrush(COLOR_BTNFACE) );
-            }
-	}
-	else {
-		if( is_default || GTK_WIDGET_HAS_FOCUS(widget) ) {
-                    FrameRect( dc, &rect, GetSysColorBrush(COLOR_WINDOWFRAME) );
-                    InflateRect( &rect, -1, -1 );
-		}
-		DrawFrameControl( dc, &rect, DFC_BUTTON, DFCS_BUTTONPUSH );
+draw_push_button (GdkWindow *window, GtkWidget *widget, GtkStyle *style,
+		  gint x, gint y, gint width, gint height,
+		  GtkStateType state_type, gboolean is_default)
+{
+  HDC dc;
+  RECT rect;
+
+  dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+
+  if (GTK_IS_TOGGLE_BUTTON (widget))
+    {
+      if (state_type == GTK_STATE_PRELIGHT &&
+	  gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)))
+	{
+	  state_type = GTK_STATE_ACTIVE;
+	}
+    }
+
+  if (state_type == GTK_STATE_ACTIVE)
+    {
+      if (GTK_IS_TOGGLE_BUTTON (widget))
+	{
+	  DrawEdge (dc, &rect, EDGE_SUNKEN, BF_RECT | BF_ADJUST);
+	  SetTextColor (dc, GetSysColor (COLOR_3DHILIGHT));
+	  SetBkColor (dc, GetSysColor (COLOR_BTNFACE));
+	  FillRect (dc, &rect, get_dither_brush ());
+	}
+      else
+	{
+	  FrameRect (dc, &rect, GetSysColorBrush (COLOR_WINDOWFRAME));
+	  InflateRect (&rect, -1, -1);
+	  FrameRect (dc, &rect, GetSysColorBrush (COLOR_BTNSHADOW));
+	  InflateRect (&rect, -1, -1);
+	  FillRect (dc, &rect, GetSysColorBrush (COLOR_BTNFACE));
+	}
+    }
+  else
+    {
+      if (is_default || GTK_WIDGET_HAS_FOCUS (widget))
+	{
+	  FrameRect (dc, &rect, GetSysColorBrush (COLOR_WINDOWFRAME));
+	  InflateRect (&rect, -1, -1);
 	}
-	release_window_dc(style, window, state_type);
+
+      DrawFrameControl (dc, &rect, DFC_BUTTON, DFCS_BUTTONPUSH);
+    }
+
+  release_window_dc (style, window, state_type);
 }
 
 static void
-draw_box (GtkStyle * style,
-	  GdkWindow * window,
+draw_box (GtkStyle *style,
+	  GdkWindow *window,
 	  GtkStateType state_type,
 	  GtkShadowType shadow_type,
-	  GdkRectangle * area,
-	  GtkWidget * widget,
-	  const gchar * detail, gint x, gint y, gint width, gint height)
-{
-    if (is_combo_box_child (widget) && detail && !strcmp (detail, "button")) {
-        RECT rect;
-        HDC dc;
-        int cx;
-           
-        dc = get_window_dc (style, window, state_type, x, y, width - cx, height, &rect);
-        FillRect (dc, &rect, GetSysColorBrush(COLOR_WINDOW));
-        release_window_dc (style, window, state_type);
-
-	cx = 2 * GetSystemMetrics (SM_CXEDGE) + 16; /* TODO evaluate arrow width */
-        x += width - cx;
-        width = cx;
-
-	if (xp_theme_is_active () && xp_theme_draw (
-	    window, XP_THEME_ELEMENT_COMBOBUTTON, style,
-	    x, y, width, height, state_type, area))
-	    return;
+	  GdkRectangle *area,
+	  GtkWidget *widget,
+	  const gchar *detail, gint x, gint y, gint width, gint height)
+{
+  if (is_combo_box_child (widget) && detail && !strcmp (detail, "button"))
+    {
+      RECT rect;
+      HDC dc;
+      int cx;
+
+      dc = get_window_dc (style, window, state_type, x, y, width - cx, height, &rect);
+      FillRect (dc, &rect, GetSysColorBrush (COLOR_WINDOW));
+      release_window_dc (style, window, state_type);
+
+      cx = 2 * GetSystemMetrics (SM_CXEDGE) + 16;	/* TODO evaluate arrow width */
+      x += width - cx;
+      width = cx;
+
+      if (xp_theme_is_active ()
+	  && xp_theme_draw (window, XP_THEME_ELEMENT_COMBOBUTTON, style, x, y,
+			    width, height, state_type, area))
+	{
+	  return;
+	}
     }
 
-    if (detail &&
-	(!strcmp (detail, "button") || !strcmp (detail, "buttondefault")))
+  if (detail &&
+      (!strcmp (detail, "button") || !strcmp (detail, "buttondefault")))
+    {
+      if (GTK_IS_TREE_VIEW (widget->parent) || GTK_IS_CLIST (widget->parent))
 	{
-	    if (GTK_IS_TREE_VIEW (widget->parent)
-		|| GTK_IS_CLIST (widget->parent))
-		{
-		    if (xp_theme_draw
-			(window, XP_THEME_ELEMENT_LIST_HEADER, style, x, y,
-			 width, height, state_type, area))
-			return;
-                    else {
-                        HDC dc;
-                        RECT rect;
-                        dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-
-                        DrawFrameControl( dc, &rect, DFC_BUTTON, DFCS_BUTTONPUSH | 
-                            (state_type == GTK_STATE_ACTIVE ? (DFCS_PUSHED|DFCS_FLAT) : 0 ) );
-                        release_window_dc( style, window, state_type );
-		}
-		}
-	    else if (is_toolbar_child (widget->parent)
-                    || (GTK_RELIEF_NONE == gtk_button_get_relief(GTK_BUTTON(widget)) ) )
-		{
-			if( draw_tool_button( window, widget, style, x, y, 
-					  width, height, state_type, area ) )
-		{
-			return;
-		}
-		}
-	    else
-		{
-			gboolean is_default = GTK_WIDGET_HAS_DEFAULT(widget);
-		    if (xp_theme_draw
-			(window,
-			 is_default ? XP_THEME_ELEMENT_DEFAULT_BUTTON :
-			 XP_THEME_ELEMENT_BUTTON, style, x, y, width, height,
-			 state_type, area))
-			{
-				return;
-			}
-			draw_push_button( window, widget, style, 
-				x, y, width, height, state_type, is_default );
-			return;
-		}
-            return;
+	  if (xp_theme_draw
+	      (window, XP_THEME_ELEMENT_LIST_HEADER, style, x, y,
+	       width, height, state_type, area))
+	    {
+	      return;
+	    }
+	  else
+	    {
+	      HDC dc;
+	      RECT rect;
+	      dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+
+	      DrawFrameControl (dc, &rect, DFC_BUTTON, DFCS_BUTTONPUSH |
+				(state_type ==
+				 GTK_STATE_ACTIVE ? (DFCS_PUSHED | DFCS_FLAT)
+				 : 0));
+	      release_window_dc (style, window, state_type);
+	    }
 	}
-    else if (detail && !strcmp (detail, "spinbutton"))
+      else if (is_toolbar_child (widget->parent)
+	       || (GTK_RELIEF_NONE ==
+		   gtk_button_get_relief (GTK_BUTTON (widget))))
 	{
-	    if (xp_theme_is_drawable (XP_THEME_ELEMENT_SPIN_BUTTON_UP))
-		{
-		    return;
-		}
+	  if (draw_tool_button (window, widget, style, x, y,
+				width, height, state_type, area))
+	    {
+	      return;
+	    }
 	}
-    else if (detail && (!strcmp (detail, "spinbutton_up")
-			|| !strcmp (detail, "spinbutton_down")))
+      else
 	{
-	    if ( ! xp_theme_draw ( window,
-			       (!strcmp (detail, "spinbutton_up"))
-			       ? XP_THEME_ELEMENT_SPIN_BUTTON_UP
-			       : XP_THEME_ELEMENT_SPIN_BUTTON_DOWN,
-			       style, x, y, width, height, state_type, area))
-		{
-                RECT rect;
-                HDC dc;
+	  gboolean is_default = GTK_WIDGET_HAS_DEFAULT (widget);
+	  if (xp_theme_draw
+	      (window,
+	       is_default ? XP_THEME_ELEMENT_DEFAULT_BUTTON :
+	       XP_THEME_ELEMENT_BUTTON, style, x, y, width, height,
+	       state_type, area))
+	    {
+	      return;
+	    }
 
-                dc = get_window_dc( style, window, state_type,
-                                    x, y, width, height, &rect );
-                DrawEdge( dc, &rect, 
-                        state_type == GTK_STATE_ACTIVE ? EDGE_SUNKEN : EDGE_RAISED, BF_RECT );
-                release_window_dc( style, window, state_type );
-		}
-            return;
+	  draw_push_button (window, widget, style,
+			    x, y, width, height, state_type, is_default);
+
+	  return;
 	}
-    else if (detail && !strcmp (detail, "slider"))
+
+      return;
+    }
+  else if (detail && !strcmp (detail, "spinbutton"))
+    {
+      if (xp_theme_is_drawable (XP_THEME_ELEMENT_SPIN_BUTTON_UP))
 	{
-	    if (GTK_IS_SCROLLBAR (widget))
-		{
-		    GtkScrollbar *scrollbar = GTK_SCROLLBAR (widget);
-		    gboolean is_v = GTK_IS_VSCROLLBAR (widget);
+	  return;
+	}
+    }
+  else if (detail && (!strcmp (detail, "spinbutton_up")
+		      || !strcmp (detail, "spinbutton_down")))
+    {
+      if (!xp_theme_draw (window,
+			  (!strcmp (detail, "spinbutton_up"))
+			  ? XP_THEME_ELEMENT_SPIN_BUTTON_UP
+			  : XP_THEME_ELEMENT_SPIN_BUTTON_DOWN,
+			  style, x, y, width, height, state_type, area))
+	{
+	  RECT rect;
+	  HDC dc;
+
+	  dc = get_window_dc (style, window, state_type,
+			      x, y, width, height, &rect);
+	  DrawEdge (dc, &rect,
+		    state_type ==
+		    GTK_STATE_ACTIVE ? EDGE_SUNKEN : EDGE_RAISED, BF_RECT);
+	  release_window_dc (style, window, state_type);
+	}
+      return;
+    }
+  else if (detail && !strcmp (detail, "slider"))
+    {
+      if (GTK_IS_SCROLLBAR (widget))
+	{
+	  GtkScrollbar *scrollbar = GTK_SCROLLBAR (widget);
+	  gboolean is_v = GTK_IS_VSCROLLBAR (widget);
 
-			if (xp_theme_draw (window,
-				       is_v
-				       ? XP_THEME_ELEMENT_SCROLLBAR_V
-				       : XP_THEME_ELEMENT_SCROLLBAR_H,
-				       style, x, y, width, height, state_type,
-				       area))
-			{
-			    XpThemeElement gripper =
-				(is_v ? XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_V :
-				 XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_H);
-
-			    /* Do not display grippers on tiny scroll bars,
-			       the limit imposed is rather arbitrary, perhaps
-			       we can fetch the gripper geometry from
-			       somewhere and use that... */
-			    if ((gripper ==
-				 XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_H
-				 && width < 16)
-				|| (gripper ==
-				    XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_V
-				    && height < 16))
-				{
-				    return;
-				}
-
-			    xp_theme_draw (window, gripper, style, x, y,
-					   width, height, state_type, area);
-			    return;
-			}
-		    else
-			{
-			    if (scrollbar->range.adjustment->page_size >=
-				(scrollbar->range.adjustment->upper -
-				 scrollbar->range.adjustment->lower))
-				return;
-			}
+	  if (xp_theme_draw (window,
+			     is_v
+			     ? XP_THEME_ELEMENT_SCROLLBAR_V
+			     : XP_THEME_ELEMENT_SCROLLBAR_H,
+			     style, x, y, width, height, state_type, area))
+	    {
+	      XpThemeElement gripper =
+		(is_v ? XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_V :
+		 XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_H);
+
+	      /* Do not display grippers on tiny scroll bars,
+	         the limit imposed is rather arbitrary, perhaps
+	         we can fetch the gripper geometry from
+	         somewhere and use that... */
+	      if ((gripper ==
+		   XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_H
+		   && width < 16)
+		  || (gripper ==
+		      XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_V && height < 16))
+		{
+		  return;
+		}
+
+	      xp_theme_draw (window, gripper, style, x, y,
+			     width, height, state_type, area);
+	      return;
+	    }
+	  else
+	    {
+	      if (scrollbar->range.adjustment->page_size >=
+		  (scrollbar->range.adjustment->upper -
+		   scrollbar->range.adjustment->lower))
+		{
+		  return;
 		}
+	    }
 	}
-    else if (detail && !strcmp (detail, "bar"))
+    }
+  else if (detail && !strcmp (detail, "bar"))
+    {
+      if (widget && GTK_IS_PROGRESS_BAR (widget))
 	{
-	    if (widget && GTK_IS_PROGRESS_BAR (widget))
-		{
-		    GtkProgressBar *progress_bar = GTK_PROGRESS_BAR (widget);
-		    XpThemeElement xp_progress_bar =
-			map_gtk_progress_bar_to_xp (progress_bar, FALSE);
-
-		    if (xp_theme_draw (window, xp_progress_bar, style, x, y,
-							   width, height, state_type, area))
-			{
-			    return;
-			}
+	  GtkProgressBar *progress_bar = GTK_PROGRESS_BAR (widget);
+	  XpThemeElement xp_progress_bar =
+	    map_gtk_progress_bar_to_xp (progress_bar, FALSE);
 
-			shadow_type = GTK_SHADOW_NONE;
-		}
+	  if (xp_theme_draw (window, xp_progress_bar, style, x, y,
+			     width, height, state_type, area))
+	    {
+	      return;
+	    }
+
+	  shadow_type = GTK_SHADOW_NONE;
 	}
-    else if (detail && strcmp (detail, "menuitem") == 0)
+    }
+  else if (detail && strcmp (detail, "menuitem") == 0)
+    {
+      shadow_type = GTK_SHADOW_NONE;
+      if (draw_menu_item (window, widget, style,
+			  x, y, width, height, state_type, area))
 	{
-	    shadow_type = GTK_SHADOW_NONE;
-        if( draw_menu_item(window, widget, style, 
-            x, y, width, height, state_type, area ) )
-		{
-		    return;
-		}
+	  return;
 	}
-    else if (detail && !strcmp (detail, "trough"))
+    }
+  else if (detail && !strcmp (detail, "trough"))
+    {
+      if (widget && GTK_IS_PROGRESS_BAR (widget))
 	{
-	    if (widget && GTK_IS_PROGRESS_BAR (widget))
-		{
-		    GtkProgressBar *progress_bar = GTK_PROGRESS_BAR (widget);
-		    XpThemeElement xp_progress_bar =
-			map_gtk_progress_bar_to_xp (progress_bar, TRUE);
-		    if (xp_theme_draw
-			(window, xp_progress_bar, style, x, y, width, height,
-			 state_type, area))
-			{
-			    return;
-			}
-		    else
-			{
-			    /* Blank in classic Windows */
-			}
-		}
-	    else if (widget && GTK_IS_SCROLLBAR (widget))
-		{
-		    gboolean is_vertical = GTK_IS_VSCROLLBAR (widget);
+	  GtkProgressBar *progress_bar = GTK_PROGRESS_BAR (widget);
+	  XpThemeElement xp_progress_bar =
+	    map_gtk_progress_bar_to_xp (progress_bar, TRUE);
+	  if (xp_theme_draw
+	      (window, xp_progress_bar, style, x, y, width, height,
+	       state_type, area))
+	    {
+	      return;
+	    }
+	  else
+	    {
+	      /* Blank in classic Windows */
+	    }
+	}
+      else if (widget && GTK_IS_SCROLLBAR (widget))
+	{
+	  gboolean is_vertical = GTK_IS_VSCROLLBAR (widget);
+
+	  if (xp_theme_draw (window,
+			     is_vertical
+			     ? XP_THEME_ELEMENT_TROUGH_V
+			     : XP_THEME_ELEMENT_TROUGH_H,
+			     style, x, y, width, height, state_type, area))
+	    {
+	      return;
+	    }
+	  else
+	    {
+	      HDC dc;
+	      RECT rect;
 
-		    if (xp_theme_draw (window,
-				       is_vertical
-				       ? XP_THEME_ELEMENT_TROUGH_V
-				       : XP_THEME_ELEMENT_TROUGH_H,
-				       style,
-				       x, y, width, height, state_type, area))
-			{
-			    return;
-			}
-		    else
-			{
-                            HDC dc;
-                            RECT rect;
-
-			    sanitize_size (window, &width, &height);
-                            dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-                            SetTextColor( dc, GetSysColor(COLOR_3DHILIGHT) );
-                            SetBkColor( dc, GetSysColor(COLOR_BTNFACE) );
-                            FillRect( dc, &rect, get_dither_brush() );
-                            release_window_dc( style, window, state_type );
+	      sanitize_size (window, &width, &height);
+	      dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
 
-			    return;
-			}
-		}
-	    else if (widget && GTK_IS_SCALE (widget))
-		{
-		    gboolean is_vertical = GTK_IS_VSCALE (widget);
+	      SetTextColor (dc, GetSysColor (COLOR_3DHILIGHT));
+	      SetBkColor (dc, GetSysColor (COLOR_BTNFACE));
+	      FillRect (dc, &rect, get_dither_brush ());
 
-		    if (!xp_theme_is_active ())
-			{
-			    parent_class->draw_box (style, window, state_type,
-						    GTK_SHADOW_NONE, area,
-						    widget, detail, x, y,
-						    width, height);
-			}
-
-		    if (is_vertical)
-			{
-			    if (xp_theme_draw
-				(window, XP_THEME_ELEMENT_SCALE_TROUGH_V,
-				 style, (2 * x + width) / 2, y, 2, height,
-				 state_type, area))
-				return;
-
-			    parent_class->draw_box (style, window, state_type,
-						    GTK_SHADOW_ETCHED_IN,
-						    area, NULL, NULL,
-						    (2 * x + width) / 2, y, 1,
-						    height);
-			}
-		    else
-			{
-			    if (xp_theme_draw
-				(window, XP_THEME_ELEMENT_SCALE_TROUGH_H,
-				 style, x, (2 * y + height) / 2, width, 2,
-				 state_type, area))
-				return;
-
-			    parent_class->draw_box (style, window, state_type,
-						    GTK_SHADOW_ETCHED_IN,
-						    area, NULL, NULL, x,
-						    (2 * y + height) / 2,
-						    width, 1);
-			}
-		    return;
-		}
+	      release_window_dc (style, window, state_type);
+
+	      return;
+	    }
 	}
-    else if (detail && strcmp (detail, "optionmenu") == 0)
+      else if (widget && GTK_IS_SCALE (widget))
 	{
-	    if (xp_theme_draw (window, XP_THEME_ELEMENT_EDIT_TEXT,
-			       style, x, y, width, height, state_type, area))
-		{
-		    return;
+	  gboolean is_vertical = GTK_IS_VSCALE (widget);
+
+	  if (!xp_theme_is_active ())
+	    {
+	      parent_class->draw_box (style, window, state_type,
+				      GTK_SHADOW_NONE, area,
+				      widget, detail, x, y, width, height);
+	    }
+
+	  if (is_vertical)
+	    {
+	      if (xp_theme_draw
+		  (window, XP_THEME_ELEMENT_SCALE_TROUGH_V,
+		   style, (2 * x + width) / 2, y, 2, height,
+		   state_type, area))
+		{
+		  return;
 		}
-	}
-    else if (detail
-	     && (strcmp (detail, "vscrollbar") == 0
-		 || strcmp (detail, "hscrollbar") == 0))
-	{
-            return;
-	}
-    else if (detail
-	     && (strcmp (detail, "handlebox_bin") == 0
-		 || strcmp (detail, "toolbar") == 0
-		 || strcmp (detail, "menubar") == 0))
-	{
-            sanitize_size( window, &width, &height );
-	    if (xp_theme_draw (window, XP_THEME_ELEMENT_REBAR,
-			       style, x, y, width, height, state_type, area))
-		{
-		    return;
+
+	      parent_class->draw_box (style, window, state_type,
+				      GTK_SHADOW_ETCHED_IN,
+				      area, NULL, NULL,
+				      (2 * x + width) / 2, y, 1, height);
+	    }
+	  else
+	    {
+	      if (xp_theme_draw
+		  (window, XP_THEME_ELEMENT_SCALE_TROUGH_H,
+		   style, x, (2 * y + height) / 2, width, 2,
+		   state_type, area))
+		{
+		  return;
 		}
+
+	      parent_class->draw_box (style, window, state_type,
+				      GTK_SHADOW_ETCHED_IN,
+				      area, NULL, NULL, x,
+				      (2 * y + height) / 2, width, 1);
+	    }
+
+	  return;
+	}
+    }
+  else if (detail && strcmp (detail, "optionmenu") == 0)
+    {
+      if (xp_theme_draw (window, XP_THEME_ELEMENT_EDIT_TEXT,
+			 style, x, y, width, height, state_type, area))
+	{
+	  return;
 	}
-    else if (detail && (!strcmp (detail, "handlebox")))	/* grip */
+    }
+  else if (detail
+	   && (strcmp (detail, "vscrollbar") == 0
+	       || strcmp (detail, "hscrollbar") == 0))
+    {
+      return;
+    }
+  else if (detail
+	   && (strcmp (detail, "handlebox_bin") == 0
+	       || strcmp (detail, "toolbar") == 0
+	       || strcmp (detail, "menubar") == 0))
+    {
+      sanitize_size (window, &width, &height);
+      if (xp_theme_draw (window, XP_THEME_ELEMENT_REBAR,
+			 style, x, y, width, height, state_type, area))
 	{
-            if( !xp_theme_is_active() ) {
-                return;
-            }
+	  return;
 	}
-    else if (detail && !strcmp (detail, "notebook") && GTK_IS_NOTEBOOK (widget))
+    }
+  else if (detail && (!strcmp (detail, "handlebox")))	/* grip */
+    {
+      if (!xp_theme_is_active ())
 	{
-	    GtkNotebook *notebook = GTK_NOTEBOOK (widget);
+	  return;
+	}
+    }
+  else if (detail && !strcmp (detail, "notebook") && GTK_IS_NOTEBOOK (widget))
+    {
+      GtkNotebook *notebook = GTK_NOTEBOOK (widget);
 
-	    if (xp_theme_draw (window, XP_THEME_ELEMENT_TAB_PANE, style,
-			       x, y, width, height, state_type, area))
-		{
-		    return;
-		}
+      if (xp_theme_draw (window, XP_THEME_ELEMENT_TAB_PANE, style,
+			 x, y, width, height, state_type, area))
+	{
+	  return;
 	}
+    }
+
+  else
+    {
+      const gchar *name = gtk_widget_get_name (widget);
 
-    else
+      if (name && !strcmp (name, "gtk-tooltips"))
 	{
-	    const gchar *name = gtk_widget_get_name (widget);
+	  if (xp_theme_draw
+	      (window, XP_THEME_ELEMENT_TOOLTIP, style, x, y, width,
+	       height, state_type, area))
+	    {
+	      return;
+	    }
+	  else
+	    {
+	      HBRUSH brush;
+	      RECT rect;
+	      HDC hdc;
+
+	      hdc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+
+	      brush = GetSysColorBrush (COLOR_3DDKSHADOW);
 
-	    if (name && !strcmp (name, "gtk-tooltips"))
+	      if (brush)
 		{
-		    if (xp_theme_draw
-			(window, XP_THEME_ELEMENT_TOOLTIP, style, x, y, width,
-			 height, state_type, area))
-			{
-			    return;
-			}
-		    else
-			{
-			    HBRUSH brush;
-			    RECT rect;
-			    HDC hdc;
-
-				hdc = get_window_dc(style, window, state_type, x, y, width, height, &rect);
-
-			    brush = GetSysColorBrush (COLOR_3DDKSHADOW);
-			    if (brush)
-				FrameRect (hdc, &rect, brush);
-			    InflateRect (&rect, -1, -1);
-			    FillRect (hdc, &rect,
-				      (HBRUSH) (COLOR_INFOBK + 1));
+		  FrameRect (hdc, &rect, brush);
+		}
 
-				release_window_dc (style, window, state_type);
+	      InflateRect (&rect, -1, -1);
+	      FillRect (hdc, &rect, (HBRUSH) (COLOR_INFOBK + 1));
 
-			    return;
-			}
+	      release_window_dc (style, window, state_type);
 
-		}
+	      return;
+	    }
 	}
+    }
+
+  parent_class->draw_box (style, window, state_type, shadow_type, area,
+			  widget, detail, x, y, width, height);
+
+  if (detail && strcmp (detail, "optionmenu") == 0)
+    {
+      GtkRequisition indicator_size;
+      GtkBorder indicator_spacing;
+      gint vline_x;
+
+      option_menu_get_props (widget, &indicator_size, &indicator_spacing);
 
-    parent_class->draw_box (style, window, state_type, shadow_type, area,
-			    widget, detail, x, y, width, height);
+      sanitize_size (window, &width, &height);
 
-    if (detail && strcmp (detail, "optionmenu") == 0)
+      if (gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL)
 	{
-	    GtkRequisition indicator_size;
-	    GtkBorder indicator_spacing;
-	    gint vline_x;
-
-	    option_menu_get_props (widget, &indicator_size,
-				   &indicator_spacing);
-
-	    sanitize_size (window, &width, &height);
-
-	    if (gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL)
-		vline_x =
-		    x + indicator_size.width + indicator_spacing.left +
-		    indicator_spacing.right;
-	    else
-		vline_x =
-		    x + width - (indicator_size.width +
+	  vline_x =
+	    x + indicator_size.width + indicator_spacing.left +
+	    indicator_spacing.right;
+	}
+      else
+	{
+	  vline_x = x + width - (indicator_size.width +
 				 indicator_spacing.left +
 				 indicator_spacing.right) - style->xthickness;
 
-	    parent_class->draw_vline (style, window, state_type, area, widget,
-				      detail,
-				      y + style->ythickness + 1,
-				      y + height - style->ythickness - 3,
-				      vline_x);
+	  parent_class->draw_vline (style, window, state_type, area, widget,
+				    detail,
+				    y + style->ythickness + 1,
+				    y + height - style->ythickness - 3, vline_x);
 	}
+    }
 }
 
 static void
-draw_tab (GtkStyle * style,
-	  GdkWindow * window,
+draw_tab (GtkStyle *style,
+	  GdkWindow *window,
 	  GtkStateType state,
 	  GtkShadowType shadow,
-	  GdkRectangle * area,
-	  GtkWidget * widget,
-	  const gchar * detail, gint x, gint y, gint width, gint height)
+	  GdkRectangle *area,
+	  GtkWidget *widget,
+	  const gchar *detail, gint x, gint y, gint width, gint height)
 {
-    GtkRequisition indicator_size;
-    GtkBorder indicator_spacing;
+  GtkRequisition indicator_size;
+  GtkBorder indicator_spacing;
 
-    gint arrow_height;
+  gint arrow_height;
 
-    g_return_if_fail (style != NULL);
-    g_return_if_fail (window != NULL);
+  g_return_if_fail (style != NULL);
+  g_return_if_fail (window != NULL);
 
-    if (detail && !strcmp (detail, "optionmenutab"))
+  if (detail && !strcmp (detail, "optionmenutab"))
+    {
+      if (xp_theme_draw (window, XP_THEME_ELEMENT_COMBOBUTTON,
+			 style, x - 5, widget->allocation.y + 1,
+			 width + 10, widget->allocation.height - 2,
+			 state, area))
 	{
-	    if (xp_theme_draw (window, XP_THEME_ELEMENT_COMBOBUTTON,
-			       style, x - 5, widget->allocation.y + 1,
-			       width + 10, widget->allocation.height - 2,
-			       state, area))
-		{
-		    return;
-		}
+	  return;
 	}
+    }
 
-    option_menu_get_props (widget, &indicator_size, &indicator_spacing);
+  option_menu_get_props (widget, &indicator_size, &indicator_spacing);
 
-    x += (width - indicator_size.width) / 2;
-    arrow_height = (indicator_size.width + 1) / 2;
+  x += (width - indicator_size.width) / 2;
+  arrow_height = (indicator_size.width + 1) / 2;
 
-    y += (height - arrow_height) / 2;
+  y += (height - arrow_height) / 2;
 
-    draw_varrow (window, style->black_gc, shadow, area, GTK_ARROW_DOWN,
-		 x, y, indicator_size.width, arrow_height);
+  draw_varrow (window, style->black_gc, shadow, area, GTK_ARROW_DOWN,
+	       x, y, indicator_size.width, arrow_height);
 }
 
 /* Draw classic Windows tab - thanks Mozilla!
   (no system API for this, but DrawEdge can draw all the parts of a tab) */
-static void DrawTab(HDC hdc, const RECT R, gint32 aPosition, gboolean aSelected,
-                     gboolean aDrawLeft, gboolean aDrawRight)
+static void
+DrawTab (HDC hdc, const RECT R, gint32 aPosition, gboolean aSelected,
+	 gboolean aDrawLeft, gboolean aDrawRight)
 {
   gint32 leftFlag, topFlag, rightFlag, lightFlag, shadeFlag;
   RECT topRect, sideRect, bottomRect, lightRect, shadeRect;
@@ -2289,96 +2408,111 @@
   switch (aPosition)
     {
     case BF_LEFT:
-      leftFlag = BF_TOP; topFlag = BF_LEFT;
+      leftFlag = BF_TOP;
+      topFlag = BF_LEFT;
       rightFlag = BF_BOTTOM;
       lightFlag = BF_DIAGONAL_ENDTOPRIGHT;
       shadeFlag = BF_DIAGONAL_ENDBOTTOMRIGHT;
 
-      SetRect(&topRect, R.left, R.top+lOffset, R.right, R.bottom-rOffset);
-      SetRect(&sideRect, R.left+2, R.top, R.right-2+selectedOffset, R.bottom);
-      SetRect(&bottomRect, R.right-2, R.top, R.right, R.bottom);
-      SetRect(&lightRect, R.left, R.top, R.left+3, R.top+3);
-      SetRect(&shadeRect, R.left+1, R.bottom-2, R.left+2, R.bottom-1);
+      SetRect (&topRect, R.left, R.top + lOffset, R.right,
+	       R.bottom - rOffset);
+      SetRect (&sideRect, R.left + 2, R.top, R.right - 2 + selectedOffset,
+	       R.bottom);
+      SetRect (&bottomRect, R.right - 2, R.top, R.right, R.bottom);
+      SetRect (&lightRect, R.left, R.top, R.left + 3, R.top + 3);
+      SetRect (&shadeRect, R.left + 1, R.bottom - 2, R.left + 2,
+	       R.bottom - 1);
       break;
 
     case BF_TOP:
-      leftFlag = BF_LEFT; topFlag = BF_TOP;
+      leftFlag = BF_LEFT;
+      topFlag = BF_TOP;
       rightFlag = BF_RIGHT;
       lightFlag = BF_DIAGONAL_ENDTOPRIGHT;
       shadeFlag = BF_DIAGONAL_ENDBOTTOMRIGHT;
 
-      SetRect(&topRect, R.left+lOffset, R.top, R.right-rOffset, R.bottom);
-      SetRect(&sideRect, R.left, R.top+2, R.right, R.bottom-1+selectedOffset);
-      SetRect(&bottomRect, R.left, R.bottom-1, R.right, R.bottom);
-      SetRect(&lightRect, R.left, R.top, R.left+3, R.top+3);
-      SetRect(&shadeRect, R.right-2, R.top+1, R.right-1, R.top+2);
+      SetRect (&topRect, R.left + lOffset, R.top, R.right - rOffset,
+	       R.bottom);
+      SetRect (&sideRect, R.left, R.top + 2, R.right,
+	       R.bottom - 1 + selectedOffset);
+      SetRect (&bottomRect, R.left, R.bottom - 1, R.right, R.bottom);
+      SetRect (&lightRect, R.left, R.top, R.left + 3, R.top + 3);
+      SetRect (&shadeRect, R.right - 2, R.top + 1, R.right - 1, R.top + 2);
       break;
+
     case BF_RIGHT:
-      leftFlag = BF_TOP; topFlag = BF_RIGHT;
+      leftFlag = BF_TOP;
+      topFlag = BF_RIGHT;
       rightFlag = BF_BOTTOM;
       lightFlag = BF_DIAGONAL_ENDTOPLEFT;
       shadeFlag = BF_DIAGONAL_ENDBOTTOMLEFT;
 
-      SetRect(&topRect, R.left, R.top+lOffset, R.right, R.bottom-rOffset);
-      SetRect(&sideRect, R.left+2-selectedOffset, R.top, R.right-2, R.bottom);
-      SetRect(&bottomRect, R.left, R.top, R.left+2, R.bottom);
-      SetRect(&lightRect, R.right-3, R.top, R.right-1, R.top+2);
-      SetRect(&shadeRect, R.right-2, R.bottom-3, R.right, R.bottom-1);
+      SetRect (&topRect, R.left, R.top + lOffset, R.right,
+	       R.bottom - rOffset);
+      SetRect (&sideRect, R.left + 2 - selectedOffset, R.top, R.right - 2,
+	       R.bottom);
+      SetRect (&bottomRect, R.left, R.top, R.left + 2, R.bottom);
+      SetRect (&lightRect, R.right - 3, R.top, R.right - 1, R.top + 2);
+      SetRect (&shadeRect, R.right - 2, R.bottom - 3, R.right, R.bottom - 1);
       break;
 
     case BF_BOTTOM:
-      leftFlag = BF_LEFT; topFlag = BF_BOTTOM;
+      leftFlag = BF_LEFT;
+      topFlag = BF_BOTTOM;
       rightFlag = BF_RIGHT;
       lightFlag = BF_DIAGONAL_ENDTOPLEFT;
       shadeFlag = BF_DIAGONAL_ENDBOTTOMLEFT;
 
-      SetRect(&topRect, R.left+lOffset, R.top, R.right-rOffset, R.bottom);
-      SetRect(&sideRect, R.left, R.top+2-selectedOffset, R.right, R.bottom-2);
-      SetRect(&bottomRect, R.left, R.top, R.right, R.top+2);
-      SetRect(&lightRect, R.left, R.bottom-3, R.left+2, R.bottom-1);
-      SetRect(&shadeRect, R.right-2, R.bottom-3, R.right, R.bottom-1);
+      SetRect (&topRect, R.left + lOffset, R.top, R.right - rOffset,
+	       R.bottom);
+      SetRect (&sideRect, R.left, R.top + 2 - selectedOffset, R.right,
+	       R.bottom - 2);
+      SetRect (&bottomRect, R.left, R.top, R.right, R.top + 2);
+      SetRect (&lightRect, R.left, R.bottom - 3, R.left + 2, R.bottom - 1);
+      SetRect (&shadeRect, R.right - 2, R.bottom - 3, R.right, R.bottom - 1);
       break;
 
     default:
-      g_return_if_reached();
+      g_return_if_reached ();
     }
-  
+
   /* Background */
-  FillRect(hdc, &R, (HBRUSH) (COLOR_3DFACE+1) );
+  FillRect (hdc, &R, (HBRUSH) (COLOR_3DFACE + 1));
 
   /* Tab "Top" */
-  DrawEdge(hdc, &topRect, EDGE_RAISED, BF_SOFT | topFlag);
+  DrawEdge (hdc, &topRect, EDGE_RAISED, BF_SOFT | topFlag);
 
   /* Tab "Bottom" */
   if (!aSelected)
-    DrawEdge(hdc, &bottomRect, EDGE_RAISED, BF_SOFT | topFlag);
+    DrawEdge (hdc, &bottomRect, EDGE_RAISED, BF_SOFT | topFlag);
 
   /* Tab "Sides" */
   if (!aDrawLeft)
     leftFlag = 0;
   if (!aDrawRight)
     rightFlag = 0;
-  DrawEdge(hdc, &sideRect, EDGE_RAISED, BF_SOFT | leftFlag | rightFlag);
+
+  DrawEdge (hdc, &sideRect, EDGE_RAISED, BF_SOFT | leftFlag | rightFlag);
 
   /* Tab Diagonal Corners */
   if (aDrawLeft)
-    DrawEdge(hdc, &lightRect, EDGE_RAISED, BF_SOFT | lightFlag);
+    DrawEdge (hdc, &lightRect, EDGE_RAISED, BF_SOFT | lightFlag);
 
   if (aDrawRight)
-    DrawEdge(hdc, &shadeRect, EDGE_RAISED, BF_SOFT | shadeFlag);
+    DrawEdge (hdc, &shadeRect, EDGE_RAISED, BF_SOFT | shadeFlag);
 }
 
 static gboolean
 draw_themed_tab_button (GtkStyle *style,
-                        GdkWindow *window,
-                        GtkStateType state_type,
-                        GtkNotebook *notebook,
-                        gint x, gint y,
-                        gint width, gint height,
-                        gint gap_side)
+			GdkWindow *window,
+			GtkStateType state_type,
+			GtkNotebook *notebook,
+			gint x, gint y,
+			gint width, gint height, gint gap_side)
 {
   GdkPixmap *pixmap = NULL;
-  gint border_width = gtk_container_get_border_width (GTK_CONTAINER (notebook));
+  gint border_width =
+    gtk_container_get_border_width (GTK_CONTAINER (notebook));
   GtkWidget *widget = GTK_WIDGET (notebook);
   GdkRectangle draw_rect, clip_rect;
   GdkPixbufRotation rotation = GDK_PIXBUF_ROTATE_NONE;
@@ -2388,59 +2522,61 @@
       int widget_right;
 
       if (state_type == GTK_STATE_NORMAL)
-        {
-          draw_rect.x = x;
-          draw_rect.y = y;
-          draw_rect.width = width + 2;
-          draw_rect.height = height;
-
-          clip_rect = draw_rect;
-          clip_rect.height--;
-        }
-      else
-        {
-          draw_rect.x = x + 2;
-          draw_rect.y = y;
-          draw_rect.width = width - 2;
-          draw_rect.height = height - 2;
-          clip_rect = draw_rect;
-        }
+	{
+	  draw_rect.x = x;
+	  draw_rect.y = y;
+	  draw_rect.width = width + 2;
+	  draw_rect.height = height;
+
+	  clip_rect = draw_rect;
+	  clip_rect.height--;
+	}
+      else
+	{
+	  draw_rect.x = x + 2;
+	  draw_rect.y = y;
+	  draw_rect.width = width - 2;
+	  draw_rect.height = height - 2;
+	  clip_rect = draw_rect;
+	}
 
       /* If we are currently drawing the right-most tab, and if that tab is the selected tab... */
       widget_right = widget->allocation.x + widget->allocation.width - border_width - 2;
+
       if (draw_rect.x + draw_rect.width >= widget_right)
-        {
-          draw_rect.width = clip_rect.width = widget_right - draw_rect.x;
-        }
+	{
+	  draw_rect.width = clip_rect.width = widget_right - draw_rect.x;
+	}
     }
   if (gap_side == GTK_POS_BOTTOM)
     {
       int widget_right;
-    
+
       if (state_type == GTK_STATE_NORMAL)
-        {
-          draw_rect.x = x;
-          draw_rect.y = y;
-          draw_rect.width = width + 2;
-          draw_rect.height = height;
-
-          clip_rect = draw_rect;
-        }
-      else
-        {
-          draw_rect.x = x + 2;
-          draw_rect.y = y + 2;
-          draw_rect.width = width - 2;
-          draw_rect.height = height - 2;
-          clip_rect = draw_rect;
-        }
+	{
+	  draw_rect.x = x;
+	  draw_rect.y = y;
+	  draw_rect.width = width + 2;
+	  draw_rect.height = height;
+
+	  clip_rect = draw_rect;
+	}
+      else
+	{
+	  draw_rect.x = x + 2;
+	  draw_rect.y = y + 2;
+	  draw_rect.width = width - 2;
+	  draw_rect.height = height - 2;
+	  clip_rect = draw_rect;
+	}
 
       /* If we are currently drawing the right-most tab, and if that tab is the selected tab... */
       widget_right = widget->allocation.x + widget->allocation.width - border_width - 2;
+
       if (draw_rect.x + draw_rect.width >= widget_right)
-        {
-          draw_rect.width = clip_rect.width = widget_right - draw_rect.x;
-        }
+	{
+	  draw_rect.width = clip_rect.width = widget_right - draw_rect.x;
+	}
 
       rotation = GDK_PIXBUF_ROTATE_UPSIDEDOWN;
     }
@@ -2449,30 +2585,31 @@
       int widget_bottom;
 
       if (state_type == GTK_STATE_NORMAL)
-        {
-          draw_rect.x = x;
-          draw_rect.y = y;
-          draw_rect.width = width;
-          draw_rect.height = height + 2;
-
-          clip_rect = draw_rect;
-          clip_rect.width--;
-        }
-      else
-        {
-          draw_rect.x = x;
-          draw_rect.y = y + 2;
-          draw_rect.width = width - 2;
-          draw_rect.height = height - 2;
-          clip_rect = draw_rect;
-        }
+	{
+	  draw_rect.x = x;
+	  draw_rect.y = y;
+	  draw_rect.width = width;
+	  draw_rect.height = height + 2;
+
+	  clip_rect = draw_rect;
+	  clip_rect.width--;
+	}
+      else
+	{
+	  draw_rect.x = x;
+	  draw_rect.y = y + 2;
+	  draw_rect.width = width - 2;
+	  draw_rect.height = height - 2;
+	  clip_rect = draw_rect;
+	}
 
       /* If we are currently drawing the bottom-most tab, and if that tab is the selected tab... */
       widget_bottom = widget->allocation.x + widget->allocation.height - border_width - 2;
+
       if (draw_rect.y + draw_rect.height >= widget_bottom)
-        {
-          draw_rect.height = clip_rect.height = widget_bottom - draw_rect.y;
-        }
+	{
+	  draw_rect.height = clip_rect.height = widget_bottom - draw_rect.y;
+	}
 
       rotation = GDK_PIXBUF_ROTATE_COUNTERCLOCKWISE;
     }
@@ -2481,30 +2618,31 @@
       int widget_bottom;
 
       if (state_type == GTK_STATE_NORMAL)
-        {
-          draw_rect.x = x + 1;
-          draw_rect.y = y;
-          draw_rect.width = width;
-          draw_rect.height = height + 2;
-
-          clip_rect = draw_rect;
-          clip_rect.width--;
-        }
-      else
-        {
-          draw_rect.x = x + 2;
-          draw_rect.y = y + 2;
-          draw_rect.width = width - 2;
-          draw_rect.height = height - 2;
-          clip_rect = draw_rect;
-        }
+	{
+	  draw_rect.x = x + 1;
+	  draw_rect.y = y;
+	  draw_rect.width = width;
+	  draw_rect.height = height + 2;
+
+	  clip_rect = draw_rect;
+	  clip_rect.width--;
+	}
+      else
+	{
+	  draw_rect.x = x + 2;
+	  draw_rect.y = y + 2;
+	  draw_rect.width = width - 2;
+	  draw_rect.height = height - 2;
+	  clip_rect = draw_rect;
+	}
 
       /* If we are currently drawing the bottom-most tab, and if that tab is the selected tab... */
       widget_bottom = widget->allocation.x + widget->allocation.height - border_width - 2;
+
       if (draw_rect.y + draw_rect.height >= widget_bottom)
-        {
-          draw_rect.height = clip_rect.height = widget_bottom - draw_rect.y;
-        }
+	{
+	  draw_rect.height = clip_rect.height = widget_bottom - draw_rect.y;
+	}
 
       rotation = GDK_PIXBUF_ROTATE_CLOCKWISE;
     }
@@ -2512,12 +2650,12 @@
   if (gap_side == GTK_POS_TOP)
     {
       if (!xp_theme_draw (window, XP_THEME_ELEMENT_TAB_ITEM, style,
-                          draw_rect.x, draw_rect.y,
-                          draw_rect.width,draw_rect.height,
-                          state_type, &clip_rect))
-        {
-          return FALSE;
-        }
+			  draw_rect.x, draw_rect.y,
+			  draw_rect.width, draw_rect.height,
+			  state_type, &clip_rect))
+	{
+	  return FALSE;
+	}
     }
   else
     {
@@ -2525,35 +2663,37 @@
       GdkPixbuf *rotated;
 
       if (gap_side == GTK_POS_LEFT || gap_side == GTK_POS_RIGHT)
-        {
-          pixmap = gdk_pixmap_new (window, clip_rect.height, clip_rect.width, -1);
-          if (!xp_theme_draw (pixmap, XP_THEME_ELEMENT_TAB_ITEM, style,
-                              draw_rect.y - clip_rect.y, draw_rect.x - clip_rect.x,
-                              draw_rect.height, draw_rect.width, state_type, 0))
-            {
-              g_object_unref (pixmap);
-              return FALSE;
-            }
-
-          pixbuf = gdk_pixbuf_get_from_drawable (NULL, pixmap, NULL, 0, 0, 0, 0,
-                                                 clip_rect.height, clip_rect.width);
-          g_object_unref (pixmap);
-        }
-      else
-        {
-          pixmap = gdk_pixmap_new (window, clip_rect.width, clip_rect.height, -1);
-          if (!xp_theme_draw (pixmap, XP_THEME_ELEMENT_TAB_ITEM, style,
-                              draw_rect.x - clip_rect.x, draw_rect.y - clip_rect.y,
-                              draw_rect.width, draw_rect.height, state_type, 0))
-            {
-              g_object_unref (pixmap);
-              return FALSE;
-            }
-
-          pixbuf = gdk_pixbuf_get_from_drawable (NULL, pixmap, NULL, 0, 0, 0, 0,
-                                                 clip_rect.width, clip_rect.height);
-          g_object_unref (pixmap);
-        }
+	{
+	  pixmap = gdk_pixmap_new (window, clip_rect.height, clip_rect.width, -1);
+
+	  if (!xp_theme_draw (pixmap, XP_THEME_ELEMENT_TAB_ITEM, style,
+			      draw_rect.y - clip_rect.y, draw_rect.x - clip_rect.x,
+			      draw_rect.height, draw_rect.width, state_type, 0))
+	    {
+	      g_object_unref (pixmap);
+	      return FALSE;
+	    }
+
+	  pixbuf = gdk_pixbuf_get_from_drawable (NULL, pixmap, NULL, 0, 0, 0, 0,
+						 clip_rect.height, clip_rect.width);
+	  g_object_unref (pixmap);
+	}
+      else
+	{
+	  pixmap = gdk_pixmap_new (window, clip_rect.width, clip_rect.height, -1);
+
+	  if (!xp_theme_draw (pixmap, XP_THEME_ELEMENT_TAB_ITEM, style,
+			      draw_rect.x - clip_rect.x, draw_rect.y - clip_rect.y,
+			      draw_rect.width, draw_rect.height, state_type, 0))
+	    {
+	      g_object_unref (pixmap);
+	      return FALSE;
+	    }
+
+	  pixbuf = gdk_pixbuf_get_from_drawable (NULL, pixmap, NULL, 0, 0, 0, 0,
+						 clip_rect.width, clip_rect.height);
+	  g_object_unref (pixmap);
+	}
 
       rotated = gdk_pixbuf_rotate_simple (pixbuf, rotation);
       g_object_unref (pixbuf);
@@ -2563,7 +2703,8 @@
       //       while it is active on a bottom-oriented notebook, there is one white
       //       pixel at the top.  There may be a better solution than this if someone
       //       has time to discover it.
-      if (gap_side == GTK_POS_BOTTOM && state_type == GTK_STATE_NORMAL && x == widget->allocation.x)
+      if (gap_side == GTK_POS_BOTTOM && state_type == GTK_STATE_NORMAL
+	  && x == widget->allocation.x)
 	{
 	  int rowstride = gdk_pixbuf_get_rowstride (pixbuf);
 	  int n_channels = gdk_pixbuf_get_n_channels (pixbuf);
@@ -2579,73 +2720,71 @@
 	}
 
       gdk_draw_pixbuf (window, NULL, pixbuf, 0, 0, clip_rect.x, clip_rect.y,
-                       clip_rect.width, clip_rect.height, GDK_RGB_DITHER_NONE, 0, 0);
+		       clip_rect.width, clip_rect.height, GDK_RGB_DITHER_NONE,
+		       0, 0);
       g_object_unref (pixbuf);
     }
-  
+
   return TRUE;
 }
 
 static gboolean
 draw_tab_button (GtkStyle *style,
-                 GdkWindow *window,
-                 GtkStateType state_type,
-                 GtkShadowType shadow_type,
-                 GdkRectangle *area,
-                 GtkWidget *widget,
-                 const gchar *detail,
-                 gint x, gint y,
-                 gint width, gint height,
-                 gint gap_side)
+		 GdkWindow *window,
+		 GtkStateType state_type,
+		 GtkShadowType shadow_type,
+		 GdkRectangle *area,
+		 GtkWidget *widget,
+		 const gchar *detail,
+		 gint x, gint y, gint width, gint height, gint gap_side)
 {
   if (gap_side == GTK_POS_TOP || gap_side == GTK_POS_BOTTOM)
-   {
-     /* experimental tab-drawing code from mozilla */
-     RECT rect;
-     HDC dc;
-     gint32 aPosition;
-
-     dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
-
-     if (gap_side == GTK_POS_TOP)
-       aPosition = BF_TOP;
-     else if (gap_side == GTK_POS_BOTTOM)
-       aPosition = BF_BOTTOM;
-     else if (gap_side == GTK_POS_LEFT)
-       aPosition = BF_LEFT;
-     else
-       aPosition = BF_RIGHT;
-
-     if(state_type == GTK_STATE_PRELIGHT)
-       state_type = GTK_STATE_NORMAL;
-     if (area)
-       gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
-
-     DrawTab (dc, rect, aPosition,
-              state_type != GTK_STATE_PRELIGHT,
-              (gap_side != GTK_POS_LEFT),
-              (gap_side != GTK_POS_RIGHT));
-     if (area)
-       gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
-
-     release_window_dc (style, window, state_type);
-     return TRUE;
-   }
+    {
+      /* experimental tab-drawing code from mozilla */
+      RECT rect;
+      HDC dc;
+      gint32 aPosition;
+
+      dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+
+      if (gap_side == GTK_POS_TOP)
+	aPosition = BF_TOP;
+      else if (gap_side == GTK_POS_BOTTOM)
+	aPosition = BF_BOTTOM;
+      else if (gap_side == GTK_POS_LEFT)
+	aPosition = BF_LEFT;
+      else
+	aPosition = BF_RIGHT;
+
+      if (state_type == GTK_STATE_PRELIGHT)
+	state_type = GTK_STATE_NORMAL;
+      if (area)
+	gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
+
+      DrawTab (dc, rect, aPosition,
+	       state_type != GTK_STATE_PRELIGHT,
+	       (gap_side != GTK_POS_LEFT), (gap_side != GTK_POS_RIGHT));
+
+      if (area)
+	gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
+
+      release_window_dc (style, window, state_type);
+      return TRUE;
+    }
 
   return FALSE;
 }
 
 static void
 draw_extension (GtkStyle *style,
-                GdkWindow *window,
-                GtkStateType state_type,
-                GtkShadowType shadow_type,
-                GdkRectangle *area,
-                GtkWidget *widget,
-                const gchar *detail,
-                gint x, gint y,
-                gint width, gint height,
-                GtkPositionType gap_side)
+		GdkWindow *window,
+		GtkStateType state_type,
+		GtkShadowType shadow_type,
+		GdkRectangle *area,
+		GtkWidget *widget,
+		const gchar *detail,
+		gint x, gint y,
+		gint width, gint height, GtkPositionType gap_side)
 {
   if (widget && GTK_IS_NOTEBOOK (widget) && detail && !strcmp (detail, "tab"))
     {
@@ -2655,588 +2794,665 @@
       int real_gap_side = gtk_notebook_get_tab_pos (notebook);
 
       if (!draw_themed_tab_button (style, window, state_type,
-                                   GTK_NOTEBOOK (widget), x, y,
-                                   width, height, real_gap_side))
-        {
-          if (!draw_tab_button (style, window, state_type,
-                                shadow_type, area, widget,
-                                detail,
-                                x, y, width, height, real_gap_side))
-            {
-              parent_class->draw_extension (style, window, state_type,
-                                            shadow_type, area, widget, detail,
-                                            x, y, width, height, real_gap_side);
-            }
-        }
+				   GTK_NOTEBOOK (widget), x, y,
+				   width, height, real_gap_side))
+	{
+	  if (!draw_tab_button (style, window, state_type,
+				shadow_type, area, widget,
+				detail, x, y, width, height, real_gap_side))
+	    {
+	      parent_class->draw_extension (style, window, state_type,
+					    shadow_type, area, widget, detail,
+					    x, y, width, height,
+					    real_gap_side);
+	    }
+	}
     }
 }
 
 static void
-draw_box_gap (GtkStyle * style, GdkWindow * window, GtkStateType state_type,
-	      GtkShadowType shadow_type, GdkRectangle * area,
-	      GtkWidget * widget, const gchar * detail, gint x,
+draw_box_gap (GtkStyle *style, GdkWindow *window, GtkStateType state_type,
+	      GtkShadowType shadow_type, GdkRectangle *area,
+	      GtkWidget *widget, const gchar *detail, gint x,
 	      gint y, gint width, gint height, GtkPositionType gap_side,
 	      gint gap_x, gint gap_width)
 {
-    if (GTK_IS_NOTEBOOK (widget) && detail && !strcmp (detail, "notebook"))
+  if (GTK_IS_NOTEBOOK (widget) && detail && !strcmp (detail, "notebook"))
+    {
+      GtkNotebook *notebook = GTK_NOTEBOOK (widget);
+      int side = gtk_notebook_get_tab_pos (notebook);
+      int x2 = x, y2 = y, w2 = width, h2 = height;
+
+      if (side == GTK_POS_TOP)
+	{
+	  x2 = x;
+	  y2 = y - notebook->tab_vborder;
+	  w2 = width;
+	  h2 = height + notebook->tab_vborder * 2;
+	}
+      else if (side == GTK_POS_BOTTOM)
+	{
+	  x2 = x;
+	  y2 = y;
+	  w2 = width;
+	  h2 = height + notebook->tab_vborder * 2;
+	}
+      else if (side == GTK_POS_LEFT)
+	{
+	  x2 = x - notebook->tab_hborder;
+	  y2 = y;
+	  w2 = width + notebook->tab_hborder;
+	  h2 = height;
+	}
+      else if (side == GTK_POS_RIGHT)
 	{
-	    GtkNotebook *notebook = GTK_NOTEBOOK (widget);
-	    int side = gtk_notebook_get_tab_pos (notebook);
-	    int x2 = x, y2 = y, w2 = width, h2 = height;
-
-	    if (side == GTK_POS_TOP)
-	      {
-		x2 = x;
-		y2 = y - notebook->tab_vborder;
-		w2 = width;
-		h2 = height + notebook->tab_vborder * 2;
-	      }
-	    else if (side == GTK_POS_BOTTOM)
-	      {
-		x2 = x;
-		y2 = y;
-		w2 = width;
-		h2 = height + notebook->tab_vborder * 2;
-	      }
-	    else if (side == GTK_POS_LEFT)
-	      {
-		x2 = x - notebook->tab_hborder;
-		y2 = y;
-		w2 = width + notebook->tab_hborder;
-		h2 = height;
-	      }
-	    else if (side == GTK_POS_RIGHT)
-	      {
-		x2 = x;
-		y2 = y;
-		w2 = width + notebook->tab_hborder * 2;
-		h2 = height;
-	      }
+	  x2 = x;
+	  y2 = y;
+	  w2 = width + notebook->tab_hborder * 2;
+	  h2 = height;
+	}
 
-	    if (xp_theme_draw (window, XP_THEME_ELEMENT_TAB_PANE, style,
-			       x2, y2, w2, h2, state_type, area))
-		{
-		    return;
-		}
+      if (xp_theme_draw (window, XP_THEME_ELEMENT_TAB_PANE, style,
+			 x2, y2, w2, h2, state_type, area))
+	{
+	  return;
 	}
+    }
 
-    parent_class->draw_box_gap (style, window, state_type, shadow_type,
-				area, widget, detail, x, y, width, height,
-				gap_side, gap_x, gap_width);
-}
-
-static gboolean is_popup_window_child( GtkWidget* widget )
-{
-    GtkWidget* top;
-    GtkWindowType type = -1;
-
-    top = gtk_widget_get_toplevel( widget );
-    if( top && GTK_IS_WINDOW(top) ) {
-        g_object_get(top, "type", &type, NULL );
-        if( type == GTK_WINDOW_POPUP ) { /* Hack for combo boxes */
-            return TRUE;
-        }
+  parent_class->draw_box_gap (style, window, state_type, shadow_type,
+			      area, widget, detail, x, y, width, height,
+			      gap_side, gap_x, gap_width);
+}
+
+static gboolean
+is_popup_window_child (GtkWidget *widget)
+{
+  GtkWidget *top;
+  GtkWindowType type = -1;
+
+  top = gtk_widget_get_toplevel (widget);
+
+  if (top && GTK_IS_WINDOW (top))
+    {
+      g_object_get (top, "type", &type, NULL);
+
+      if (type == GTK_WINDOW_POPUP)
+	{			/* Hack for combo boxes */
+	  return TRUE;
+	}
     }
-    return FALSE;
+
+  return FALSE;
 }
 
 static void
-draw_flat_box (GtkStyle * style, GdkWindow * window,
+draw_flat_box (GtkStyle *style, GdkWindow *window,
 	       GtkStateType state_type, GtkShadowType shadow_type,
-	       GdkRectangle * area, GtkWidget * widget,
-	       const gchar * detail, gint x, gint y, gint width, gint height)
+	       GdkRectangle *area, GtkWidget *widget,
+	       const gchar *detail, gint x, gint y, gint width, gint height)
 {
-    if( detail ) {
-        if ( !strcmp (detail, "checkbutton") )
+  if (detail)
+    {
+      if (!strcmp (detail, "checkbutton"))
 	{
-	    if (state_type == GTK_STATE_PRELIGHT)
-		{
-		    return;
-		}
+	  if (state_type == GTK_STATE_PRELIGHT)
+	    {
+	      return;
+	    }
 	}
     }
 
-    parent_class->draw_flat_box (style, window, state_type, shadow_type,
-				 area, widget, detail, x, y, width, height);
+  parent_class->draw_flat_box (style, window, state_type, shadow_type,
+			       area, widget, detail, x, y, width, height);
 }
 
 static gboolean
-draw_menu_border ( GdkWindow* win, GtkStyle* style, 
-				  gint x, gint y, gint width, gint height )
+draw_menu_border (GdkWindow *win, GtkStyle *style,
+		  gint x, gint y, gint width, gint height)
 {
-    RECT rect;
-    HDC dc;
+  RECT rect;
+  HDC dc;
+
+  dc = get_window_dc (style, win, GTK_STATE_NORMAL, x, y, width, height, &rect);
+
+  if (!dc)
+    return FALSE;
 
-    dc = get_window_dc (style, win, GTK_STATE_NORMAL, x, y, width, height, &rect );
-    if (!dc)
-        return FALSE;
-    if( xp_theme_is_active() ) {
-        FrameRect( dc, &rect, GetSysColorBrush(COLOR_3DSHADOW) );
+  if (xp_theme_is_active ())
+    {
+      FrameRect (dc, &rect, GetSysColorBrush (COLOR_3DSHADOW));
     }
-    else {
-        DrawEdge( dc, &rect, EDGE_RAISED, BF_RECT );
+  else
+    {
+      DrawEdge (dc, &rect, EDGE_RAISED, BF_RECT);
     }
-    release_window_dc( style, win, GTK_STATE_NORMAL );
-    return TRUE;
+
+  release_window_dc (style, win, GTK_STATE_NORMAL);
+
+  return TRUE;
 }
 
 static void
-draw_shadow (GtkStyle * style,
-	     GdkWindow * window,
+draw_shadow (GtkStyle *style,
+	     GdkWindow *window,
 	     GtkStateType state_type,
 	     GtkShadowType shadow_type,
-	     GdkRectangle * area,
-	     GtkWidget * widget,
-	     const gchar * detail, gint x, gint y, gint width, gint height)
-{
-    gboolean is_handlebox;
-    gboolean is_toolbar;
-
-    if( detail && !strcmp( detail, "frame") )
-	{
-        HDC dc;
-        RECT rect;
-        dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-        if( is_popup_window_child(widget) ) {
-            FrameRect( dc, &rect, GetSysColorBrush( COLOR_WINDOWFRAME ) );
-        }
-        else{
-            switch( shadow_type ){
-            case GTK_SHADOW_IN:
-                draw_3d_border(dc, &rect, TRUE);
-                break;
-            case GTK_SHADOW_OUT:
-                draw_3d_border(dc, &rect, FALSE);
-                break;
-            case GTK_SHADOW_ETCHED_IN:
-                draw_3d_border(dc, &rect, TRUE);
-                InflateRect( &rect, -1, -1 );
-                draw_3d_border(dc, &rect, FALSE);
-                break;
-            case GTK_SHADOW_ETCHED_OUT:
-                draw_3d_border(dc, &rect, FALSE);
-                InflateRect( &rect, -1, -1 );
-                draw_3d_border(dc, &rect, TRUE);
-                break;
-            case GTK_SHADOW_NONE:
-                break;
-            }
-        }
-        release_window_dc( style, window, state_type );
-        return;
-    }
-    if (detail && (!strcmp (detail, "entry") || !strcmp (detail, "combobox")) )
-	{
-            if( shadow_type != GTK_SHADOW_IN )
-	    	return;
-
-	    if ( !xp_theme_draw (window, XP_THEME_ELEMENT_EDIT_TEXT, style,
-				 x, y, width, height, state_type, area))
-	    {
-		HDC dc;
-		RECT rect;
-
-		dc = get_window_dc (style, window, state_type, 
-				    x, y, width, height, &rect);
-		DrawEdge (dc, &rect, EDGE_SUNKEN, BF_RECT);
-		release_window_dc (style, window, state_type);
-	    }
-
-	    return;
-	}
-
-    if (detail && !strcmp (detail, "scrolled_window") &&
-        xp_theme_draw (window, XP_THEME_ELEMENT_EDIT_TEXT, style,
-                       x, y, width, height, state_type, area))
-        return;
-
-    if (detail && !strcmp (detail, "spinbutton"))
-        return;
-
-    if (detail && !strcmp (detail, "menu"))
-			{
-	    if ( draw_menu_border ( window, style, x, y, width, height ) ) {
-		    return;
-			}
-		}
+	     GdkRectangle *area,
+	     GtkWidget *widget,
+	     const gchar *detail, gint x, gint y, gint width, gint height)
+{
+  gboolean is_handlebox;
+  gboolean is_toolbar;
+
+  if (detail && !strcmp (detail, "frame"))
+    {
+      HDC dc;
+      RECT rect;
+      dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+
+      if (is_popup_window_child (widget))
+	{
+	  FrameRect (dc, &rect, GetSysColorBrush (COLOR_WINDOWFRAME));
+	}
+      else
+	{
+	  switch (shadow_type)
+	    {
+	    case GTK_SHADOW_IN:
+	      draw_3d_border (dc, &rect, TRUE);
+	      break;
+
+	    case GTK_SHADOW_OUT:
+	      draw_3d_border (dc, &rect, FALSE);
+	      break;
+
+	    case GTK_SHADOW_ETCHED_IN:
+	      draw_3d_border (dc, &rect, TRUE);
+	      InflateRect (&rect, -1, -1);
+	      draw_3d_border (dc, &rect, FALSE);
+	      break;
+
+	    case GTK_SHADOW_ETCHED_OUT:
+	      draw_3d_border (dc, &rect, FALSE);
+	      InflateRect (&rect, -1, -1);
+	      draw_3d_border (dc, &rect, TRUE);
+	      break;
+
+	    case GTK_SHADOW_NONE:
+	      break;
+	    }
+	}
+
+      release_window_dc (style, window, state_type);
+
+      return;
+    }
+  if (detail && (!strcmp (detail, "entry") || !strcmp (detail, "combobox")))
+    {
+      if (shadow_type != GTK_SHADOW_IN)
+	return;
+
+      if (!xp_theme_draw (window, XP_THEME_ELEMENT_EDIT_TEXT, style,
+			  x, y, width, height, state_type, area))
+	{
+	  HDC dc;
+	  RECT rect;
+
+	  dc = get_window_dc (style, window, state_type,
+			      x, y, width, height, &rect);
+
+	  DrawEdge (dc, &rect, EDGE_SUNKEN, BF_RECT);
+	  release_window_dc (style, window, state_type);
+	}
+
+      return;
+    }
+
+  if (detail && !strcmp (detail, "scrolled_window") &&
+      xp_theme_draw (window, XP_THEME_ELEMENT_EDIT_TEXT, style,
+		     x, y, width, height, state_type, area))
+    {
+      return;
+    }
+
+  if (detail && !strcmp (detail, "spinbutton"))
+    return;
+
+  if (detail && !strcmp (detail, "menu"))
+    {
+      if (draw_menu_border (window, style, x, y, width, height))
+	{
+	  return;
+	}
+    }
+
+  if (detail && !strcmp (detail, "handlebox"))
+    return;
 
-    if (detail && !strcmp (detail, "handlebox"))
-        return;
+  is_handlebox = (detail && !strcmp (detail, "handlebox_bin"));
+  is_toolbar = (detail
+		&& (!strcmp (detail, "toolbar")
+		    || !strcmp (detail, "menubar")));
 
-    is_handlebox = (detail && !strcmp (detail, "handlebox_bin"));
-    is_toolbar = (detail && (!strcmp (detail, "toolbar") || !strcmp(detail, "menubar")));
+  if (is_toolbar || is_handlebox)
+    {
+      if (shadow_type == GTK_SHADOW_NONE)
+	{
+	  return;
+	}
+
+      if (widget)
+	{
+	  HDC dc;
+	  RECT rect;
+	  HGDIOBJ old_pen = NULL;
+	  GtkPositionType pos;
+
+	  sanitize_size (window, &width, &height);
 
-    if ( is_toolbar || is_handlebox )
-				{
-        if( shadow_type == GTK_SHADOW_NONE )
-	    return;
-
-        if( widget ) {
-            HDC dc;
-            RECT rect;
-            HGDIOBJ old_pen = NULL;
-            GtkPositionType pos;
-
-            sanitize_size (window, &width, &height);
-
-            if( is_handlebox ) {
-                pos = gtk_handle_box_get_handle_position(GTK_HANDLE_BOX(widget));
-                /*
-                    If the handle box is at left side, 
-                    we shouldn't draw its right border.
-                    The same holds true for top, right, and bottom.
-                */
-                switch( pos ) {
-                case GTK_POS_LEFT:
-                    pos = GTK_POS_RIGHT;    break;
-                case GTK_POS_RIGHT:
-                    pos = GTK_POS_LEFT;     break;
-                case GTK_POS_TOP:
-                    pos = GTK_POS_BOTTOM;   break;
-                case GTK_POS_BOTTOM:
-                    pos = GTK_POS_TOP;      break;
-				}
-			}
-            else {
-                GtkWidget* parent = gtk_widget_get_parent(widget);
-                /* Dirty hack for toolbars contained in handle boxes */
-                if( GTK_IS_HANDLE_BOX( parent ) ) {
-                    pos = gtk_handle_box_get_handle_position( GTK_HANDLE_BOX( parent ) );
-			}
-                else {
-                    /*
-                        Dirty hack:
-                        Make pos != all legal enum vaules of GtkPositionType.
-                        So every border will be draw.
-                    */
-                    pos = (GtkPositionType)-1;
+	  if (is_handlebox)
+	    {
+	      pos = gtk_handle_box_get_handle_position (GTK_HANDLE_BOX (widget));
+	      /*
+	         If the handle box is at left side, 
+	         we shouldn't draw its right border.
+	         The same holds true for top, right, and bottom.
+	       */
+	      switch (pos)
+		{
+		case GTK_POS_LEFT:
+		  pos = GTK_POS_RIGHT;
+		  break;
+
+		case GTK_POS_RIGHT:
+		  pos = GTK_POS_LEFT;
+		  break;
+
+		case GTK_POS_TOP:
+		  pos = GTK_POS_BOTTOM;
+		  break;
+
+		case GTK_POS_BOTTOM:
+		  pos = GTK_POS_TOP;
+		  break;
 		}
-				}
+	    }
+	  else
+	    {
+	      GtkWidget *parent = gtk_widget_get_parent (widget);
 
-            dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-            if( pos != GTK_POS_LEFT ) {
-                old_pen = SelectObject( dc, get_light_pen() );
-                MoveToEx( dc, rect.left, rect.top, NULL );
-                LineTo( dc, rect.left, rect.bottom );
-				}
-            if( pos != GTK_POS_TOP ) {
-                old_pen = SelectObject( dc, get_light_pen() );
-                MoveToEx( dc, rect.left, rect.top, NULL );
-                LineTo( dc, rect.right, rect.top );
-			}
-            if( pos != GTK_POS_RIGHT ) {
-                old_pen = SelectObject( dc, get_dark_pen() );
-                MoveToEx( dc, rect.right-1, rect.top, NULL );
-                LineTo( dc, rect.right-1, rect.bottom );
-			}
-            if( pos != GTK_POS_BOTTOM ) {
-                old_pen = SelectObject( dc, get_dark_pen() );
-                MoveToEx( dc, rect.left, rect.bottom-1, NULL );
-                LineTo( dc, rect.right, rect.bottom-1 );
+	      /* Dirty hack for toolbars contained in handle boxes */
+	      if (GTK_IS_HANDLE_BOX (parent))
+		{
+		  pos = gtk_handle_box_get_handle_position (GTK_HANDLE_BOX (parent));
 		}
-            if (old_pen)
-                SelectObject( dc, old_pen );
-            release_window_dc( style, window, state_type );
-			}
-        return;
+	      else
+		{
+		  /*
+		     Dirty hack:
+		     Make pos != all legal enum vaules of GtkPositionType.
+		     So every border will be draw.
+		   */
+		  pos = (GtkPositionType) - 1;
 		}
+	    }
 
-    if (detail && !strcmp (detail, "statusbar")) {
-	    return;
+	  dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+
+	  if (pos != GTK_POS_LEFT)
+	    {
+	      old_pen = SelectObject (dc, get_light_pen ());
+	      MoveToEx (dc, rect.left, rect.top, NULL);
+	      LineTo (dc, rect.left, rect.bottom);
+	    }
+	  if (pos != GTK_POS_TOP)
+	    {
+	      old_pen = SelectObject (dc, get_light_pen ());
+	      MoveToEx (dc, rect.left, rect.top, NULL);
+	      LineTo (dc, rect.right, rect.top);
+	    }
+	  if (pos != GTK_POS_RIGHT)
+	    {
+	      old_pen = SelectObject (dc, get_dark_pen ());
+	      MoveToEx (dc, rect.right - 1, rect.top, NULL);
+	      LineTo (dc, rect.right - 1, rect.bottom);
+	    }
+	  if (pos != GTK_POS_BOTTOM)
+	    {
+	      old_pen = SelectObject (dc, get_dark_pen ());
+	      MoveToEx (dc, rect.left, rect.bottom - 1, NULL);
+	      LineTo (dc, rect.right, rect.bottom - 1);
+	    }
+	  if (old_pen)
+	    SelectObject (dc, old_pen);
+	  release_window_dc (style, window, state_type);
 	}
 
-    parent_class->draw_shadow (style, window, state_type, shadow_type, area,
-			       widget, detail, x, y, width, height);
+      return;
+    }
+
+  if (detail && !strcmp (detail, "statusbar"))
+    {
+      return;
+    }
+
+  parent_class->draw_shadow (style, window, state_type, shadow_type, area,
+			     widget, detail, x, y, width, height);
 }
 
 static void
-draw_hline (GtkStyle * style,
-	    GdkWindow * window,
+draw_hline (GtkStyle *style,
+	    GdkWindow *window,
 	    GtkStateType state_type,
-	    GdkRectangle * area,
-	    GtkWidget * widget,
-	    const gchar * detail, gint x1, gint x2, gint y)
-{
-  if (xp_theme_is_active () && detail && !strcmp(detail, "menuitem")) {
-	if(xp_theme_draw (window, XP_THEME_ELEMENT_MENU_SEPARATOR, style, x1, y, x2, 1, state_type, area))
-		return;
-	else {
-	    if (area)
+	    GdkRectangle *area,
+	    GtkWidget *widget,
+	    const gchar *detail, gint x1, gint x2, gint y)
+{
+  if (xp_theme_is_active () && detail && !strcmp (detail, "menuitem"))
+    {
+      if (xp_theme_draw
+	  (window, XP_THEME_ELEMENT_MENU_SEPARATOR, style, x1, y, x2, 1,
+	   state_type, area))
+	{
+	  return;
+	}
+      else
+	{
+	  if (area)
+	    {
+	      gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
+	    }
+
+	  gdk_draw_line (window, style->dark_gc[state_type], x1, y, x2, y);
+
+	  if (area)
+	    {
+	      gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
+	    }
+	}
+    }
+  else
+    {
+      if (style->ythickness == 2)
+	{
+	  if (area)
+	    {
 	      gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
+	      gdk_gc_set_clip_rectangle (style->light_gc[state_type], area);
+	    }
 
-	    gdk_draw_line (window, style->dark_gc[state_type], x1, y, x2, y);
+	  gdk_draw_line (window, style->dark_gc[state_type], x1, y, x2, y);
+	  ++y;
+	  gdk_draw_line (window, style->light_gc[state_type], x1, y, x2, y);
 
-	    if (area)
+	  if (area)
+	    {
 	      gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
+	      gdk_gc_set_clip_rectangle (style->light_gc[state_type], NULL);
+	    }
+	}
+      else
+	{
+	  parent_class->draw_hline (style, window, state_type, area, widget,
+				    detail, x1, x2, y);
 	}
-  } else {
-      if( style->ythickness == 2 )
-      {
-        if (area)
-        {
-          gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
-          gdk_gc_set_clip_rectangle (style->light_gc[state_type], area);
-        }
-        gdk_draw_line (window, style->dark_gc[state_type], x1, y, x2, y);
-        ++y;
-        gdk_draw_line (window, style->light_gc[state_type], x1, y, x2, y);
-        if (area)
-        {
-          gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
-          gdk_gc_set_clip_rectangle (style->light_gc[state_type], NULL);
-        }
-      }
-      else
-      {
-    parent_class->draw_hline (style, window, state_type, area, widget,
-			      detail, x1, x2, y);
-  }
-  }
+    }
 }
 
 static void
-draw_vline (GtkStyle * style,
-	    GdkWindow * window,
+draw_vline (GtkStyle *style,
+	    GdkWindow *window,
 	    GtkStateType state_type,
-	    GdkRectangle * area,
-	    GtkWidget * widget,
-	    const gchar * detail, gint y1, gint y2, gint x)
+	    GdkRectangle *area,
+	    GtkWidget *widget,
+	    const gchar *detail, gint y1, gint y2, gint x)
 {
-  if( style->xthickness == 2 )
-  {
-    if (area)
+  if (style->xthickness == 2)
     {
-      gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
-      gdk_gc_set_clip_rectangle (style->light_gc[state_type], area);
+      if (area)
+	{
+	  gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
+	  gdk_gc_set_clip_rectangle (style->light_gc[state_type], area);
+	}
+
+      gdk_draw_line (window, style->dark_gc[state_type], x, y1, x, y2);
+      ++x;
+      gdk_draw_line (window, style->light_gc[state_type], x, y1, x, y2);
+
+      if (area)
+	{
+	  gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
+	  gdk_gc_set_clip_rectangle (style->light_gc[state_type], NULL);
+	}
     }
-    gdk_draw_line (window, style->dark_gc[state_type], x, y1, x, y2);
-    ++x;
-    gdk_draw_line (window, style->light_gc[state_type], x, y1, x, y2);
-    if (area)
+  else
     {
-      gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
-      gdk_gc_set_clip_rectangle (style->light_gc[state_type], NULL);
+      parent_class->draw_vline (style, window, state_type, area, widget,
+				detail, y1, y2, x);
     }
-  }
-  else
-  {
-    parent_class->draw_vline (style, window, state_type, area, widget,
-			      detail, y1, y2, x);
-  }
 }
 
 static void
-draw_slider (GtkStyle * style,
-	     GdkWindow * window,
+draw_slider (GtkStyle *style,
+	     GdkWindow *window,
 	     GtkStateType state_type,
 	     GtkShadowType shadow_type,
-	     GdkRectangle * area,
-	     GtkWidget * widget,
-	     const gchar * detail,
+	     GdkRectangle *area,
+	     GtkWidget *widget,
+	     const gchar *detail,
 	     gint x,
 	     gint y, gint width, gint height, GtkOrientation orientation)
 {
-    if (GTK_IS_SCALE (widget) &&
-	xp_theme_draw (window,
-		       ((orientation ==
-			 GTK_ORIENTATION_VERTICAL) ?
-			XP_THEME_ELEMENT_SCALE_SLIDER_V :
-			XP_THEME_ELEMENT_SCALE_SLIDER_H), style, x, y, width,
-		       height, state_type, area))
-	{
-	    return;
-	}
+  if (GTK_IS_SCALE (widget) &&
+      xp_theme_draw (window, ((orientation == GTK_ORIENTATION_VERTICAL) ?
+			      XP_THEME_ELEMENT_SCALE_SLIDER_V :
+			      XP_THEME_ELEMENT_SCALE_SLIDER_H), style, x, y, width,
+		     height, state_type, area))
+    {
+      return;
+    }
 
-    parent_class->draw_slider (style, window, state_type, shadow_type, area,
-			       widget, detail, x, y, width, height,
-			       orientation);
+  parent_class->draw_slider (style, window, state_type, shadow_type, area,
+			     widget, detail, x, y, width, height,
+			     orientation);
 }
 
 static void
-draw_resize_grip (GtkStyle * style,
-		  GdkWindow * window,
+draw_resize_grip (GtkStyle *style,
+		  GdkWindow *window,
 		  GtkStateType state_type,
-		  GdkRectangle * area,
-		  GtkWidget * widget,
-		  const gchar * detail,
+		  GdkRectangle *area,
+		  GtkWidget *widget,
+		  const gchar *detail,
 		  GdkWindowEdge edge, gint x, gint y, gint width, gint height)
 {
-    if (detail && !strcmp (detail, "statusbar"))
+  if (detail && !strcmp (detail, "statusbar"))
+    {
+      if (xp_theme_draw
+	  (window, XP_THEME_ELEMENT_STATUS_GRIPPER, style, x, y, width,
+	   height, state_type, area))
 	{
-	    if (xp_theme_draw
-		(window, XP_THEME_ELEMENT_STATUS_GRIPPER, style, x, y, width,
-		 height, state_type, area))
-			return;
-		else {
-			RECT rect;
-			HDC dc = get_window_dc(style, window, state_type, x, y, width, height, &rect);
-
-			if (area)
-				gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
-			DrawFrameControl(dc, &rect, DFC_SCROLL, DFCS_SCROLLSIZEGRIP);
-			release_window_dc(style, window, state_type);
-			if (area)
-				gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
-			return;
-		}
+	  return;
+	}
+      else
+	{
+	  RECT rect;
+	  HDC dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+
+	  if (area)
+	    gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
+
+	  DrawFrameControl (dc, &rect, DFC_SCROLL, DFCS_SCROLLSIZEGRIP);
+	  release_window_dc (style, window, state_type);
+
+	  if (area)
+	    gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
+
+	  return;
 	}
+    }
 
-    parent_class->draw_resize_grip (style, window, state_type, area,
-				    widget, detail, edge, x, y, width,
-				    height);
+  parent_class->draw_resize_grip (style, window, state_type, area,
+				  widget, detail, edge, x, y, width, height);
 }
 
 static void
-draw_handle (GtkStyle * style,
-	     GdkWindow * window,
+draw_handle (GtkStyle *style,
+	     GdkWindow *window,
 	     GtkStateType state_type,
 	     GtkShadowType shadow_type,
-	     GdkRectangle * area,
-	     GtkWidget * widget,
-	     const gchar * detail,
+	     GdkRectangle *area,
+	     GtkWidget *widget,
+	     const gchar *detail,
 	     gint x,
 	     gint y, gint width, gint height, GtkOrientation orientation)
 {
-    HDC dc;
-    RECT rect;
+  HDC dc;
+  RECT rect;
+
+  if (is_toolbar_child (widget))
+    {
+      XpThemeElement hndl;
+
+      sanitize_size (window, &width, &height);
 
-    if (is_toolbar_child (widget))
+      if (GTK_IS_HANDLE_BOX (widget))
 	{
-	    XpThemeElement hndl;
+	  GtkPositionType pos;
+	  pos = gtk_handle_box_get_handle_position (GTK_HANDLE_BOX (widget));
 
-	    sanitize_size (window, &width, &height);
+	  if (pos == GTK_POS_TOP || pos == GTK_POS_BOTTOM)
+	    {
+	      orientation = GTK_ORIENTATION_HORIZONTAL;
+	    }
+	  else
+	    {
+	      orientation = GTK_ORIENTATION_VERTICAL;
+	    }
+	}
 
-            if( GTK_IS_HANDLE_BOX(widget) ) {
-                GtkPositionType pos;
-                pos = gtk_handle_box_get_handle_position(GTK_HANDLE_BOX(widget));
-                if( pos == GTK_POS_TOP || pos == GTK_POS_BOTTOM ) {
-                    orientation = GTK_ORIENTATION_HORIZONTAL;
-                }
-                else {
-                    orientation = GTK_ORIENTATION_VERTICAL;
-                }
-            }
-
-            if ( orientation == GTK_ORIENTATION_VERTICAL )
-		hndl = XP_THEME_ELEMENT_REBAR_GRIPPER_V;
-	    else
-		hndl = XP_THEME_ELEMENT_REBAR_GRIPPER_H;
+      if (orientation == GTK_ORIENTATION_VERTICAL)
+	hndl = XP_THEME_ELEMENT_REBAR_GRIPPER_V;
+      else
+	hndl = XP_THEME_ELEMENT_REBAR_GRIPPER_H;
 
-	    if (xp_theme_draw (window, hndl, style, x, y, width, height,
-			       state_type, area))
-		{
-		    return;
-		}
+      if (xp_theme_draw (window, hndl, style, x, y, width, height,
+			 state_type, area))
+	{
+	  return;
+	}
 
-            dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-	    if ( orientation == GTK_ORIENTATION_VERTICAL ) {
-                rect.left += 3;
-                rect.right = rect.left + 3;
-                rect.bottom -= 3;
-                rect.top += 3;
-            }
-            else{
-                rect.top += 3;
-                rect.bottom = rect.top + 3;
-                rect.right -= 3;
-                rect.left += 3;
-            }
-            draw_3d_border( dc, &rect, FALSE );
-            release_window_dc( style, window, state_type );
-            return;
-	}
-
-    if (!GTK_IS_PANED (widget))
-	{
-	    gint xthick, ythick;
-	    GdkGC *light_gc, *dark_gc, *shadow_gc;
-	    GdkRectangle dest;
-
-	    sanitize_size (window, &width, &height);
-
-	    gtk_paint_box (style, window, state_type, shadow_type, area,
-			   widget, detail, x, y, width, height);
-
-	    light_gc = style->light_gc[state_type];
-	    dark_gc = style->dark_gc[state_type];
-	    shadow_gc = style->mid_gc[state_type];
-
-	    xthick = style->xthickness;
-	    ythick = style->ythickness;
-
-	    dest.x = x + xthick;
-	    dest.y = y + ythick;
-	    dest.width = width - (xthick * 2);
-	    dest.height = height - (ythick * 2);
-
-	    if (dest.width < dest.height)
-		dest.x += 2;
-	    else
-		dest.y += 2;
-
-	    gdk_gc_set_clip_rectangle (light_gc, &dest);
-	    gdk_gc_set_clip_rectangle (dark_gc, &dest);
-	    gdk_gc_set_clip_rectangle (shadow_gc, &dest);
+      dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
 
-	    if (dest.width < dest.height)
-		{
-		    gdk_draw_line (window, light_gc, dest.x, dest.y, dest.x,
-				   dest.height);
-		    gdk_draw_line (window, dark_gc, dest.x + (dest.width / 2),
-				   dest.y, dest.x + (dest.width / 2),
-				   dest.height);
-		    gdk_draw_line (window, shadow_gc, dest.x + dest.width,
-				   dest.y, dest.x + dest.width, dest.height);
-		}
-	    else
-		{
-		    gdk_draw_line (window, light_gc, dest.x, dest.y,
-				   dest.x + dest.width, dest.y);
-		    gdk_draw_line (window, dark_gc, dest.x,
-				   dest.y + (dest.height / 2),
-				   dest.x + dest.width,
-				   dest.y + (dest.height / 2));
-		    gdk_draw_line (window, shadow_gc, dest.x,
-				   dest.y + dest.height, dest.x + dest.width,
-				   dest.y + dest.height);
-		}
+      if (orientation == GTK_ORIENTATION_VERTICAL)
+	{
+	  rect.left += 3;
+	  rect.right = rect.left + 3;
+	  rect.bottom -= 3;
+	  rect.top += 3;
+	}
+      else
+	{
+	  rect.top += 3;
+	  rect.bottom = rect.top + 3;
+	  rect.right -= 3;
+	  rect.left += 3;
+	}
+
+      draw_3d_border (dc, &rect, FALSE);
+      release_window_dc (style, window, state_type);
+      return;
+    }
+
+  if (!GTK_IS_PANED (widget))
+    {
+      gint xthick, ythick;
+      GdkGC *light_gc, *dark_gc, *shadow_gc;
+      GdkRectangle dest;
+
+      sanitize_size (window, &width, &height);
+
+      gtk_paint_box (style, window, state_type, shadow_type, area,
+		     widget, detail, x, y, width, height);
 
-	    gdk_gc_set_clip_rectangle (shadow_gc, NULL);
-	    gdk_gc_set_clip_rectangle (light_gc, NULL);
-	    gdk_gc_set_clip_rectangle (dark_gc, NULL);
+      light_gc = style->light_gc[state_type];
+      dark_gc = style->dark_gc[state_type];
+      shadow_gc = style->mid_gc[state_type];
+
+      xthick = style->xthickness;
+      ythick = style->ythickness;
+
+      dest.x = x + xthick;
+      dest.y = y + ythick;
+      dest.width = width - (xthick * 2);
+      dest.height = height - (ythick * 2);
+
+      if (dest.width < dest.height)
+	dest.x += 2;
+      else
+	dest.y += 2;
+
+      gdk_gc_set_clip_rectangle (light_gc, &dest);
+      gdk_gc_set_clip_rectangle (dark_gc, &dest);
+      gdk_gc_set_clip_rectangle (shadow_gc, &dest);
+
+      if (dest.width < dest.height)
+	{
+	  gdk_draw_line (window, light_gc, dest.x, dest.y, dest.x,
+			 dest.height);
+	  gdk_draw_line (window, dark_gc, dest.x + (dest.width / 2),
+			 dest.y, dest.x + (dest.width / 2), dest.height);
+	  gdk_draw_line (window, shadow_gc, dest.x + dest.width,
+			 dest.y, dest.x + dest.width, dest.height);
+	}
+      else
+	{
+	  gdk_draw_line (window, light_gc, dest.x, dest.y,
+			 dest.x + dest.width, dest.y);
+	  gdk_draw_line (window, dark_gc, dest.x,
+			 dest.y + (dest.height / 2),
+			 dest.x + dest.width, dest.y + (dest.height / 2));
+	  gdk_draw_line (window, shadow_gc, dest.x,
+			 dest.y + dest.height, dest.x + dest.width,
+			 dest.y + dest.height);
 	}
+
+      gdk_gc_set_clip_rectangle (shadow_gc, NULL);
+      gdk_gc_set_clip_rectangle (light_gc, NULL);
+      gdk_gc_set_clip_rectangle (dark_gc, NULL);
+    }
 }
 
 static void
-draw_focus ( GtkStyle      *style,
-             GdkWindow     *window,
-             GtkStateType   state_type,
-             GdkRectangle  *area,
-             GtkWidget     *widget,
-             const gchar   *detail,
-             gint           x,
-             gint           y,
-             gint           width,
-             gint           height)
+draw_focus (GtkStyle *style,
+	    GdkWindow *window,
+	    GtkStateType state_type,
+	    GdkRectangle *area,
+	    GtkWidget *widget,
+	    const gchar *detail, gint x, gint y, gint width, gint height)
 {
-    HDC dc;
-    RECT rect;
-    if( !GTK_WIDGET_CAN_FOCUS(widget) ) {
-        return;
+  HDC dc;
+  RECT rect;
+
+  if (!GTK_WIDGET_CAN_FOCUS (widget))
+    {
+      return;
     }
 
-    if ( is_combo_box_child(widget) 
-        && (GTK_IS_ARROW(widget) || GTK_IS_BUTTON(widget)) ) {
-        return;
+  if (is_combo_box_child (widget)
+      && (GTK_IS_ARROW (widget) || GTK_IS_BUTTON (widget)))
+    {
+      return;
     }
-    if (GTK_IS_TREE_VIEW (widget->parent) /* list view bheader */
-        || GTK_IS_CLIST (widget->parent)) {
-        return;
+  if (GTK_IS_TREE_VIEW (widget->parent)	/* list view bheader */
+      || GTK_IS_CLIST (widget->parent))
+    {
+      return;
     }
 
-    dc = get_window_dc( style, window, state_type, x, y, width, height, &rect );
-    DrawFocusRect(dc, &rect);
-    release_window_dc( style, window, state_type );
+  dc = get_window_dc (style, window, state_type, x, y, width, height, &rect);
+  DrawFocusRect (dc, &rect);
+  release_window_dc (style, window, state_type);
 /*
     parent_class->draw_focus (style, window, state_type,
 						     area, widget, detail, x, y, width, height);
@@ -3244,73 +3460,70 @@
 }
 
 static void
-draw_layout (GtkStyle        *style,
-	     GdkWindow       *window,
-	     GtkStateType     state_type,
-	     gboolean         use_text,
-	     GdkRectangle    *area,
-	     GtkWidget       *widget,
-	     const gchar     *detail,
-	     gint             old_x,
-	     gint             old_y,
-	     PangoLayout     *layout)
-{
-    GtkNotebook *notebook = NULL;
-    gint x = old_x;
-    gint y = old_y;
-
-    /* In the XP theme, labels don't appear correctly centered inside
-     * notebook tabs, so we give them a gentle nudge two pixels to the
-     * right.  A little hackish, but what are 'ya gonna do?  -- Cody
-     */
-    if (xp_theme_is_active () && detail && !strcmp (detail, "label"))
-      {
-	if (widget->parent != NULL)
-	  {
-	    if (GTK_IS_NOTEBOOK (widget->parent))
-	      {
-		notebook = GTK_NOTEBOOK (widget->parent);
-		int side = gtk_notebook_get_tab_pos (notebook);
-
-		if (side == GTK_POS_TOP || side == GTK_POS_BOTTOM)
-		  {
-		    x += 2;
-		  }
-	      }
-	  }
-      }
-
-    parent_class->draw_layout (style, window, state_type,
-			       use_text, area, widget,
-			       detail, x, y, layout);
+draw_layout (GtkStyle *style,
+	     GdkWindow *window,
+	     GtkStateType state_type,
+	     gboolean use_text,
+	     GdkRectangle *area,
+	     GtkWidget *widget,
+	     const gchar *detail,
+	     gint old_x, gint old_y, PangoLayout *layout)
+{
+  GtkNotebook *notebook = NULL;
+  gint x = old_x;
+  gint y = old_y;
+
+  /* In the XP theme, labels don't appear correctly centered inside
+   * notebook tabs, so we give them a gentle nudge two pixels to the
+   * right.  A little hackish, but what are 'ya gonna do?  -- Cody
+   */
+  if (xp_theme_is_active () && detail && !strcmp (detail, "label"))
+    {
+      if (widget->parent != NULL)
+	{
+	  if (GTK_IS_NOTEBOOK (widget->parent))
+	    {
+	      notebook = GTK_NOTEBOOK (widget->parent);
+	      int side = gtk_notebook_get_tab_pos (notebook);
+
+	      if (side == GTK_POS_TOP || side == GTK_POS_BOTTOM)
+		{
+		  x += 2;
+		}
+	    }
+	}
+    }
+
+  parent_class->draw_layout (style, window, state_type,
+			     use_text, area, widget, detail, x, y, layout);
 }
 
 static void
-msw_style_init_from_rc (GtkStyle * style, GtkRcStyle * rc_style)
-{
-    setup_system_font (style);
-    setup_menu_settings (gtk_settings_get_default ());
-    setup_system_styles (style);
-    parent_class->init_from_rc (style, rc_style);
+msw_style_init_from_rc (GtkStyle *style, GtkRcStyle *rc_style)
+{
+  setup_system_font (style);
+  setup_menu_settings (gtk_settings_get_default ());
+  setup_system_styles (style);
+  parent_class->init_from_rc (style, rc_style);
 }
 
 static GdkPixmap *
 load_bg_image (GdkColormap *colormap,
-	       GdkColor    *bg_color,
-	       const gchar *filename)
+	       GdkColor *bg_color, const gchar *filename)
 {
   if (strcmp (filename, "<parent>") == 0)
-    return (GdkPixmap*) GDK_PARENT_RELATIVE;
+    {
+      return (GdkPixmap *) GDK_PARENT_RELATIVE;
+    }
   else
     {
       return gdk_pixmap_colormap_create_from_xpm (NULL, colormap, NULL,
-						  bg_color,
-						  filename);
+						  bg_color, filename);
     }
 }
 
 static void
-msw_style_realize (GtkStyle * style)
+msw_style_realize (GtkStyle *style)
 {
   GdkGCValues gc_values;
   GdkGCValuesMask gc_values_mask;
@@ -3320,12 +3533,15 @@
   for (i = 0; i < 5; i++)
     {
       style->mid[i].red = (style->light[i].red + style->dark[i].red) / 2;
-      style->mid[i].green = (style->light[i].green + style->dark[i].green) / 2;
+      style->mid[i].green =
+	(style->light[i].green + style->dark[i].green) / 2;
       style->mid[i].blue = (style->light[i].blue + style->dark[i].blue) / 2;
 
       style->text_aa[i].red = (style->text[i].red + style->base[i].red) / 2;
-      style->text_aa[i].green = (style->text[i].green + style->base[i].green) / 2;
-      style->text_aa[i].blue = (style->text[i].blue + style->base[i].blue) / 2;
+      style->text_aa[i].green =
+	(style->text[i].green + style->base[i].green) / 2;
+      style->text_aa[i].blue =
+	(style->text[i].blue + style->base[i].blue) / 2;
     }
 
   style->black.red = 0x0000;
@@ -3342,45 +3558,79 @@
 
   gc_values.foreground = style->black;
   gc_values.background = style->white;
-  style->black_gc = gtk_gc_get (style->depth, style->colormap, &gc_values, gc_values_mask);
+  style->black_gc =
+    gtk_gc_get (style->depth, style->colormap, &gc_values, gc_values_mask);
 
   gc_values.foreground = style->white;
   gc_values.background = style->black;
-  style->white_gc = gtk_gc_get (style->depth, style->colormap, &gc_values, gc_values_mask);
+  style->white_gc =
+    gtk_gc_get (style->depth, style->colormap, &gc_values, gc_values_mask);
 
   gc_values_mask = GDK_GC_FOREGROUND;
 
   for (i = 0; i < 5; i++)
     {
       if (style->rc_style && style->rc_style->bg_pixmap_name[i])
-	style->bg_pixmap[i] = load_bg_image (style->colormap,
-					     &style->bg[i],
-					     style->rc_style->bg_pixmap_name[i]);
+	{
+	  style->bg_pixmap[i] = load_bg_image (style->colormap,
+					       &style->bg[i],
+					       style->rc_style->
+					       bg_pixmap_name[i]);
+	}
 
       if (!gdk_colormap_alloc_color (style->colormap, &style->fg[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->fg[i].red, style->fg[i].green, style->fg[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )", style->fg[i].red,
+		     style->fg[i].green, style->fg[i].blue);
+	}
+
       if (!gdk_colormap_alloc_color (style->colormap, &style->bg[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->bg[i].red, style->bg[i].green, style->bg[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )", style->bg[i].red,
+		     style->bg[i].green, style->bg[i].blue);
+	}
+
       if (!gdk_colormap_alloc_color (style->colormap, &style->light[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->light[i].red, style->light[i].green, style->light[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )",
+		     style->light[i].red, style->light[i].green,
+		     style->light[i].blue);
+	}
+
       if (!gdk_colormap_alloc_color (style->colormap, &style->dark[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->dark[i].red, style->dark[i].green, style->dark[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )",
+		     style->dark[i].red, style->dark[i].green,
+		     style->dark[i].blue);
+	}
+
       if (!gdk_colormap_alloc_color (style->colormap, &style->mid[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->mid[i].red, style->mid[i].green, style->mid[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )",
+		     style->mid[i].red, style->mid[i].green,
+		     style->mid[i].blue);
+	}
+
       if (!gdk_colormap_alloc_color (style->colormap, &style->text[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->text[i].red, style->text[i].green, style->text[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )",
+		     style->text[i].red, style->text[i].green,
+		     style->text[i].blue);
+	}
+
       if (!gdk_colormap_alloc_color (style->colormap, &style->base[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->base[i].red, style->base[i].green, style->base[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )",
+		     style->base[i].red, style->base[i].green,
+		     style->base[i].blue);
+	}
+
       if (!gdk_colormap_alloc_color (style->colormap, &style->text_aa[i], FALSE, TRUE))
-        g_warning ("unable to allocate color: ( %d %d %d )",
-                   style->text_aa[i].red, style->text_aa[i].green, style->text_aa[i].blue);
+	{
+	  g_warning ("unable to allocate color: ( %d %d %d )",
+		     style->text_aa[i].red, style->text_aa[i].green,
+		     style->text_aa[i].blue);
+	}
 
       gc_values.foreground = style->fg[i];
       style->fg_gc[i] = gtk_gc_get (style->depth, style->colormap, &gc_values, gc_values_mask);
@@ -3409,91 +3659,98 @@
 }
 
 static void
-msw_style_unrealize (GtkStyle * style)
+msw_style_unrealize (GtkStyle *style)
 {
-	parent_class->unrealize (style);
+  parent_class->unrealize (style);
 }
 
 static void
-msw_style_class_init (MswStyleClass * klass)
+msw_style_class_init (MswStyleClass *klass)
 {
-    GtkStyleClass *style_class = GTK_STYLE_CLASS (klass);
-
-    parent_class = g_type_class_peek_parent (klass);
-
-    style_class->init_from_rc = msw_style_init_from_rc;
-    style_class->draw_arrow = draw_arrow;
-    style_class->draw_box = draw_box;
-    style_class->draw_check = draw_check;
-    style_class->draw_option = draw_option;
-    style_class->draw_tab = draw_tab;
-    style_class->draw_flat_box = draw_flat_box;
-    style_class->draw_expander = draw_expander;
-    style_class->draw_extension = draw_extension;
-    style_class->draw_box_gap = draw_box_gap;
-    style_class->draw_shadow = draw_shadow;
-    style_class->draw_hline = draw_hline;
-    style_class->draw_vline = draw_vline;
-    style_class->draw_handle = draw_handle;
-    style_class->draw_resize_grip = draw_resize_grip;
-    style_class->draw_slider = draw_slider;
-    style_class->draw_focus = draw_focus;
-    style_class->draw_layout = draw_layout;
+  GtkStyleClass *style_class = GTK_STYLE_CLASS (klass);
+
+  parent_class = g_type_class_peek_parent (klass);
+
+  style_class->init_from_rc = msw_style_init_from_rc;
+  style_class->draw_arrow = draw_arrow;
+  style_class->draw_box = draw_box;
+  style_class->draw_check = draw_check;
+  style_class->draw_option = draw_option;
+  style_class->draw_tab = draw_tab;
+  style_class->draw_flat_box = draw_flat_box;
+  style_class->draw_expander = draw_expander;
+  style_class->draw_extension = draw_extension;
+  style_class->draw_box_gap = draw_box_gap;
+  style_class->draw_shadow = draw_shadow;
+  style_class->draw_hline = draw_hline;
+  style_class->draw_vline = draw_vline;
+  style_class->draw_handle = draw_handle;
+  style_class->draw_resize_grip = draw_resize_grip;
+  style_class->draw_slider = draw_slider;
+  style_class->draw_focus = draw_focus;
+  style_class->draw_layout = draw_layout;
 
-    style_class->realize = msw_style_realize;
-    style_class->unrealize = msw_style_unrealize;
+  style_class->realize = msw_style_realize;
+  style_class->unrealize = msw_style_unrealize;
 }
 
 GType msw_type_style = 0;
 
 void
-msw_style_register_type (GTypeModule * module)
+msw_style_register_type (GTypeModule *module)
 {
-    static const GTypeInfo object_info = {
-	sizeof (MswStyleClass),
-	(GBaseInitFunc) NULL,
-	(GBaseFinalizeFunc) NULL,
-	(GClassInitFunc) msw_style_class_init,
-	NULL,			/* class_finalize */
-	NULL,			/* class_data */
-	sizeof (MswStyle),
-	0,			/* n_preallocs */
-	(GInstanceInitFunc) NULL,
-    };
-
-    msw_type_style = g_type_module_register_type (module,
-						  GTK_TYPE_STYLE,
-						  "MswStyle",
-						  &object_info, 0);
+  static const GTypeInfo object_info = {
+    sizeof (MswStyleClass),
+    (GBaseInitFunc) NULL,
+    (GBaseFinalizeFunc) NULL,
+    (GClassInitFunc) msw_style_class_init,
+    NULL,			/* class_finalize */
+    NULL,			/* class_data */
+    sizeof (MswStyle),
+    0,				/* n_preallocs */
+    (GInstanceInitFunc) NULL,
+  };
+
+  msw_type_style = g_type_module_register_type (module,
+						GTK_TYPE_STYLE,
+						"MswStyle", &object_info, 0);
 }
 
 void
 msw_style_init (void)
 {
-    xp_theme_init ();
-    msw_style_setup_system_settings ();
-    setup_msw_rc_style ();
+  xp_theme_init ();
+  msw_style_setup_system_settings ();
+  setup_msw_rc_style ();
 
-    if( g_light_pen ){
-        DeleteObject( g_light_pen );
-        g_light_pen = NULL;
+  if (g_light_pen)
+    {
+      DeleteObject (g_light_pen);
+      g_light_pen = NULL;
     }
-    if( g_dark_pen ){
-        DeleteObject( g_dark_pen );
-        g_dark_pen = NULL;
+
+  if (g_dark_pen)
+    {
+      DeleteObject (g_dark_pen);
+      g_dark_pen = NULL;
     }
 }
 
-void msw_style_finalize(void)
+void
+msw_style_finalize (void)
 {
-    if( g_dither_brush ){
-        DeleteObject( g_dither_brush );
+  if (g_dither_brush)
+    {
+      DeleteObject (g_dither_brush);
     }
-    if( g_light_pen ){
-        DeleteObject( g_light_pen );
+
+  if (g_light_pen)
+    {
+      DeleteObject (g_light_pen);
     }
-    if( g_dark_pen ){
-        DeleteObject( g_dark_pen );
+
+  if (g_dark_pen)
+    {
+      DeleteObject (g_dark_pen);
     }
 }
-

Modified: trunk/modules/engines/ms-windows/msw_theme_main.c
==============================================================================
--- trunk/modules/engines/ms-windows/msw_theme_main.c	(original)
+++ trunk/modules/engines/ms-windows/msw_theme_main.c	Fri Feb  1 23:25:18 2008
@@ -35,10 +35,10 @@
 #endif
 
 static GModule *this_module = NULL;
-static void (*msw_rc_reset_styles) (GtkSettings * settings) = NULL;
-static GdkWindow* hidden_msg_window = NULL;
+static void (*msw_rc_reset_styles) (GtkSettings *settings) = NULL;
+static GdkWindow *hidden_msg_window = NULL;
 
-static GdkWindow*
+static GdkWindow *
 create_hidden_msg_window (void)
 {
   GdkWindowAttr attributes;
@@ -60,79 +60,79 @@
 }
 
 static GdkFilterReturn
-global_filter_func (void *xevent, GdkEvent * event, gpointer data)
+global_filter_func (void *xevent, GdkEvent *event, gpointer data)
 {
-    MSG *msg = (MSG *) xevent;
+  MSG *msg = (MSG *) xevent;
 
-    switch (msg->message)
+  switch (msg->message)
+    {
+      /* catch theme changes */
+    case WM_THEMECHANGED:
+    case WM_SYSCOLORCHANGE:
+
+      if (msw_rc_reset_styles != NULL)
 	{
-	    /* catch theme changes */
-	case WM_THEMECHANGED:
-	case WM_SYSCOLORCHANGE:
-
-	    if (msw_rc_reset_styles != NULL)
-		{
-		    xp_theme_reset ();
-		    msw_style_init ();
-
-		    /* force all gtkwidgets to redraw */
-		    (*msw_rc_reset_styles) (gtk_settings_get_default ());
-		}
-
-	    return GDK_FILTER_REMOVE;
-
-	case WM_SETTINGCHANGE:
-	    /* catch cursor blink, etc... changes */
-	    msw_style_setup_system_settings ();
-	    return GDK_FILTER_REMOVE;
+	  xp_theme_reset ();
+	  msw_style_init ();
 
-	default:
-	    return GDK_FILTER_CONTINUE;
+	  /* force all gtkwidgets to redraw */
+	  (*msw_rc_reset_styles) (gtk_settings_get_default ());
 	}
+
+      return GDK_FILTER_REMOVE;
+
+    case WM_SETTINGCHANGE:
+      /* catch cursor blink, etc... changes */
+      msw_style_setup_system_settings ();
+      return GDK_FILTER_REMOVE;
+
+    default:
+      return GDK_FILTER_CONTINUE;
+    }
 }
 
 G_MODULE_EXPORT void
 theme_init (GTypeModule * module)
 {
-    msw_rc_style_register_type (module);
-    msw_style_register_type (module);
-
-    /* this craziness is required because only gtk 2.4.x and later have
-       gtk_rc_reset_styles(). But we want to be able to run acceptly well on
-       any GTK 2.x.x platform. */
-    if (gtk_check_version (2, 4, 0) == NULL)
-	{
-	    this_module = g_module_open (NULL, 0);
+  msw_rc_style_register_type (module);
+  msw_style_register_type (module);
 
-	    if (this_module)
-		g_module_symbol (this_module, "gtk_rc_reset_styles",
-				 (gpointer *) (&msw_rc_reset_styles));
-	}
-
-    msw_style_init ();
-    hidden_msg_window = create_hidden_msg_window ();
-    gdk_window_add_filter (hidden_msg_window, global_filter_func, NULL);
+  /* this craziness is required because only gtk 2.4.x and later have
+     gtk_rc_reset_styles(). But we want to be able to run acceptly well on
+     any GTK 2.x.x platform. */
+  if (gtk_check_version (2, 4, 0) == NULL)
+    {
+      this_module = g_module_open (NULL, 0);
+
+      if (this_module)
+	g_module_symbol (this_module, "gtk_rc_reset_styles",
+			 (gpointer *) (&msw_rc_reset_styles));
+    }
+
+  msw_style_init ();
+  hidden_msg_window = create_hidden_msg_window ();
+  gdk_window_add_filter (hidden_msg_window, global_filter_func, NULL);
 }
 
 G_MODULE_EXPORT void
 theme_exit (void)
 {
-    gdk_window_remove_filter (hidden_msg_window, global_filter_func, NULL);
-    gdk_window_destroy (hidden_msg_window);
-    hidden_msg_window = NULL;
-    msw_style_finalize();
-
-    if (this_module)
-	{
-	    g_module_close (this_module);
-	    this_module = NULL;
-	}
+  gdk_window_remove_filter (hidden_msg_window, global_filter_func, NULL);
+  gdk_window_destroy (hidden_msg_window);
+  hidden_msg_window = NULL;
+  msw_style_finalize ();
+
+  if (this_module)
+    {
+      g_module_close (this_module);
+      this_module = NULL;
+    }
 }
 
 G_MODULE_EXPORT GtkRcStyle *
 theme_create_rc_style (void)
 {
-    return g_object_new (MSW_TYPE_RC_STYLE, NULL);
+  return g_object_new (MSW_TYPE_RC_STYLE, NULL);
 }
 
 /* The following function will be called by GTK+ when the module
@@ -140,7 +140,7 @@
  * version of GTK+ that loads us.
  */
 G_MODULE_EXPORT const gchar *
-g_module_check_init (GModule * module)
+g_module_check_init (GModule *module)
 {
-    return gtk_check_version (2, 0, 0);
+  return gtk_check_version (2, 0, 0);
 }

Modified: trunk/modules/engines/ms-windows/xp_theme.c
==============================================================================
--- trunk/modules/engines/ms-windows/xp_theme.c	(original)
+++ trunk/modules/engines/ms-windows/xp_theme.c	Fri Feb  1 23:25:18 2008
@@ -41,143 +41,140 @@
 /* These aren't in mingw's "w32api" headers, nor in the Platform SDK
  * headers.
  */
-#define TMT_CAPTIONFONT 801
-#define TMT_MENUFONT 803
-#define TMT_STATUSFONT 804
-#define TMT_MSGBOXFONT 805
+#define TMT_CAPTIONFONT   801
+#define TMT_MENUFONT      803
+#define TMT_STATUSFONT    804
+#define TMT_MSGBOXFONT    805
 #endif
 
-#define GP_LINEHORZ 2
-#define GP_LINEVERT 3
-#define TP_SEPARATOR           5
-#define TP_SEPARATORVERT       6
+#define GP_LINEHORZ       2
+#define GP_LINEVERT       3
+#define TP_SEPARATOR      5
+#define TP_SEPARATORVERT  6
 
 /* GLOBALS LINEHORZ states */
-#define LHS_FLAT   1
-#define LHS_RAISED 2
-#define LHS_SUNKEN 3
+#define LHS_FLAT          1
+#define LHS_RAISED        2
+#define LHS_SUNKEN        3
 
 /* GLOBAL LINEVERT states */
-#define LVS_FLAT   1
-#define LVS_RAISED 2
-#define LVS_SUNKEN 3
+#define LVS_FLAT          1
+#define LVS_RAISED        2
+#define LVS_SUNKEN        3
 
 /* TRACKBAR parts */
-#define TKP_TRACK       1
-#define TKP_TRACKVERT   2
-#define TKP_THUMB       3
-#define TKP_THUMBBOTTOM 4
-#define TKP_THUMBTOP    5
-#define TKP_THUMBVERT   6
-#define TKP_THUMBLEFT   7
-#define TKP_THUMBRIGHT  8
-#define TKP_TICS        9
-#define TKP_TICSVERT    10
+#define TKP_TRACK         1
+#define TKP_TRACKVERT     2
+#define TKP_THUMB         3
+#define TKP_THUMBBOTTOM   4
+#define TKP_THUMBTOP      5
+#define TKP_THUMBVERT     6
+#define TKP_THUMBLEFT     7
+#define TKP_THUMBRIGHT    8
+#define TKP_TICS          9
+#define TKP_TICSVERT      10
 
-#define TRS_NORMAL 1
+#define TRS_NORMAL        1
 
 static const LPCWSTR class_descriptors[] = {
-    L"Scrollbar",		/* XP_THEME_CLASS_SCROLLBAR */
-    L"Button",			/* XP_THEME_CLASS_BUTTON */
-    L"Header",			/* XP_THEME_CLASS_HEADER */
-    L"ComboBox",		/* XP_THEME_CLASS_COMBOBOX */
-    L"Tab",			    /* XP_THEME_CLASS_TAB */
-    L"Edit",			/* XP_THEME_CLASS_EDIT */
-    L"TreeView",		/* XP_THEME_CLASS_TREEVIEW */
-    L"Spin",			/* XP_THEME_CLASS_SPIN */
-    L"Progress",		/* XP_THEME_CLASS_PROGRESS */
-    L"Tooltip",			/* XP_THEME_CLASS_TOOLTIP */
-    L"Rebar",			/* XP_THEME_CLASS_REBAR */
-    L"Toolbar",			/* XP_THEME_CLASS_TOOLBAR */
-    L"Globals",			/* XP_THEME_CLASS_GLOBALS */
-    L"Menu",			/* XP_THEME_CLASS_MENU */
-    L"Window",			/* XP_THEME_CLASS_WINDOW */
-    L"Status",			/* XP_THEME_CLASS_STATUS */
-    L"Trackbar"			/* XP_THEME_CLASS_TRACKBAR */
+  L"Scrollbar",			/* XP_THEME_CLASS_SCROLLBAR */
+  L"Button",			/* XP_THEME_CLASS_BUTTON */
+  L"Header",			/* XP_THEME_CLASS_HEADER */
+  L"ComboBox",			/* XP_THEME_CLASS_COMBOBOX */
+  L"Tab",			/* XP_THEME_CLASS_TAB */
+  L"Edit",			/* XP_THEME_CLASS_EDIT */
+  L"TreeView",			/* XP_THEME_CLASS_TREEVIEW */
+  L"Spin",			/* XP_THEME_CLASS_SPIN */
+  L"Progress",			/* XP_THEME_CLASS_PROGRESS */
+  L"Tooltip",			/* XP_THEME_CLASS_TOOLTIP */
+  L"Rebar",			/* XP_THEME_CLASS_REBAR */
+  L"Toolbar",			/* XP_THEME_CLASS_TOOLBAR */
+  L"Globals",			/* XP_THEME_CLASS_GLOBALS */
+  L"Menu",			/* XP_THEME_CLASS_MENU */
+  L"Window",			/* XP_THEME_CLASS_WINDOW */
+  L"Status",			/* XP_THEME_CLASS_STATUS */
+  L"Trackbar"			/* XP_THEME_CLASS_TRACKBAR */
 };
 
 static const short element_part_map[XP_THEME_ELEMENT__SIZEOF] = {
-    BP_CHECKBOX,
-    BP_CHECKBOX,
-    BP_CHECKBOX,
-    BP_PUSHBUTTON,
-    HP_HEADERITEM,
-    CP_DROPDOWNBUTTON,
-    TABP_BODY,
-    TABP_TABITEM,
-    TABP_TABITEMLEFTEDGE,
-   	TABP_TABITEMRIGHTEDGE,
-    TABP_PANE,
-    SBP_THUMBBTNHORZ,
-    SBP_THUMBBTNVERT,
-    SBP_ARROWBTN,
-    SBP_ARROWBTN,
-    SBP_ARROWBTN,
-    SBP_ARROWBTN,
-    SBP_GRIPPERHORZ,
-    SBP_GRIPPERVERT,
-    SBP_LOWERTRACKHORZ,
-    SBP_LOWERTRACKVERT,
-    EP_EDITTEXT,
-    BP_PUSHBUTTON,
-    SPNP_UP,
-    SPNP_DOWN,
-    BP_RADIOBUTTON,
-    BP_RADIOBUTTON,
-    TVP_GLYPH,
-    TVP_GLYPH,
-    PP_CHUNK,
-    PP_CHUNKVERT,
-    PP_BAR,
-    PP_BARVERT,
-    TTP_STANDARD,
-    0 /* RP_BAND */ ,
-    RP_GRIPPER,
-    RP_GRIPPERVERT,
-    RP_CHEVRON,
-    TP_BUTTON,
-    MP_MENUITEM,
-    MP_SEPARATOR,
-    SP_GRIPPER,
-    SP_PANE,
-    GP_LINEHORZ,
-    GP_LINEVERT,
-    TP_SEPARATOR,
-    TP_SEPARATORVERT,
-    TKP_TRACK,
-    TKP_TRACKVERT,
-    TKP_THUMB,
-    TKP_THUMBVERT,
-    TKP_TICS,
-    TKP_TICSVERT
+  BP_CHECKBOX,
+  BP_CHECKBOX,
+  BP_CHECKBOX,
+  BP_PUSHBUTTON,
+  HP_HEADERITEM,
+  CP_DROPDOWNBUTTON,
+  TABP_BODY,
+  TABP_TABITEM,
+  TABP_TABITEMLEFTEDGE,
+  TABP_TABITEMRIGHTEDGE,
+  TABP_PANE,
+  SBP_THUMBBTNHORZ,
+  SBP_THUMBBTNVERT,
+  SBP_ARROWBTN,
+  SBP_ARROWBTN,
+  SBP_ARROWBTN,
+  SBP_ARROWBTN,
+  SBP_GRIPPERHORZ,
+  SBP_GRIPPERVERT,
+  SBP_LOWERTRACKHORZ,
+  SBP_LOWERTRACKVERT,
+  EP_EDITTEXT,
+  BP_PUSHBUTTON,
+  SPNP_UP,
+  SPNP_DOWN,
+  BP_RADIOBUTTON,
+  BP_RADIOBUTTON,
+  TVP_GLYPH,
+  TVP_GLYPH,
+  PP_CHUNK,
+  PP_CHUNKVERT,
+  PP_BAR,
+  PP_BARVERT,
+  TTP_STANDARD,
+  0 /* RP_BAND */ ,
+  RP_GRIPPER,
+  RP_GRIPPERVERT,
+  RP_CHEVRON,
+  TP_BUTTON,
+  MP_MENUITEM,
+  MP_SEPARATOR,
+  SP_GRIPPER,
+  SP_PANE,
+  GP_LINEHORZ,
+  GP_LINEVERT,
+  TP_SEPARATOR,
+  TP_SEPARATORVERT,
+  TKP_TRACK,
+  TKP_TRACKVERT,
+  TKP_THUMB,
+  TKP_THUMBVERT,
+  TKP_TICS,
+  TKP_TICSVERT
 };
 
 static HINSTANCE uxtheme_dll = NULL;
 static HTHEME open_themes[XP_THEME_CLASS__SIZEOF];
 static gboolean use_xp_theme = FALSE;
 
-typedef HRESULT (FAR PASCAL * GetThemeSysFontFunc)
-    (HTHEME hTheme, int iFontID, OUT LOGFONT * plf);
-typedef int (FAR PASCAL * GetThemeSysSizeFunc) (HTHEME hTheme, int iSizeId);
-typedef COLORREF (FAR PASCAL * GetThemeSysColorFunc) (HTHEME hTheme,
-						      int iColorID);
-typedef HTHEME (FAR PASCAL * OpenThemeDataFunc) (HWND hwnd,
-						 LPCWSTR pszClassList);
-typedef HRESULT (FAR PASCAL * CloseThemeDataFunc) (HTHEME theme);
-typedef HRESULT (FAR PASCAL * DrawThemeBackgroundFunc)
-    (HTHEME hTheme, HDC hdc, int iPartId, int iStateId,
-     const RECT * pRect, const RECT * pClipRect);
-typedef HRESULT (FAR PASCAL * EnableThemeDialogTextureFunc) (HWND hwnd,
+typedef HRESULT (FAR PASCAL *GetThemeSysFontFunc)           (HTHEME hTheme, int iFontID, OUT LOGFONT *plf);
+typedef int (FAR PASCAL *GetThemeSysSizeFunc)               (HTHEME hTheme, int iSizeId);
+typedef COLORREF (FAR PASCAL *GetThemeSysColorFunc)         (HTHEME hTheme,
+							     int iColorID);
+typedef HTHEME (FAR PASCAL *OpenThemeDataFunc)              (HWND hwnd,
+							     LPCWSTR pszClassList);
+typedef HRESULT (FAR PASCAL *CloseThemeDataFunc)            (HTHEME theme);
+typedef HRESULT (FAR PASCAL *DrawThemeBackgroundFunc)       (HTHEME hTheme, HDC hdc, int iPartId, int iStateId,
+							     const RECT *pRect, const RECT *pClipRect);
+typedef HRESULT (FAR PASCAL *EnableThemeDialogTextureFunc)  (HWND hwnd,
 							     DWORD dwFlags);
-typedef BOOL (FAR PASCAL * IsThemeActiveFunc) (VOID);
-typedef BOOL (FAR PASCAL * IsAppThemedFunc) (VOID);
-typedef BOOL (FAR PASCAL *
-	      IsThemeBackgroundPartiallyTransparentFunc) (HTHEME hTheme,
-							  int iPartId,
-							  int iStateId);
-typedef HRESULT (FAR PASCAL * DrawThemeParentBackgroundFunc) (HWND hwnd,
-							      HDC hdc,
-							      RECT * prc);
+typedef BOOL (FAR PASCAL *IsThemeActiveFunc)                (VOID);
+typedef BOOL (FAR PASCAL *IsAppThemedFunc)                  (VOID);
+typedef BOOL (FAR PASCAL *IsThemeBackgroundPartiallyTransparentFunc) (HTHEME hTheme,
+								      int iPartId,
+								      int iStateId);
+typedef HRESULT (FAR PASCAL *DrawThemeParentBackgroundFunc) (HWND hwnd,
+							     HDC hdc,
+							     RECT *prc);
 
 static GetThemeSysFontFunc get_theme_sys_font_func = NULL;
 static GetThemeSysColorFunc get_theme_sys_color_func = NULL;
@@ -188,769 +185,804 @@
 static EnableThemeDialogTextureFunc enable_theme_dialog_texture_func = NULL;
 static IsThemeActiveFunc is_theme_active_func = NULL;
 static IsAppThemedFunc is_app_themed_func = NULL;
-static IsThemeBackgroundPartiallyTransparentFunc
-    is_theme_partially_transparent_func = NULL;
+static IsThemeBackgroundPartiallyTransparentFunc is_theme_partially_transparent_func = NULL;
 static DrawThemeParentBackgroundFunc draw_theme_parent_background_func = NULL;
 
 static void
 xp_theme_close_open_handles (void)
 {
-    int i;
+  int i;
 
-    for (i = 0; i < XP_THEME_CLASS__SIZEOF; i++)
+  for (i = 0; i < XP_THEME_CLASS__SIZEOF; i++)
+    {
+      if (open_themes[i])
 	{
-	    if (open_themes[i])
-		{
-		    close_theme_data_func (open_themes[i]);
-		    open_themes[i] = NULL;
-		}
+	  close_theme_data_func (open_themes[i]);
+	  open_themes[i] = NULL;
 	}
+    }
 }
 
 void
 xp_theme_init (void)
 {
-    if (uxtheme_dll)
-	return;
+  if (uxtheme_dll)
+    return;
 
-    memset (open_themes, 0, sizeof (open_themes));
+  memset (open_themes, 0, sizeof (open_themes));
 
-    uxtheme_dll = LoadLibrary ("uxtheme.dll");
-    if (!uxtheme_dll)
-	return;
-
-    is_app_themed_func =
-	(IsAppThemedFunc) GetProcAddress (uxtheme_dll, "IsAppThemed");
-
-    if (is_app_themed_func)
-	{
-	    is_theme_active_func =
-		(IsThemeActiveFunc) GetProcAddress (uxtheme_dll,
-						    "IsThemeActive");
-	    open_theme_data_func =
-		(OpenThemeDataFunc) GetProcAddress (uxtheme_dll,
-						    "OpenThemeData");
-	    close_theme_data_func =
-		(CloseThemeDataFunc) GetProcAddress (uxtheme_dll,
-						     "CloseThemeData");
-	    draw_theme_background_func =
-		(DrawThemeBackgroundFunc) GetProcAddress (uxtheme_dll,
-							  "DrawThemeBackground");
-	    enable_theme_dialog_texture_func =
-		(EnableThemeDialogTextureFunc) GetProcAddress (uxtheme_dll,
-							       "EnableThemeDialogTexture");
-	    get_theme_sys_font_func =
-		(GetThemeSysFontFunc) GetProcAddress (uxtheme_dll,
-						      "GetThemeSysFont");
-	    get_theme_sys_color_func =
-		(GetThemeSysColorFunc) GetProcAddress (uxtheme_dll,
-						       "GetThemeSysColor");
-	    get_theme_sys_metric_func =
-		(GetThemeSysSizeFunc) GetProcAddress (uxtheme_dll,
-						      "GetThemeSysSize");
-	    is_theme_partially_transparent_func =
-		(IsThemeBackgroundPartiallyTransparentFunc)
-		GetProcAddress (uxtheme_dll,
-				"IsThemeBackgroundPartiallyTransparent");
-	    draw_theme_parent_background_func =
-		(DrawThemeParentBackgroundFunc) GetProcAddress (uxtheme_dll,
-								"DrawThemeParentBackground");
-	}
+  uxtheme_dll = LoadLibrary ("uxtheme.dll");
+  if (!uxtheme_dll)
+    return;
+
+  is_app_themed_func = (IsAppThemedFunc) GetProcAddress (uxtheme_dll, "IsAppThemed");
+
+  if (is_app_themed_func)
+    {
+      is_theme_active_func = (IsThemeActiveFunc) GetProcAddress (uxtheme_dll, "IsThemeActive");
+      open_theme_data_func = (OpenThemeDataFunc) GetProcAddress (uxtheme_dll, "OpenThemeData");
+      close_theme_data_func = (CloseThemeDataFunc) GetProcAddress (uxtheme_dll, "CloseThemeData");
+      draw_theme_background_func = (DrawThemeBackgroundFunc) GetProcAddress (uxtheme_dll, "DrawThemeBackground");
+      enable_theme_dialog_texture_func = (EnableThemeDialogTextureFunc) GetProcAddress (uxtheme_dll, "EnableThemeDialogTexture");
+      get_theme_sys_font_func = (GetThemeSysFontFunc) GetProcAddress (uxtheme_dll, "GetThemeSysFont");
+      get_theme_sys_color_func = (GetThemeSysColorFunc) GetProcAddress (uxtheme_dll, "GetThemeSysColor");
+      get_theme_sys_metric_func = (GetThemeSysSizeFunc) GetProcAddress (uxtheme_dll, "GetThemeSysSize");
+      is_theme_partially_transparent_func = (IsThemeBackgroundPartiallyTransparentFunc) GetProcAddress (uxtheme_dll, "IsThemeBackgroundPartiallyTransparent");
+      draw_theme_parent_background_func = (DrawThemeParentBackgroundFunc) GetProcAddress (uxtheme_dll, "DrawThemeParentBackground");
+    }
 
-    if (is_app_themed_func && is_theme_active_func) {
-        use_xp_theme = (is_app_themed_func () && is_theme_active_func ());
+  if (is_app_themed_func && is_theme_active_func)
+    {
+      use_xp_theme = (is_app_themed_func () && is_theme_active_func ());
     }
-    else {
-        use_xp_theme = FALSE;
+  else
+    {
+      use_xp_theme = FALSE;
     }
 }
 
 void
 xp_theme_reset (void)
 {
-    xp_theme_close_open_handles ();
+  xp_theme_close_open_handles ();
 
-    if (is_app_themed_func && is_theme_active_func) {
-        use_xp_theme = (is_app_themed_func () && is_theme_active_func ());
+  if (is_app_themed_func && is_theme_active_func)
+    {
+      use_xp_theme = (is_app_themed_func () && is_theme_active_func ());
     }
-    else {
-        use_xp_theme = FALSE;
+  else
+    {
+      use_xp_theme = FALSE;
     }
 }
 
 void
 xp_theme_exit (void)
 {
-    if (!uxtheme_dll)
-	return;
+  if (!uxtheme_dll)
+    return;
 
-    xp_theme_close_open_handles ();
+  xp_theme_close_open_handles ();
 
-    FreeLibrary (uxtheme_dll);
-    uxtheme_dll = NULL;
-	use_xp_theme = FALSE;
-
-    is_app_themed_func = NULL;
-    is_theme_active_func = NULL;
-    open_theme_data_func = NULL;
-    close_theme_data_func = NULL;
-    draw_theme_background_func = NULL;
-    enable_theme_dialog_texture_func = NULL;
-    get_theme_sys_font_func = NULL;
-    get_theme_sys_color_func = NULL;
-    get_theme_sys_metric_func = NULL;
-    is_theme_partially_transparent_func = NULL;
-    draw_theme_parent_background_func = NULL;
+  FreeLibrary (uxtheme_dll);
+  uxtheme_dll = NULL;
+  use_xp_theme = FALSE;
+
+  is_app_themed_func = NULL;
+  is_theme_active_func = NULL;
+  open_theme_data_func = NULL;
+  close_theme_data_func = NULL;
+  draw_theme_background_func = NULL;
+  enable_theme_dialog_texture_func = NULL;
+  get_theme_sys_font_func = NULL;
+  get_theme_sys_color_func = NULL;
+  get_theme_sys_metric_func = NULL;
+  is_theme_partially_transparent_func = NULL;
+  draw_theme_parent_background_func = NULL;
 }
 
 static HTHEME
 xp_theme_get_handle_by_class (XpThemeClass klazz)
 {
-    if (!open_themes[klazz] && open_theme_data_func)
-	{
-	    open_themes[klazz] =
-		open_theme_data_func (NULL, class_descriptors[klazz]);
-	}
-    return open_themes[klazz];
+  if (!open_themes[klazz] && open_theme_data_func)
+    {
+      open_themes[klazz] = open_theme_data_func (NULL, class_descriptors[klazz]);
+    }
+
+  return open_themes[klazz];
 }
 
 static HTHEME
 xp_theme_get_handle_by_element (XpThemeElement element)
 {
-    HTHEME ret = NULL;
-    XpThemeClass klazz = XP_THEME_CLASS__SIZEOF;
+  HTHEME ret = NULL;
+  XpThemeClass klazz = XP_THEME_CLASS__SIZEOF;
+
+  switch (element)
+    {
+    case XP_THEME_ELEMENT_TOOLTIP:
+      klazz = XP_THEME_CLASS_TOOLTIP;
+      break;
+
+    case XP_THEME_ELEMENT_REBAR:
+    case XP_THEME_ELEMENT_REBAR_GRIPPER_H:
+    case XP_THEME_ELEMENT_REBAR_GRIPPER_V:
+    case XP_THEME_ELEMENT_REBAR_CHEVRON:
+      klazz = XP_THEME_CLASS_REBAR;
+      break;
+
+    case XP_THEME_ELEMENT_SCALE_TROUGH_H:
+    case XP_THEME_ELEMENT_SCALE_TROUGH_V:
+    case XP_THEME_ELEMENT_SCALE_SLIDER_H:
+    case XP_THEME_ELEMENT_SCALE_SLIDER_V:
+    case XP_THEME_ELEMENT_SCALE_TICS_H:
+    case XP_THEME_ELEMENT_SCALE_TICS_V:
+      klazz = XP_THEME_CLASS_TRACKBAR;
+      break;
+
+    case XP_THEME_ELEMENT_STATUS_GRIPPER:
+    case XP_THEME_ELEMENT_STATUS_PANE:
+      klazz = XP_THEME_CLASS_STATUS;
+      break;
+
+    case XP_THEME_ELEMENT_TOOLBAR_BUTTON:
+    case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_H:
+    case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_V:
+      klazz = XP_THEME_CLASS_TOOLBAR;
+      break;
+
+    case XP_THEME_ELEMENT_MENU_ITEM:
+    case XP_THEME_ELEMENT_MENU_SEPARATOR:
+      klazz = XP_THEME_CLASS_MENU;
+      break;
+
+    case XP_THEME_ELEMENT_PRESSED_CHECKBOX:
+    case XP_THEME_ELEMENT_INCONSISTENT_CHECKBOX:
+    case XP_THEME_ELEMENT_CHECKBOX:
+    case XP_THEME_ELEMENT_BUTTON:
+    case XP_THEME_ELEMENT_DEFAULT_BUTTON:
+    case XP_THEME_ELEMENT_PRESSED_RADIO_BUTTON:
+    case XP_THEME_ELEMENT_RADIO_BUTTON:
+      klazz = XP_THEME_CLASS_BUTTON;
+      break;
+
+    case XP_THEME_ELEMENT_LIST_HEADER:
+      klazz = XP_THEME_CLASS_HEADER;
+      break;
+
+    case XP_THEME_ELEMENT_COMBOBUTTON:
+      klazz = XP_THEME_CLASS_COMBOBOX;
+      break;
+
+    case XP_THEME_ELEMENT_BODY:
+    case XP_THEME_ELEMENT_TAB_ITEM:
+    case XP_THEME_ELEMENT_TAB_ITEM_LEFT_EDGE:
+    case XP_THEME_ELEMENT_TAB_ITEM_RIGHT_EDGE:
+    case XP_THEME_ELEMENT_TAB_PANE:
+      klazz = XP_THEME_CLASS_TAB;
+      break;
+
+    case XP_THEME_ELEMENT_SCROLLBAR_V:
+    case XP_THEME_ELEMENT_SCROLLBAR_H:
+    case XP_THEME_ELEMENT_ARROW_UP:
+    case XP_THEME_ELEMENT_ARROW_DOWN:
+    case XP_THEME_ELEMENT_ARROW_LEFT:
+    case XP_THEME_ELEMENT_ARROW_RIGHT:
+    case XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_V:
+    case XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_H:
+    case XP_THEME_ELEMENT_TROUGH_V:
+    case XP_THEME_ELEMENT_TROUGH_H:
+      klazz = XP_THEME_CLASS_SCROLLBAR;
+      break;
+
+    case XP_THEME_ELEMENT_EDIT_TEXT:
+      klazz = XP_THEME_CLASS_EDIT;
+      break;
+
+    case XP_THEME_ELEMENT_SPIN_BUTTON_UP:
+    case XP_THEME_ELEMENT_SPIN_BUTTON_DOWN:
+      klazz = XP_THEME_CLASS_SPIN;
+      break;
+
+    case XP_THEME_ELEMENT_PROGRESS_BAR_H:
+    case XP_THEME_ELEMENT_PROGRESS_BAR_V:
+    case XP_THEME_ELEMENT_PROGRESS_TROUGH_H:
+    case XP_THEME_ELEMENT_PROGRESS_TROUGH_V:
+      klazz = XP_THEME_CLASS_PROGRESS;
+      break;
+
+    case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_OPENED:
+    case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_CLOSED:
+      klazz = XP_THEME_CLASS_TREEVIEW;
+      break;
+
+    case XP_THEME_ELEMENT_LINE_H:
+    case XP_THEME_ELEMENT_LINE_V:
+      klazz = XP_THEME_CLASS_GLOBALS;
+      break;
+
+    default:
+      break;
+    }
+
+  if (klazz != XP_THEME_CLASS__SIZEOF)
+    {
+      ret = xp_theme_get_handle_by_class (klazz);
+    }
+
+  return ret;
+}
+
+static int
+xp_theme_map_gtk_state (XpThemeElement element, GtkStateType state)
+{
+  int ret = 0;
 
-    switch (element)
+  switch (element)
+    {
+    case XP_THEME_ELEMENT_TOOLTIP:
+      ret = TTSS_NORMAL;
+      break;
+
+    case XP_THEME_ELEMENT_REBAR:
+      ret = 0;
+      break;
+
+    case XP_THEME_ELEMENT_REBAR_GRIPPER_H:
+    case XP_THEME_ELEMENT_REBAR_GRIPPER_V:
+      ret = 0;
+      break;
+
+    case XP_THEME_ELEMENT_STATUS_GRIPPER:
+    case XP_THEME_ELEMENT_STATUS_PANE:
+      ret = 1;
+      break;
+
+    case XP_THEME_ELEMENT_REBAR_CHEVRON:
+      switch (state)
 	{
-	case XP_THEME_ELEMENT_TOOLTIP:
-	    klazz = XP_THEME_CLASS_TOOLTIP;
-	    break;
-
-	case XP_THEME_ELEMENT_REBAR:
-	case XP_THEME_ELEMENT_REBAR_GRIPPER_H:
-	case XP_THEME_ELEMENT_REBAR_GRIPPER_V:
-	case XP_THEME_ELEMENT_REBAR_CHEVRON:
-	    klazz = XP_THEME_CLASS_REBAR;
-	    break;
-
-	case XP_THEME_ELEMENT_SCALE_TROUGH_H:
-	case XP_THEME_ELEMENT_SCALE_TROUGH_V:
-	case XP_THEME_ELEMENT_SCALE_SLIDER_H:
-	case XP_THEME_ELEMENT_SCALE_SLIDER_V:
-	case XP_THEME_ELEMENT_SCALE_TICS_H:
-	case XP_THEME_ELEMENT_SCALE_TICS_V:
-	    klazz = XP_THEME_CLASS_TRACKBAR;
-	    break;
-
-	case XP_THEME_ELEMENT_STATUS_GRIPPER:
-	case XP_THEME_ELEMENT_STATUS_PANE:
-	    klazz = XP_THEME_CLASS_STATUS;
-	    break;
-
-	case XP_THEME_ELEMENT_TOOLBAR_BUTTON:
-	case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_H:
-	case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_V:
-	    klazz = XP_THEME_CLASS_TOOLBAR;
-	    break;
-
-	case XP_THEME_ELEMENT_MENU_ITEM:
-	case XP_THEME_ELEMENT_MENU_SEPARATOR:
-	    klazz = XP_THEME_CLASS_MENU;
-	    break;
-
-	case XP_THEME_ELEMENT_PRESSED_CHECKBOX:
-	case XP_THEME_ELEMENT_INCONSISTENT_CHECKBOX:
-	case XP_THEME_ELEMENT_CHECKBOX:
-	case XP_THEME_ELEMENT_BUTTON:
-	case XP_THEME_ELEMENT_DEFAULT_BUTTON:
-	case XP_THEME_ELEMENT_PRESSED_RADIO_BUTTON:
-	case XP_THEME_ELEMENT_RADIO_BUTTON:
-	    klazz = XP_THEME_CLASS_BUTTON;
-	    break;
-
-	case XP_THEME_ELEMENT_LIST_HEADER:
-	    klazz = XP_THEME_CLASS_HEADER;
-	    break;
-
-	case XP_THEME_ELEMENT_COMBOBUTTON:
-	    klazz = XP_THEME_CLASS_COMBOBOX;
-	    break;
-
-	case XP_THEME_ELEMENT_BODY:
-	case XP_THEME_ELEMENT_TAB_ITEM:
-	case XP_THEME_ELEMENT_TAB_ITEM_LEFT_EDGE:
-	case XP_THEME_ELEMENT_TAB_ITEM_RIGHT_EDGE:
-	case XP_THEME_ELEMENT_TAB_PANE:
-	    klazz = XP_THEME_CLASS_TAB;
-	    break;
-
-	case XP_THEME_ELEMENT_SCROLLBAR_V:
-	case XP_THEME_ELEMENT_SCROLLBAR_H:
-	case XP_THEME_ELEMENT_ARROW_UP:
-	case XP_THEME_ELEMENT_ARROW_DOWN:
-	case XP_THEME_ELEMENT_ARROW_LEFT:
-	case XP_THEME_ELEMENT_ARROW_RIGHT:
-	case XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_V:
-	case XP_THEME_ELEMENT_SCROLLBAR_GRIPPER_H:
-	case XP_THEME_ELEMENT_TROUGH_V:
-	case XP_THEME_ELEMENT_TROUGH_H:
-	    klazz = XP_THEME_CLASS_SCROLLBAR;
-	    break;
-
-	case XP_THEME_ELEMENT_EDIT_TEXT:
-	    klazz = XP_THEME_CLASS_EDIT;
-	    break;
-
-	case XP_THEME_ELEMENT_SPIN_BUTTON_UP:
-	case XP_THEME_ELEMENT_SPIN_BUTTON_DOWN:
-	    klazz = XP_THEME_CLASS_SPIN;
-	    break;
-
-	case XP_THEME_ELEMENT_PROGRESS_BAR_H:
-	case XP_THEME_ELEMENT_PROGRESS_BAR_V:
-	case XP_THEME_ELEMENT_PROGRESS_TROUGH_H:
-	case XP_THEME_ELEMENT_PROGRESS_TROUGH_V:
-	    klazz = XP_THEME_CLASS_PROGRESS;
-	    break;
-
-	case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_OPENED:
-	case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_CLOSED:
-	    klazz = XP_THEME_CLASS_TREEVIEW;
-	    break;
-
-	case XP_THEME_ELEMENT_LINE_H:
-	case XP_THEME_ELEMENT_LINE_V:
-	    klazz = XP_THEME_CLASS_GLOBALS;
-	    break;
+	case GTK_STATE_PRELIGHT:
+	  ret = CHEVS_HOT;
+	  break;
+
+	case GTK_STATE_SELECTED:
+	case GTK_STATE_ACTIVE:
+	  ret = CHEVS_PRESSED;
+	  break;
 
 	default:
-	    break;
+	  ret = CHEVS_NORMAL;
 	}
+      break;
+
+    case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_H:
+    case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_V:
+      ret = TS_NORMAL;
+      break;
 
-    if (klazz != XP_THEME_CLASS__SIZEOF)
+    case XP_THEME_ELEMENT_TOOLBAR_BUTTON:
+      switch (state)
 	{
-	    ret = xp_theme_get_handle_by_class (klazz);
+	case GTK_STATE_ACTIVE:
+	  ret = TS_PRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = TS_HOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = TS_DISABLED;
+	  break;
+
+	default:
+	  ret = TS_NORMAL;
 	}
-    return ret;
-}
+      break;
 
-static int
-xp_theme_map_gtk_state (XpThemeElement element, GtkStateType state)
-{
-    int ret = 0;
+    case XP_THEME_ELEMENT_TAB_PANE:
+      ret = 1;
+      break;
 
-    switch (element)
+    case XP_THEME_ELEMENT_TAB_ITEM_LEFT_EDGE:
+    case XP_THEME_ELEMENT_TAB_ITEM_RIGHT_EDGE:
+    case XP_THEME_ELEMENT_TAB_ITEM:
+      switch (state)
 	{
-	case XP_THEME_ELEMENT_TOOLTIP:
-	    ret = TTSS_NORMAL;
-	    break;
-
-	case XP_THEME_ELEMENT_REBAR:
-	    ret = 0;
-	    break;
-
-	case XP_THEME_ELEMENT_REBAR_GRIPPER_H:
-	case XP_THEME_ELEMENT_REBAR_GRIPPER_V:
-	    ret = 0;
-	    break;
-
-	case XP_THEME_ELEMENT_STATUS_GRIPPER:
-	case XP_THEME_ELEMENT_STATUS_PANE:
-	    ret = 1;
-	    break;
-
-	case XP_THEME_ELEMENT_REBAR_CHEVRON:
-	    switch (state)
-		{
-		case GTK_STATE_PRELIGHT:
-		    ret = CHEVS_HOT;
-		    break;
-		case GTK_STATE_SELECTED:
-		case GTK_STATE_ACTIVE:
-		    ret = CHEVS_PRESSED;
-		    break;
-		default:
-		    ret = CHEVS_NORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_H:
-	case XP_THEME_ELEMENT_TOOLBAR_SEPARATOR_V:
-	    ret = TS_NORMAL;
-	    break;
-
-	case XP_THEME_ELEMENT_TOOLBAR_BUTTON:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = TS_PRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = TS_HOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = TS_DISABLED;
-		    break;
-		default:
-		    ret = TS_NORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_TAB_PANE:
-	    ret = 1;
-	    break;
-
-	case XP_THEME_ELEMENT_TAB_ITEM_LEFT_EDGE:
-	case XP_THEME_ELEMENT_TAB_ITEM_RIGHT_EDGE:
-	case XP_THEME_ELEMENT_TAB_ITEM:
-	    switch (state)
-		{
-		case GTK_STATE_PRELIGHT:
-		    ret = TIS_HOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = TIS_DISABLED;
-		    break;
-		case GTK_STATE_SELECTED:
-		case GTK_STATE_ACTIVE:
-		    ret = TIS_NORMAL;
-		    break;
-		default:
-		    ret = TIS_SELECTED;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_EDIT_TEXT:
-	    switch (state)
-		{
-		case GTK_STATE_PRELIGHT:
-		    ret = ETS_FOCUSED;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = ETS_READONLY;
-		    break;
-		case GTK_STATE_SELECTED:
-		case GTK_STATE_ACTIVE:
-		default:
-		    ret = ETS_NORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_TROUGH_H:
-	case XP_THEME_ELEMENT_TROUGH_V:
-	    ret = SCRBS_NORMAL;
-	    break;
-
-	case XP_THEME_ELEMENT_SCROLLBAR_H:
-	case XP_THEME_ELEMENT_SCROLLBAR_V:
-	    switch (state)
-		{
-		case GTK_STATE_SELECTED:
-		case GTK_STATE_ACTIVE:
-		    ret = SCRBS_PRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = SCRBS_HOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = SCRBS_DISABLED;
-		    break;
-		default:
-		    ret = SCRBS_NORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_ARROW_DOWN:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = ABS_DOWNPRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = ABS_DOWNHOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = ABS_DOWNDISABLED;
-		    break;
-		default:
-		    ret = ABS_DOWNNORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_ARROW_UP:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = ABS_UPPRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = ABS_UPHOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = ABS_UPDISABLED;
-		    break;
-		default:
-		    ret = ABS_UPNORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_ARROW_LEFT:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = ABS_LEFTPRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = ABS_LEFTHOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = ABS_LEFTDISABLED;
-		    break;
-		default:
-		    ret = ABS_LEFTNORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_ARROW_RIGHT:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = ABS_RIGHTPRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = ABS_RIGHTHOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = ABS_RIGHTDISABLED;
-		    break;
-		default:
-		    ret = ABS_RIGHTNORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_CHECKBOX:
-	case XP_THEME_ELEMENT_RADIO_BUTTON:
-	    switch (state)
-		{
-		case GTK_STATE_SELECTED:
-		    ret = CBS_UNCHECKEDPRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = CBS_UNCHECKEDHOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = CBS_UNCHECKEDDISABLED;
-		    break;
-		default:
-		    ret = CBS_UNCHECKEDNORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_INCONSISTENT_CHECKBOX:
-	  switch (state)
-	    {
-	    case GTK_STATE_SELECTED:
-	      ret = CBS_MIXEDPRESSED;
-	      break;
-	    case GTK_STATE_PRELIGHT:
-	      ret = CBS_MIXEDHOT;
-	      break;
-	    case GTK_STATE_INSENSITIVE:
-	      ret = CBS_MIXEDDISABLED;
-	      break;
-	    default:
-	      ret = CBS_MIXEDNORMAL;
-	    }
-	  break;
-
-	case XP_THEME_ELEMENT_PRESSED_CHECKBOX:
-	case XP_THEME_ELEMENT_PRESSED_RADIO_BUTTON:
-	    switch (state)
-		{
-		case GTK_STATE_SELECTED:
-		    ret = CBS_CHECKEDPRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = CBS_CHECKEDHOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = CBS_CHECKEDDISABLED;
-		    break;
-		default:
-		    ret = CBS_CHECKEDNORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_DEFAULT_BUTTON:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = PBS_PRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = PBS_HOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = PBS_DISABLED;
-		    break;
-		default:
-		    ret = PBS_DEFAULTED;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_SPIN_BUTTON_DOWN:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = DNS_PRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = DNS_HOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = DNS_DISABLED;
-		    break;
-		default:
-		    ret = DNS_NORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_SPIN_BUTTON_UP:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = UPS_PRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = UPS_HOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = UPS_DISABLED;
-		    break;
-		default:
-		    ret = UPS_NORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_OPENED:
-	    ret = GLPS_OPENED;
-	    break;
-
-	case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_CLOSED:
-	    ret = GLPS_CLOSED;
-	    break;
-
-	case XP_THEME_ELEMENT_PROGRESS_BAR_H:
-	case XP_THEME_ELEMENT_PROGRESS_BAR_V:
-	case XP_THEME_ELEMENT_PROGRESS_TROUGH_H:
-	case XP_THEME_ELEMENT_PROGRESS_TROUGH_V:
-	    ret = 1;
-	    break;
-
-	case XP_THEME_ELEMENT_MENU_ITEM:
-	case XP_THEME_ELEMENT_MENU_SEPARATOR:
-	    switch (state)
-		{
-		case GTK_STATE_SELECTED:
-		    ret = MS_SELECTED;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = MS_DEMOTED;
-		    break;
-		default:
-		    ret = MS_NORMAL;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_LINE_H:
-	    switch (state)
-		{
-		    /* LHS_FLAT, LHS_RAISED, LHS_SUNKEN */
-		    ret = LHS_RAISED;
-		    break;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_LINE_V:
-	    switch (state)
-		{
-		    /* LVS_FLAT, LVS_RAISED, LVS_SUNKEN */
-		    ret = LVS_RAISED;
-		    break;
-		}
-	    break;
-
-	case XP_THEME_ELEMENT_SCALE_TROUGH_H:
-	case XP_THEME_ELEMENT_SCALE_TROUGH_V:
-	    ret = TRS_NORMAL;
-	    break;
-
-	default:
-	    switch (state)
-		{
-		case GTK_STATE_ACTIVE:
-		    ret = PBS_PRESSED;
-		    break;
-		case GTK_STATE_PRELIGHT:
-		    ret = PBS_HOT;
-		    break;
-		case GTK_STATE_INSENSITIVE:
-		    ret = PBS_DISABLED;
-		    break;
-		default:
-		    ret = PBS_NORMAL;
-		}
+	case GTK_STATE_PRELIGHT:
+	  ret = TIS_HOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = TIS_DISABLED;
+	  break;
+
+	case GTK_STATE_SELECTED:
+	case GTK_STATE_ACTIVE:
+	  ret = TIS_NORMAL;
+	  break;
+
+	default:
+	  ret = TIS_SELECTED;
 	}
-    return ret;
-}
+      break;
 
-gboolean
-xp_theme_draw (GdkWindow * win, XpThemeElement element, GtkStyle * style,
-	       int x, int y, int width, int height,
-	       GtkStateType state_type, GdkRectangle * area)
-{
-    HTHEME theme;
-    RECT rect, clip, *pClip;
-    int xoff, yoff;
-    HDC dc;
-    GdkDrawable *drawable;
-    int part_state;
+    case XP_THEME_ELEMENT_EDIT_TEXT:
+      switch (state)
+	{
+	case GTK_STATE_PRELIGHT:
+	  ret = ETS_FOCUSED;
+	  break;
 
-    if (!xp_theme_is_drawable (element))
-	return FALSE;
+	case GTK_STATE_INSENSITIVE:
+	  ret = ETS_READONLY;
+	  break;
 
-    theme = xp_theme_get_handle_by_element (element);
-    if (!theme)
-	return FALSE;
+	case GTK_STATE_SELECTED:
+	case GTK_STATE_ACTIVE:
+	default:
+	  ret = ETS_NORMAL;
+	}
+      break;
 
-    /* FIXME: Recheck its function */
-    enable_theme_dialog_texture_func (GDK_WINDOW_HWND (win), ETDT_ENABLETAB);
+    case XP_THEME_ELEMENT_TROUGH_H:
+    case XP_THEME_ELEMENT_TROUGH_V:
+      ret = SCRBS_NORMAL;
+      break;
+
+    case XP_THEME_ELEMENT_SCROLLBAR_H:
+    case XP_THEME_ELEMENT_SCROLLBAR_V:
+      switch (state)
+	{
+	case GTK_STATE_SELECTED:
+	case GTK_STATE_ACTIVE:
+	  ret = SCRBS_PRESSED;
+	  break;
 
-    if (!GDK_IS_WINDOW (win))
+	case GTK_STATE_PRELIGHT:
+	  ret = SCRBS_HOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = SCRBS_DISABLED;
+	  break;
+
+	default:
+	  ret = SCRBS_NORMAL;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_ARROW_DOWN:
+      switch (state)
 	{
-	    xoff = 0;
-	    yoff = 0;
-	    drawable = win;
+	case GTK_STATE_ACTIVE:
+	  ret = ABS_DOWNPRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = ABS_DOWNHOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = ABS_DOWNDISABLED;
+	  break;
+
+	default:
+	  ret = ABS_DOWNNORMAL;
 	}
-    else
+      break;
+
+    case XP_THEME_ELEMENT_ARROW_UP:
+      switch (state)
 	{
-	    gdk_window_get_internal_paint_info (win, &drawable, &xoff, &yoff);
+	case GTK_STATE_ACTIVE:
+	  ret = ABS_UPPRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = ABS_UPHOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = ABS_UPDISABLED;
+	  break;
+
+	default:
+	  ret = ABS_UPNORMAL;
 	}
+      break;
+
+    case XP_THEME_ELEMENT_ARROW_LEFT:
+      switch (state)
+	{
+	case GTK_STATE_ACTIVE:
+	  ret = ABS_LEFTPRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = ABS_LEFTHOT;
+	  break;
 
-    rect.left = x - xoff;
-    rect.top = y - yoff;
-    rect.right = rect.left + width;
-    rect.bottom = rect.top + height;
+	case GTK_STATE_INSENSITIVE:
+	  ret = ABS_LEFTDISABLED;
+	  break;
+
+	default:
+	  ret = ABS_LEFTNORMAL;
+	}
+      break;
 
-    if (area)
+    case XP_THEME_ELEMENT_ARROW_RIGHT:
+      switch (state)
 	{
-	    clip.left = area->x - xoff;
-	    clip.top = area->y - yoff;
-	    clip.right = clip.left + area->width;
-	    clip.bottom = clip.top + area->height;
+	case GTK_STATE_ACTIVE:
+	  ret = ABS_RIGHTPRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = ABS_RIGHTHOT;
+	  break;
 
-	    pClip = &clip;
+	case GTK_STATE_INSENSITIVE:
+	  ret = ABS_RIGHTDISABLED;
+	  break;
+
+	default:
+	  ret = ABS_RIGHTNORMAL;
 	}
-    else
+      break;
+
+    case XP_THEME_ELEMENT_CHECKBOX:
+    case XP_THEME_ELEMENT_RADIO_BUTTON:
+      switch (state)
 	{
-	    pClip = NULL;
+	case GTK_STATE_SELECTED:
+	  ret = CBS_UNCHECKEDPRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = CBS_UNCHECKEDHOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = CBS_UNCHECKEDDISABLED;
+	  break;
+
+	default:
+	  ret = CBS_UNCHECKEDNORMAL;
 	}
+      break;
 
-    gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
-    dc = gdk_win32_hdc_get (drawable, style->dark_gc[state_type], 0);
-    if (!dc)
-	return FALSE;
+    case XP_THEME_ELEMENT_INCONSISTENT_CHECKBOX:
+      switch (state)
+	{
+	case GTK_STATE_SELECTED:
+	  ret = CBS_MIXEDPRESSED;
+	  break;
 
-    part_state = xp_theme_map_gtk_state (element, state_type);
+	case GTK_STATE_PRELIGHT:
+	  ret = CBS_MIXEDHOT;
+	  break;
 
-    draw_theme_background_func (theme, dc, element_part_map[element],
-				part_state, &rect, pClip);
-    gdk_win32_hdc_release (drawable, style->dark_gc[state_type], 0);
+	case GTK_STATE_INSENSITIVE:
+	  ret = CBS_MIXEDDISABLED;
+	  break;
+
+	default:
+	  ret = CBS_MIXEDNORMAL;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_PRESSED_CHECKBOX:
+    case XP_THEME_ELEMENT_PRESSED_RADIO_BUTTON:
+      switch (state)
+	{
+	case GTK_STATE_SELECTED:
+	  ret = CBS_CHECKEDPRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = CBS_CHECKEDHOT;
+	  break;
 
-    return TRUE;
+	case GTK_STATE_INSENSITIVE:
+	  ret = CBS_CHECKEDDISABLED;
+	  break;
+
+	default:
+	  ret = CBS_CHECKEDNORMAL;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_DEFAULT_BUTTON:
+      switch (state)
+	{
+	case GTK_STATE_ACTIVE:
+	  ret = PBS_PRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = PBS_HOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = PBS_DISABLED;
+	  break;
+
+	default:
+	  ret = PBS_DEFAULTED;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_SPIN_BUTTON_DOWN:
+      switch (state)
+	{
+	case GTK_STATE_ACTIVE:
+	  ret = DNS_PRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = DNS_HOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = DNS_DISABLED;
+	  break;
+
+	default:
+	  ret = DNS_NORMAL;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_SPIN_BUTTON_UP:
+      switch (state)
+	{
+	case GTK_STATE_ACTIVE:
+	  ret = UPS_PRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = UPS_HOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = UPS_DISABLED;
+	  break;
+
+	default:
+	  ret = UPS_NORMAL;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_OPENED:
+      ret = GLPS_OPENED;
+      break;
+
+    case XP_THEME_ELEMENT_TREEVIEW_EXPANDER_CLOSED:
+      ret = GLPS_CLOSED;
+      break;
+
+    case XP_THEME_ELEMENT_PROGRESS_BAR_H:
+    case XP_THEME_ELEMENT_PROGRESS_BAR_V:
+    case XP_THEME_ELEMENT_PROGRESS_TROUGH_H:
+    case XP_THEME_ELEMENT_PROGRESS_TROUGH_V:
+      ret = 1;
+      break;
+
+    case XP_THEME_ELEMENT_MENU_ITEM:
+    case XP_THEME_ELEMENT_MENU_SEPARATOR:
+      switch (state)
+	{
+	case GTK_STATE_SELECTED:
+	  ret = MS_SELECTED;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = MS_DEMOTED;
+	  break;
+
+	default:
+	  ret = MS_NORMAL;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_LINE_H:
+      switch (state)
+	{
+	  /* LHS_FLAT, LHS_RAISED, LHS_SUNKEN */
+	  ret = LHS_RAISED;
+	  break;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_LINE_V:
+      switch (state)
+	{
+	  /* LVS_FLAT, LVS_RAISED, LVS_SUNKEN */
+	  ret = LVS_RAISED;
+	  break;
+	}
+      break;
+
+    case XP_THEME_ELEMENT_SCALE_TROUGH_H:
+    case XP_THEME_ELEMENT_SCALE_TROUGH_V:
+      ret = TRS_NORMAL;
+      break;
+
+    default:
+      switch (state)
+	{
+	case GTK_STATE_ACTIVE:
+	  ret = PBS_PRESSED;
+	  break;
+
+	case GTK_STATE_PRELIGHT:
+	  ret = PBS_HOT;
+	  break;
+
+	case GTK_STATE_INSENSITIVE:
+	  ret = PBS_DISABLED;
+	  break;
+
+	default:
+	  ret = PBS_NORMAL;
+	}
+    }
+
+  return ret;
+}
+
+gboolean
+xp_theme_draw (GdkWindow *win, XpThemeElement element, GtkStyle *style,
+	       int x, int y, int width, int height,
+	       GtkStateType state_type, GdkRectangle *area)
+{
+  HTHEME theme;
+  RECT rect, clip, *pClip;
+  int xoff, yoff;
+  HDC dc;
+  GdkDrawable *drawable;
+  int part_state;
+
+  if (!xp_theme_is_drawable (element))
+    return FALSE;
+
+  theme = xp_theme_get_handle_by_element (element);
+  if (!theme)
+    return FALSE;
+
+  /* FIXME: Recheck its function */
+  enable_theme_dialog_texture_func (GDK_WINDOW_HWND (win), ETDT_ENABLETAB);
+
+  if (!GDK_IS_WINDOW (win))
+    {
+      xoff = 0;
+      yoff = 0;
+      drawable = win;
+    }
+  else
+    {
+      gdk_window_get_internal_paint_info (win, &drawable, &xoff, &yoff);
+    }
+
+  rect.left = x - xoff;
+  rect.top = y - yoff;
+  rect.right = rect.left + width;
+  rect.bottom = rect.top + height;
+
+  if (area)
+    {
+      clip.left = area->x - xoff;
+      clip.top = area->y - yoff;
+      clip.right = clip.left + area->width;
+      clip.bottom = clip.top + area->height;
+
+      pClip = &clip;
+    }
+  else
+    {
+      pClip = NULL;
+    }
+
+  gdk_gc_set_clip_rectangle (style->dark_gc[state_type], NULL);
+  dc = gdk_win32_hdc_get (drawable, style->dark_gc[state_type], 0);
+  if (!dc)
+    return FALSE;
+
+  part_state = xp_theme_map_gtk_state (element, state_type);
+
+  draw_theme_background_func (theme, dc, element_part_map[element],
+			      part_state, &rect, pClip);
+
+  gdk_win32_hdc_release (drawable, style->dark_gc[state_type], 0);
+
+  return TRUE;
 }
 
 gboolean
 xp_theme_is_active (void)
 {
-	return use_xp_theme;
+  return use_xp_theme;
 }
 
 gboolean
 xp_theme_is_drawable (XpThemeElement element)
 {
-    if (xp_theme_is_active ())
-	return (xp_theme_get_handle_by_element (element) != NULL);
+  if (xp_theme_is_active ())
+    return (xp_theme_get_handle_by_element (element) != NULL);
 
-    return FALSE;
+  return FALSE;
 }
 
 gboolean
 xp_theme_get_system_font (XpThemeClass klazz, XpThemeFont fontId,
-			  OUT LOGFONT * lf)
+			  OUT LOGFONT *lf)
 {
-    if (xp_theme_is_active () && get_theme_sys_font_func != NULL)
+  if (xp_theme_is_active () && get_theme_sys_font_func != NULL)
+    {
+      HTHEME theme = xp_theme_get_handle_by_class (klazz);
+      int themeFont;
+
+      if (!theme)
+	return FALSE;
+
+      switch (fontId)
 	{
-	    HTHEME theme = xp_theme_get_handle_by_class (klazz);
-	    int themeFont;
+	case XP_THEME_FONT_CAPTION:
+	  themeFont = TMT_CAPTIONFONT;
+	  break;
+
+	case XP_THEME_FONT_MENU:
+	  themeFont = TMT_MENUFONT;
+	  break;
 
-	    if (!theme)
-		return FALSE;
-
-	    switch (fontId)
-		{
-		case XP_THEME_FONT_CAPTION:
-		    themeFont = TMT_CAPTIONFONT;
-		    break;
-		case XP_THEME_FONT_MENU:
-		    themeFont = TMT_MENUFONT;
-		    break;
-		case XP_THEME_FONT_STATUS:
-		    themeFont = TMT_STATUSFONT;
-		    break;
-		case XP_THEME_FONT_MESSAGE:
-		default:
-		    themeFont = TMT_MSGBOXFONT;
-		    break;
-		}
-	    /* if theme is NULL, it will just return the GetSystemFont()
-	       value */
-	    return ((*get_theme_sys_font_func) (theme, themeFont, lf) ==
-		    S_OK);
+	case XP_THEME_FONT_STATUS:
+	  themeFont = TMT_STATUSFONT;
+	  break;
+
+	case XP_THEME_FONT_MESSAGE:
+	default:
+	  themeFont = TMT_MSGBOXFONT;
+	  break;
 	}
 
-    return FALSE;
+      /* if theme is NULL, it will just return the GetSystemFont()
+         value */
+      return ((*get_theme_sys_font_func) (theme, themeFont, lf) == S_OK);
+    }
+
+  return FALSE;
 }
 
 gboolean
 xp_theme_get_system_color (XpThemeClass klazz, int colorId,
-			   OUT DWORD * pColor)
+			   OUT DWORD *pColor)
 {
-    if (xp_theme_is_active () && get_theme_sys_color_func != NULL)
-	{
-	    HTHEME theme = xp_theme_get_handle_by_class (klazz);
-
-	    /* if theme is NULL, it will just return the GetSystemColor()
-	       value */
-	    *pColor = (*get_theme_sys_color_func) (theme, colorId);
-	    return TRUE;
-	}
+  if (xp_theme_is_active () && get_theme_sys_color_func != NULL)
+    {
+      HTHEME theme = xp_theme_get_handle_by_class (klazz);
+
+      /* if theme is NULL, it will just return the GetSystemColor()
+         value */
+      *pColor = (*get_theme_sys_color_func) (theme, colorId);
+      return TRUE;
+    }
 
-    return FALSE;
+  return FALSE;
 }
 
 gboolean
 xp_theme_get_system_metric (XpThemeClass klazz, int metricId, OUT int *pVal)
 {
-    if (xp_theme_is_active () && get_theme_sys_metric_func != NULL)
-	{
-	    HTHEME theme = xp_theme_get_handle_by_class (klazz);
-
-	    /* if theme is NULL, it will just return the GetSystemMetrics()
-	       value */
-	    *pVal = (*get_theme_sys_metric_func) (theme, metricId);
-	    return TRUE;
-	}
+  if (xp_theme_is_active () && get_theme_sys_metric_func != NULL)
+    {
+      HTHEME theme = xp_theme_get_handle_by_class (klazz);
+
+      /* if theme is NULL, it will just return the GetSystemMetrics()
+         value */
+      *pVal = (*get_theme_sys_metric_func) (theme, metricId);
+      return TRUE;
+    }
 
-    return FALSE;
+  return FALSE;
 }

Modified: trunk/modules/engines/ms-windows/xp_theme.h
==============================================================================
--- trunk/modules/engines/ms-windows/xp_theme.h	(original)
+++ trunk/modules/engines/ms-windows/xp_theme.h	Fri Feb  1 23:25:18 2008
@@ -122,8 +122,8 @@
                         GdkRectangle *area);
 gboolean xp_theme_is_drawable (XpThemeElement element);
 gboolean xp_theme_get_system_font (XpThemeClass klazz, XpThemeFont fontId, OUT LOGFONT *lf);
-gboolean xp_theme_get_system_color (XpThemeClass klazz, int colorId, OUT DWORD * pColor);
-gboolean xp_theme_get_system_metric (XpThemeClass klazz, int metricId, OUT int * pVal);
+gboolean xp_theme_get_system_color (XpThemeClass klazz, int colorId, OUT DWORD *pColor);
+gboolean xp_theme_get_system_metric (XpThemeClass klazz, int metricId, OUT int *pVal);
 
 gboolean xp_theme_is_active (void);
 

Modified: trunk/modules/engines/ms-windows/xp_theme_defs.h
==============================================================================
--- trunk/modules/engines/ms-windows/xp_theme_defs.h	(original)
+++ trunk/modules/engines/ms-windows/xp_theme_defs.h	Fri Feb  1 23:25:18 2008
@@ -33,226 +33,727 @@
 #define ETDT_USETABTEXTURE  0x00000004
 #define ETDT_ENABLETAB      (ETDT_ENABLE  | ETDT_USETABTEXTURE)
 
-enum  	{
-  BP_PUSHBUTTON = 1, BP_RADIOBUTTON = 2, BP_CHECKBOX = 3, BP_GROUPBOX = 4,
+enum {
+  BP_PUSHBUTTON = 1,
+  BP_RADIOBUTTON = 2,
+  BP_CHECKBOX = 3,
+  BP_GROUPBOX = 4,
   BP_USERBUTTON = 5
 };
-enum  	{
-  CBS_UNCHECKEDNORMAL = 1, CBS_UNCHECKEDHOT = 2, CBS_UNCHECKEDPRESSED = 3, CBS_UNCHECKEDDISABLED = 4,
-  CBS_CHECKEDNORMAL = 5, CBS_CHECKEDHOT = 6, CBS_CHECKEDPRESSED = 7, CBS_CHECKEDDISABLED = 8,
-  CBS_MIXEDNORMAL = 9, CBS_MIXEDHOT = 10, CBS_MIXEDPRESSED = 11, CBS_MIXEDDISABLED = 12
+
+enum {
+  CBS_UNCHECKEDNORMAL = 1,
+  CBS_UNCHECKEDHOT = 2,
+  CBS_UNCHECKEDPRESSED = 3,
+  CBS_UNCHECKEDDISABLED = 4,
+  CBS_CHECKEDNORMAL = 5,
+  CBS_CHECKEDHOT = 6,
+  CBS_CHECKEDPRESSED = 7,
+  CBS_CHECKEDDISABLED = 8,
+  CBS_MIXEDNORMAL = 9,
+  CBS_MIXEDHOT = 10,
+  CBS_MIXEDPRESSED = 11,
+  CBS_MIXEDDISABLED = 12
 };
-enum  	{ GBS_NORMAL = 1, GBS_DISABLED = 2 };;
+
+enum {
+  GBS_NORMAL = 1,
+  GBS_DISABLED = 2
+};
+
 enum  	{
-  PBS_NORMAL = 1, PBS_HOT = 2, PBS_PRESSED = 3, PBS_DISABLED = 4,
+  PBS_NORMAL = 1,
+  PBS_HOT = 2,
+  PBS_PRESSED = 3,
+  PBS_DISABLED = 4,
   PBS_DEFAULTED = 5
 };
-enum  	{
-  RBS_UNCHECKEDNORMAL = 1, RBS_UNCHECKEDHOT = 2, RBS_UNCHECKEDPRESSED = 3, RBS_UNCHECKEDDISABLED = 4,
-  RBS_CHECKEDNORMAL = 5, RBS_CHECKEDHOT = 6, RBS_CHECKEDPRESSED = 7, RBS_CHECKEDDISABLED = 8
+
+enum {
+  RBS_UNCHECKEDNORMAL = 1,
+  RBS_UNCHECKEDHOT = 2,
+  RBS_UNCHECKEDPRESSED = 3,
+  RBS_UNCHECKEDDISABLED = 4,
+  RBS_CHECKEDNORMAL = 5,
+  RBS_CHECKEDHOT = 6,
+  RBS_CHECKEDPRESSED = 7,
+  RBS_CHECKEDDISABLED = 8
 };
-enum  	{ CLP_TIME = 1 };
-enum  	{ CLS_NORMAL = 1 };
-enum  	{ CP_DROPDOWNBUTTON = 1 };
-enum  	{ CBXS_NORMAL = 1, CBXS_HOT = 2, CBXS_PRESSED = 3, CBXS_DISABLED = 4 };
-enum  	{ EP_EDITTEXT = 1, EP_CARET = 2 };
-enum  	{
-  ETS_NORMAL = 1, ETS_HOT = 2, ETS_SELECTED = 3, ETS_DISABLED = 4,
-  ETS_FOCUSED = 5, ETS_READONLY = 6, ETS_ASSIST = 7
+
+enum {
+  CLP_TIME = 1
 };
-enum  	{
-  EBP_HEADERBACKGROUND = 1, EBP_HEADERCLOSE = 2, EBP_HEADERPIN = 3, EBP_IEBARMENU = 4,
-  EBP_NORMALGROUPBACKGROUND = 5, EBP_NORMALGROUPCOLLAPSE = 6, EBP_NORMALGROUPEXPAND = 7, EBP_NORMALGROUPHEAD = 8,
-  EBP_SPECIALGROUPBACKGROUND = 9, EBP_SPECIALGROUPCOLLAPSE = 10, EBP_SPECIALGROUPEXPAND = 11, EBP_SPECIALGROUPHEAD = 12
+
+enum {
+  CLS_NORMAL = 1
 };
-enum  	{ EBHC_NORMAL = 1, EBHC_HOT = 2, EBHC_PRESSED = 3 };
-enum  	{
-  EBHP_NORMAL = 1, EBHP_HOT = 2, EBHP_PRESSED = 3, EBHP_SELECTEDNORMAL = 4,
-  EBHP_SELECTEDHOT = 5, EBHP_SELECTEDPRESSED = 6
+
+enum {
+  CP_DROPDOWNBUTTON = 1
 };
-enum  	{ EBM_NORMAL = 1, EBM_HOT = 2, EBM_PRESSED = 3 };
-enum  	{ EBNGC_NORMAL = 1, EBNGC_HOT = 2, EBNGC_PRESSED = 3 };
-enum  	{ EBNGE_NORMAL = 1, EBNGE_HOT = 2, EBNGE_PRESSED = 3 };
-enum  	{ EBSGC_NORMAL = 1, EBSGC_HOT = 2, EBSGC_PRESSED = 3 };
-enum  	{ EBSGE_NORMAL = 1, EBSGE_HOT = 2, EBSGE_PRESSED = 3 };
-enum  	{ HP_HEADERITEM = 1, HP_HEADERITEMLEFT = 2, HP_HEADERITEMRIGHT = 3, HP_HEADERSORTARROW = 4 };
-enum  	{ HIS_NORMAL = 1, HIS_HOT = 2, HIS_PRESSED = 3 };
-enum  	{ HILS_NORMAL = 1, HILS_HOT = 2, HILS_PRESSED = 3 };
-enum  	{ HIRS_NORMAL = 1, HIRS_HOT = 2, HIRS_PRESSED = 3 };
-enum  	{ HSAS_SORTEDUP = 1, HSAS_SORTEDDOWN = 2 };
-enum  	{
-  LVP_LISTITEM = 1, LVP_LISTGROUP = 2, LVP_LISTDETAIL = 3, LVP_LISTSORTEDDETAIL = 4,
+
+enum {
+  CBXS_NORMAL = 1,
+  CBXS_HOT = 2,
+  CBXS_PRESSED = 3,
+  CBXS_DISABLED = 4
+};
+
+enum {
+  EP_EDITTEXT = 1,
+  EP_CARET = 2
+};
+
+enum {
+  ETS_NORMAL = 1,
+  ETS_HOT = 2,
+  ETS_SELECTED = 3,
+  ETS_DISABLED = 4,
+  ETS_FOCUSED = 5,
+  ETS_READONLY = 6,
+  ETS_ASSIST = 7
+};
+
+enum {
+  EBP_HEADERBACKGROUND = 1,
+  EBP_HEADERCLOSE = 2,
+  EBP_HEADERPIN = 3,
+  EBP_IEBARMENU = 4, 
+  EBP_NORMALGROUPBACKGROUND = 5,
+  EBP_NORMALGROUPCOLLAPSE = 6,
+  EBP_NORMALGROUPEXPAND = 7,
+  EBP_NORMALGROUPHEAD = 8,
+  EBP_SPECIALGROUPBACKGROUND = 9,
+  EBP_SPECIALGROUPCOLLAPSE = 10,
+  EBP_SPECIALGROUPEXPAND = 11,
+  EBP_SPECIALGROUPHEAD = 12
+};
+
+enum {
+  EBHC_NORMAL = 1,
+  EBHC_HOT = 2,
+  EBHC_PRESSED = 3
+};
+
+enum {
+  EBHP_NORMAL = 1,
+  EBHP_HOT = 2,
+  EBHP_PRESSED = 3,
+  EBHP_SELECTEDNORMAL = 4,
+  EBHP_SELECTEDHOT = 5,
+  EBHP_SELECTEDPRESSED = 6
+};
+
+enum {
+  EBM_NORMAL = 1,
+  EBM_HOT = 2,
+  EBM_PRESSED = 3
+};
+
+enum {
+  EBNGC_NORMAL = 1,
+  EBNGC_HOT = 2,
+  EBNGC_PRESSED = 3
+};
+
+enum {
+  EBNGE_NORMAL = 1,
+  EBNGE_HOT = 2,
+  EBNGE_PRESSED = 3
+};
+
+enum {
+  EBSGC_NORMAL = 1,
+  EBSGC_HOT = 2,
+  EBSGC_PRESSED = 3
+};
+
+enum {
+  EBSGE_NORMAL = 1,
+  EBSGE_HOT = 2,
+  EBSGE_PRESSED = 3
+};
+
+enum {
+  HP_HEADERITEM = 1,
+  HP_HEADERITEMLEFT = 2,
+  HP_HEADERITEMRIGHT = 3,
+  HP_HEADERSORTARROW = 4
+};
+
+enum {
+  HIS_NORMAL = 1,
+  HIS_HOT = 2,
+  HIS_PRESSED = 3
+};
+
+enum {
+  HILS_NORMAL = 1,
+  HILS_HOT = 2,
+  HILS_PRESSED = 3
+};
+
+enum {
+  HIRS_NORMAL = 1,
+  HIRS_HOT = 2,
+  HIRS_PRESSED = 3
+};
+
+enum {
+  HSAS_SORTEDUP = 1,
+  HSAS_SORTEDDOWN = 2
+};
+
+enum {
+  LVP_LISTITEM = 1,
+  LVP_LISTGROUP = 2,
+  LVP_LISTDETAIL = 3,
+  LVP_LISTSORTEDDETAIL = 4,
   LVP_EMPTYTEXT = 5
 };
-enum  	{
-  LIS_NORMAL = 1, LIS_HOT = 2, LIS_SELECTED = 3, LIS_DISABLED = 4,
+
+enum {
+  LIS_NORMAL = 1,
+  LIS_HOT = 2,
+  LIS_SELECTED = 3,
+  LIS_DISABLED = 4,
   LIS_SELECTEDNOTFOCUS = 5
 };
-enum  	{
-  MP_MENUITEM = 1, MP_MENUDROPDOWN = 2, MP_MENUBARITEM = 3, MP_MENUBARDROPDOWN = 4,
-  MP_CHEVRON = 5, MP_SEPARATOR = 6
+
+enum {
+  MP_MENUITEM = 1,
+  MP_MENUDROPDOWN = 2,
+  MP_MENUBARITEM = 3,
+  MP_MENUBARDROPDOWN = 4,
+  MP_CHEVRON = 5,
+  MP_SEPARATOR = 6
 };
-enum  	{ MS_NORMAL = 1, MS_SELECTED = 2, MS_DEMOTED = 3 };
-enum  	{ MDP_NEWAPPBUTTON = 1, MDP_SEPERATOR = 2 };
-enum  	{
-  MDS_NORMAL = 1, MDS_HOT = 2, MDS_PRESSED = 3, MDS_DISABLED = 4,
-  MDS_CHECKED = 5, MDS_HOTCHECKED = 6
+
+enum {
+  MS_NORMAL = 1,
+  MS_SELECTED = 2,
+  MS_DEMOTED = 3
 };
-enum  	{ PGRP_UP = 1, PGRP_DOWN = 2, PGRP_UPHORZ = 3, PGRP_DOWNHORZ = 4 };
-enum  	{ DNS_NORMAL = 1, DNS_HOT = 2, DNS_PRESSED = 3, DNS_DISABLED = 4 };
-enum  	{ DNHZS_NORMAL = 1, DNHZS_HOT = 2, DNHZS_PRESSED = 3, DNHZS_DISABLED = 4 };
-enum  	{ UPS_NORMAL = 1, UPS_HOT = 2, UPS_PRESSED = 3, UPS_DISABLED = 4 };
-enum  	{ UPHZS_NORMAL = 1, UPHZS_HOT = 2, UPHZS_PRESSED = 3, UPHZS_DISABLED = 4 };
-enum  	{ PP_BAR = 1, PP_BARVERT = 2, PP_CHUNK = 3, PP_CHUNKVERT = 4 };
-enum  	{
-  RP_GRIPPER = 1, RP_GRIPPERVERT = 2, RP_BAND = 3, RP_CHEVRON = 4,
+
+enum {
+  MDP_NEWAPPBUTTON = 1,
+  MDP_SEPERATOR = 2
+};
+
+enum {
+  MDS_NORMAL = 1,
+  MDS_HOT = 2,
+  MDS_PRESSED = 3,
+  MDS_DISABLED = 4,
+  MDS_CHECKED = 5,
+  MDS_HOTCHECKED = 6
+};
+
+enum {
+  PGRP_UP = 1,
+  PGRP_DOWN = 2,
+  PGRP_UPHORZ = 3,
+  PGRP_DOWNHORZ = 4
+};
+
+enum {
+  DNS_NORMAL = 1,
+  DNS_HOT = 2,
+  DNS_PRESSED = 3,
+  DNS_DISABLED = 4
+};
+
+enum {
+  DNHZS_NORMAL = 1,
+  DNHZS_HOT = 2,
+  DNHZS_PRESSED = 3,
+  DNHZS_DISABLED = 4
+};
+
+enum {
+  UPS_NORMAL = 1,
+  UPS_HOT = 2,
+  UPS_PRESSED = 3,
+  UPS_DISABLED = 4
+};
+
+enum {
+  UPHZS_NORMAL = 1,
+  UPHZS_HOT = 2,
+  UPHZS_PRESSED = 3,
+  UPHZS_DISABLED = 4
+};
+
+enum {
+  PP_BAR = 1,
+  PP_BARVERT = 2,
+  PP_CHUNK = 3,
+  PP_CHUNKVERT = 4
+};
+
+enum {
+  RP_GRIPPER = 1,
+  RP_GRIPPERVERT = 2,
+  RP_BAND = 3,
+  RP_CHEVRON = 4,
   RP_CHEVRONVERT = 5
 };
-enum  	{ CHEVS_NORMAL = 1, CHEVS_HOT = 2, CHEVS_PRESSED = 3 };
-enum  	{
-  SBP_ARROWBTN = 1, SBP_THUMBBTNHORZ = 2, SBP_THUMBBTNVERT = 3, SBP_LOWERTRACKHORZ = 4,
-  SBP_UPPERTRACKHORZ = 5, SBP_LOWERTRACKVERT = 6, SBP_UPPERTRACKVERT = 7, SBP_GRIPPERHORZ = 8,
-  SBP_GRIPPERVERT = 9, SBP_SIZEBOX = 10
+
+enum {
+  CHEVS_NORMAL = 1,
+  CHEVS_HOT = 2,
+  CHEVS_PRESSED = 3
 };
-enum  	{
-  ABS_UPNORMAL = 1, ABS_UPHOT = 2, ABS_UPPRESSED = 3, ABS_UPDISABLED = 4,
-  ABS_DOWNNORMAL = 5, ABS_DOWNHOT = 6, ABS_DOWNPRESSED = 7, ABS_DOWNDISABLED = 8,
-  ABS_LEFTNORMAL = 9, ABS_LEFTHOT = 10, ABS_LEFTPRESSED = 11, ABS_LEFTDISABLED = 12,
-  ABS_RIGHTNORMAL = 13, ABS_RIGHTHOT = 14, ABS_RIGHTPRESSED = 15, ABS_RIGHTDISABLED = 16
-};
-enum  	{ SCRBS_NORMAL = 1, SCRBS_HOT = 2, SCRBS_PRESSED = 3, SCRBS_DISABLED = 4 };
-enum  	{ SZB_RIGHTALIGN = 1, SZB_LEFTALIGN = 2 };
-enum  	{ SPNP_UP = 1, SPNP_DOWN = 2, SPNP_UPHORZ = 3, SPNP_DOWNHORZ = 4 };
-enum  	{
-  SPP_USERPANE = 1, SPP_MOREPROGRAMS = 2, SPP_MOREPROGRAMSARROW = 3, SPP_PROGLIST = 4,
-  SPP_PROGLISTSEPARATOR = 5, SPP_PLACESLIST = 6, SPP_PLACESLISTSEPARATOR = 7, SPP_LOGOFF = 8,
-  SPP_LOGOFFBUTTONS = 9, SPP_USERPICTURE = 10, SPP_PREVIEW = 11
-};
-enum  	{ SPLS_NORMAL = 1, SPLS_HOT = 2, SPLS_PRESSED = 3 };
-enum  	{ SPS_NORMAL = 1, SPS_HOT = 2, SPS_PRESSED = 3 };
-enum  	{ SP_PANE = 1, SP_GRIPPERPANE = 2, SP_GRIPPER = 3 };
-enum  	{
-  TABP_TABITEM = 1, TABP_TABITEMLEFTEDGE = 2, TABP_TABITEMRIGHTEDGE = 3, TABP_TABITEMBOTHEDGE = 4,
-  TABP_TOPTABITEM = 5, TABP_TOPTABITEMLEFTEDGE = 6, TABP_TOPTABITEMRIGHTEDGE = 7, TABP_TOPTABITEMBOTHEDGE = 8,
-  TABP_PANE = 9, TABP_BODY = 10
+
+enum {
+  SBP_ARROWBTN = 1,
+  SBP_THUMBBTNHORZ = 2,
+  SBP_THUMBBTNVERT = 3,
+  SBP_LOWERTRACKHORZ = 4,
+  SBP_UPPERTRACKHORZ = 5,
+  SBP_LOWERTRACKVERT = 6,
+  SBP_UPPERTRACKVERT = 7,
+  SBP_GRIPPERHORZ = 8,
+  SBP_GRIPPERVERT = 9,
+  SBP_SIZEBOX = 10
 };
-enum  	{
-  TIS_NORMAL = 1, TIS_HOT = 2, TIS_SELECTED = 3, TIS_DISABLED = 4,
+
+enum {
+  ABS_UPNORMAL = 1,
+  ABS_UPHOT = 2,
+  ABS_UPPRESSED = 3,
+  ABS_UPDISABLED = 4,
+  ABS_DOWNNORMAL = 5,
+  ABS_DOWNHOT = 6,
+  ABS_DOWNPRESSED = 7,
+  ABS_DOWNDISABLED = 8,
+  ABS_LEFTNORMAL = 9,
+  ABS_LEFTHOT = 10,
+  ABS_LEFTPRESSED = 11,
+  ABS_LEFTDISABLED = 12,
+  ABS_RIGHTNORMAL = 13,
+  ABS_RIGHTHOT = 14,
+  ABS_RIGHTPRESSED = 15,
+  ABS_RIGHTDISABLED = 16
+};
+
+enum {
+  SCRBS_NORMAL = 1,
+  SCRBS_HOT = 2,
+  SCRBS_PRESSED = 3,
+  SCRBS_DISABLED = 4
+};
+
+enum {
+  SZB_RIGHTALIGN = 1,
+  SZB_LEFTALIGN = 2
+};
+
+enum {
+  SPNP_UP = 1,
+  SPNP_DOWN = 2,
+  SPNP_UPHORZ = 3,
+  SPNP_DOWNHORZ = 4
+};
+
+enum {
+  SPP_USERPANE = 1,
+  SPP_MOREPROGRAMS = 2,
+  SPP_MOREPROGRAMSARROW = 3,
+  SPP_PROGLIST = 4,
+  SPP_PROGLISTSEPARATOR = 5,
+  SPP_PLACESLIST = 6,
+  SPP_PLACESLISTSEPARATOR = 7,
+  SPP_LOGOFF = 8,
+  SPP_LOGOFFBUTTONS = 9,
+  SPP_USERPICTURE = 10,
+  SPP_PREVIEW = 11
+};
+
+enum {
+  SPLS_NORMAL = 1,
+  SPLS_HOT = 2,
+  SPLS_PRESSED = 3
+};
+
+enum {
+  SPS_NORMAL = 1,
+  SPS_HOT = 2,
+  SPS_PRESSED = 3
+};
+
+enum {
+  SP_PANE = 1,
+  SP_GRIPPERPANE = 2,
+  SP_GRIPPER = 3
+};
+
+enum {
+  TABP_TABITEM = 1,
+  TABP_TABITEMLEFTEDGE = 2,
+  TABP_TABITEMRIGHTEDGE = 3,
+  TABP_TABITEMBOTHEDGE = 4,
+  TABP_TOPTABITEM = 5,
+  TABP_TOPTABITEMLEFTEDGE = 6,
+  TABP_TOPTABITEMRIGHTEDGE = 7,
+  TABP_TOPTABITEMBOTHEDGE = 8,
+  TABP_PANE = 9,
+  TABP_BODY = 10
+};
+
+enum {
+  TIS_NORMAL = 1,
+  TIS_HOT = 2,
+  TIS_SELECTED = 3,
+  TIS_DISABLED = 4,
   TIS_FOCUSED = 5
 };
-enum  	{
-  TIBES_NORMAL = 1, TIBES_HOT = 2, TIBES_SELECTED = 3, TIBES_DISABLED = 4,
+
+enum {
+  TIBES_NORMAL = 1,
+  TIBES_HOT = 2,
+  TIBES_SELECTED = 3,
+  TIBES_DISABLED = 4,
   TIBES_FOCUSED = 5
 };
-enum  	{
-  TILES_NORMAL = 1, TILES_HOT = 2, TILES_SELECTED = 3, TILES_DISABLED = 4,
+
+enum {
+  TILES_NORMAL = 1,
+  TILES_HOT = 2,
+  TILES_SELECTED = 3,
+  TILES_DISABLED = 4,
   TILES_FOCUSED = 5
 };
-enum  	{
-  TIRES_NORMAL = 1, TIRES_HOT = 2, TIRES_SELECTED = 3, TIRES_DISABLED = 4,
+
+enum {
+  TIRES_NORMAL = 1,
+  TIRES_HOT = 2,
+  TIRES_SELECTED = 3,
+  TIRES_DISABLED = 4,
   TIRES_FOCUSED = 5
 };
-enum  	{
-  TTIS_NORMAL = 1, TTIS_HOT = 2, TTIS_SELECTED = 3, TTIS_DISABLED = 4,
+
+enum {
+  TTIS_NORMAL = 1,
+  TTIS_HOT = 2,
+  TTIS_SELECTED = 3,
+  TTIS_DISABLED = 4,
   TTIS_FOCUSED = 5
 };
-enum  	{
-  TTIBES_NORMAL = 1, TTIBES_HOT = 2, TTIBES_SELECTED = 3, TTIBES_DISABLED = 4,
+
+enum {
+  TTIBES_NORMAL = 1,
+  TTIBES_HOT = 2,
+  TTIBES_SELECTED = 3,
+  TTIBES_DISABLED = 4,
   TTIBES_FOCUSED = 5
 };
-enum  	{
-  TTILES_NORMAL = 1, TTILES_HOT = 2, TTILES_SELECTED = 3, TTILES_DISABLED = 4,
+
+enum {
+  TTILES_NORMAL = 1,
+  TTILES_HOT = 2,
+  TTILES_SELECTED = 3,
+  TTILES_DISABLED = 4,
   TTILES_FOCUSED = 5
 };
-enum  	{
-  TTIRES_NORMAL = 1, TTIRES_HOT = 2, TTIRES_SELECTED = 3, TTIRES_DISABLED = 4,
+
+enum {
+  TTIRES_NORMAL = 1,
+  TTIRES_HOT = 2,
+  TTIRES_SELECTED = 3,
+  TTIRES_DISABLED = 4,
   TTIRES_FOCUSED = 5
 };
-enum  	{ TDP_GROUPCOUNT = 1, TDP_FLASHBUTTON = 2, TDP_FLASHBUTTONGROUPMENU = 3 };
-enum  	{
-  TBP_BACKGROUNDBOTTOM = 1, TBP_BACKGROUNDRIGHT = 2, TBP_BACKGROUNDTOP = 3, TBP_BACKGROUNDLEFT = 4,
-  TBP_SIZINGBARBOTTOM = 5, TBP_SIZINGBARRIGHT = 6, TBP_SIZINGBARTOP = 7, TBP_SIZINGBARLEFT = 8
+
+enum {
+  TDP_GROUPCOUNT = 1,
+  TDP_FLASHBUTTON = 2,
+  TDP_FLASHBUTTONGROUPMENU = 3
 };
-enum  	{
-  TP_BUTTON = 1, TP_DROPDOWNBUTTON = 2, TP_SPLITBUTTON = 3, TP_SPLITBUTTONDROPDOWN = 4,
-  TP_SEPARATOR = 5, TP_SEPARATORVERT = 6
+
+enum {
+  TBP_BACKGROUNDBOTTOM = 1,
+  TBP_BACKGROUNDRIGHT = 2,
+  TBP_BACKGROUNDTOP = 3,
+  TBP_BACKGROUNDLEFT = 4,
+  TBP_SIZINGBARBOTTOM = 5,
+  TBP_SIZINGBARRIGHT = 6,
+  TBP_SIZINGBARTOP = 7,
+  TBP_SIZINGBARLEFT = 8
 };
-enum  	{
-  TS_NORMAL = 1, TS_HOT = 2, TS_PRESSED = 3, TS_DISABLED = 4,
-  TS_CHECKED = 5, TS_HOTCHECKED = 6
+
+enum {
+  TP_BUTTON = 1,
+  TP_DROPDOWNBUTTON = 2,
+  TP_SPLITBUTTON = 3,
+  TP_SPLITBUTTONDROPDOWN = 4,
+  TP_SEPARATOR = 5,
+  TP_SEPARATORVERT = 6
 };
-enum  	{
-  TTP_STANDARD = 1, TTP_STANDARDTITLE = 2, TTP_BALLOON = 3, TTP_BALLOONTITLE = 4,
+
+enum {
+  TS_NORMAL = 1,
+  TS_HOT = 2,
+  TS_PRESSED = 3,
+  TS_DISABLED = 4,
+  TS_CHECKED = 5,
+  TS_HOTCHECKED = 6
+};
+
+enum {
+  TTP_STANDARD = 1,
+  TTP_STANDARDTITLE = 2,
+  TTP_BALLOON = 3,
+  TTP_BALLOONTITLE = 4,
   TTP_CLOSE = 5
 };
-enum  	{ TTBS_NORMAL = 1, TTBS_LINK = 2 };
-enum  	{ TTCS_NORMAL = 1, TTCS_HOT = 2, TTCS_PRESSED = 3 };
-enum  	{ TTSS_NORMAL = 1, TTSS_LINK = 2 };
-enum  	{
-  TKP_TRACK = 1, TKP_TRACKVERT = 2, TKP_THUMB = 3, TKP_THUMBBOTTOM = 4,
-  TKP_THUMBTOP = 5, TKP_THUMBVERT = 6, TKP_THUMBLEFT = 7, TKP_THUMBRIGHT = 8,
+
+enum {
+  TTBS_NORMAL = 1,
+  TTBS_LINK = 2
+};
+
+enum {
+  TTCS_NORMAL = 1,
+  TTCS_HOT = 2,
+  TTCS_PRESSED = 3
+};
+
+enum {
+  TTSS_NORMAL = 1,
+  TTSS_LINK = 2
+};
+
+enum {
+  TKP_TRACK = 1,
+  TKP_TRACKVERT = 2,
+  TKP_THUMB = 3,
+  TKP_THUMBBOTTOM = 4,
+  TKP_THUMBTOP = 5,
+  TKP_THUMBVERT = 6,
+  TKP_THUMBLEFT = 7,
+  TKP_THUMBRIGHT = 8,
   TKP_TICS = 9, TKP_TICSVERT = 10
 };
-enum  	{
-  TUS_NORMAL = 1, TUS_HOT = 2, TUS_PRESSED = 3, TUS_FOCUSED = 4,
+
+enum {
+  TUS_NORMAL = 1,
+  TUS_HOT = 2,
+  TUS_PRESSED = 3,
+  TUS_FOCUSED = 4,
   TUS_DISABLED = 5
 };
-enum  	{
-  TUBS_NORMAL = 1, TUBS_HOT = 2, TUBS_PRESSED = 3, TUBS_FOCUSED = 4,
+
+enum {
+  TUBS_NORMAL = 1,
+  TUBS_HOT = 2,
+  TUBS_PRESSED = 3,
+  TUBS_FOCUSED = 4,
   TUBS_DISABLED = 5
 };
-enum  	{
-  TUVLS_NORMAL = 1, TUVLS_HOT = 2, TUVLS_PRESSED = 3, TUVLS_FOCUSED = 4,
+
+enum {
+  TUVLS_NORMAL = 1,
+  TUVLS_HOT = 2,
+  TUVLS_PRESSED = 3,
+  TUVLS_FOCUSED = 4,
   TUVLS_DISABLED = 5
 };
-enum  	{
-  TUVRS_NORMAL = 1, TUVRS_HOT = 2, TUVRS_PRESSED = 3, TUVRS_FOCUSED = 4,
+
+enum {
+  TUVRS_NORMAL = 1,
+  TUVRS_HOT = 2,
+  TUVRS_PRESSED = 3,
+  TUVRS_FOCUSED = 4,
   TUVRS_DISABLED = 5
 };
-enum  	{
-  TUTS_NORMAL = 1, TUTS_HOT = 2, TUTS_PRESSED = 3, TUTS_FOCUSED = 4,
+
+enum {
+  TUTS_NORMAL = 1,
+  TUTS_HOT = 2,
+  TUTS_PRESSED = 3,
+  TUTS_FOCUSED = 4,
   TUTS_DISABLED = 5
 };
-enum  	{
-  TUVS_NORMAL = 1, TUVS_HOT = 2, TUVS_PRESSED = 3, TUVS_FOCUSED = 4,
+
+enum {
+  TUVS_NORMAL = 1,
+  TUVS_HOT = 2,
+  TUVS_PRESSED = 3,
+  TUVS_FOCUSED = 4,
   TUVS_DISABLED = 5
 };
-enum  	{ TSS_NORMAL = 1 };
-enum  	{ TSVS_NORMAL = 1 };
-enum  	{ TRS_NORMAL = 1 };
-enum  	{ TRVS_NORMAL = 1 };
-enum  	{ TNP_BACKGROUND = 1, TNP_ANIMBACKGROUND = 2 };
-enum  	{ TVP_TREEITEM = 1, TVP_GLYPH = 2, TVP_BRANCH = 3 };
-enum  	{ GLPS_CLOSED = 1, GLPS_OPENED = 2 };
-enum  	{
-  TREIS_NORMAL = 1, TREIS_HOT = 2, TREIS_SELECTED = 3, TREIS_DISABLED = 4,
+
+enum {
+  TSS_NORMAL = 1
+};
+
+enum {
+  TSVS_NORMAL = 1
+};
+
+enum {
+  TRS_NORMAL = 1
+};
+
+enum {
+  TRVS_NORMAL = 1
+};
+
+enum {
+  TNP_BACKGROUND = 1,
+  TNP_ANIMBACKGROUND = 2
+};
+
+enum {
+  TVP_TREEITEM = 1,
+  TVP_GLYPH = 2,
+  TVP_BRANCH = 3
+};
+
+enum {
+  GLPS_CLOSED = 1,
+  GLPS_OPENED = 2
+};
+
+enum {
+  TREIS_NORMAL = 1,
+  TREIS_HOT = 2,
+  TREIS_SELECTED = 3,
+  TREIS_DISABLED = 4,
   TREIS_SELECTEDNOTFOCUS = 5
 };
-enum  	{
-  WP_CAPTION = 1, WP_SMALLCAPTION = 2, WP_MINCAPTION = 3, WP_SMALLMINCAPTION = 4,
-  WP_MAXCAPTION = 5, WP_SMALLMAXCAPTION = 6, WP_FRAMELEFT = 7, WP_FRAMERIGHT = 8,
-  WP_FRAMEBOTTOM = 9, WP_SMALLFRAMELEFT = 10, WP_SMALLFRAMERIGHT = 11, WP_SMALLFRAMEBOTTOM = 12,
-  WP_SYSBUTTON = 13, WP_MDISYSBUTTON = 14, WP_MINBUTTON = 15, WP_MDIMINBUTTON = 16,
-  WP_MAXBUTTON = 17, WP_CLOSEBUTTON = 18, WP_SMALLCLOSEBUTTON = 19, WP_MDICLOSEBUTTON = 20,
-  WP_RESTOREBUTTON = 21, WP_MDIRESTOREBUTTON = 22, WP_HELPBUTTON = 23, WP_MDIHELPBUTTON = 24,
-  WP_HORZSCROLL = 25, WP_HORZTHUMB = 26, WP_VERTSCROLL = 27, WP_VERTTHUMB = 28,
-  WP_DIALOG = 29, WP_CAPTIONSIZINGTEMPLATE = 30, WP_SMALLCAPTIONSIZINGTEMPLATE = 31, WP_FRAMELEFTSIZINGTEMPLATE = 32,
-  WP_SMALLFRAMELEFTSIZINGTEMPLATE = 33, WP_FRAMERIGHTSIZINGTEMPLATE = 34, WP_SMALLFRAMERIGHTSIZINGTEMPLATE = 35, WP_FRAMEBOTTOMSIZINGTEMPLATE = 36,
+enum {
+  WP_CAPTION = 1,
+  WP_SMALLCAPTION = 2,
+  WP_MINCAPTION = 3,
+  WP_SMALLMINCAPTION = 4,
+  WP_MAXCAPTION = 5,
+  WP_SMALLMAXCAPTION = 6,
+  WP_FRAMELEFT = 7,
+  WP_FRAMERIGHT = 8,
+  WP_FRAMEBOTTOM = 9,
+  WP_SMALLFRAMELEFT = 10,
+  WP_SMALLFRAMERIGHT = 11,
+  WP_SMALLFRAMEBOTTOM = 12,
+  WP_SYSBUTTON = 13,
+  WP_MDISYSBUTTON = 14,
+  WP_MINBUTTON = 15,
+  WP_MDIMINBUTTON = 16,
+  WP_MAXBUTTON = 17,
+  WP_CLOSEBUTTON = 18,
+  WP_SMALLCLOSEBUTTON = 19,
+  WP_MDICLOSEBUTTON = 20,
+  WP_RESTOREBUTTON = 21,
+  WP_MDIRESTOREBUTTON = 22,
+  WP_HELPBUTTON = 23,
+  WP_MDIHELPBUTTON = 24,
+  WP_HORZSCROLL = 25,
+  WP_HORZTHUMB = 26,
+  WP_VERTSCROLL = 27,
+  WP_VERTTHUMB = 28,
+  WP_DIALOG = 29,
+  WP_CAPTIONSIZINGTEMPLATE = 30,
+  WP_SMALLCAPTIONSIZINGTEMPLATE = 31,
+  WP_FRAMELEFTSIZINGTEMPLATE = 32,
+  WP_SMALLFRAMELEFTSIZINGTEMPLATE = 33,
+  WP_FRAMERIGHTSIZINGTEMPLATE = 34,
+  WP_SMALLFRAMERIGHTSIZINGTEMPLATE = 35, 
+  WP_FRAMEBOTTOMSIZINGTEMPLATE = 36,
   WP_SMALLFRAMEBOTTOMSIZINGTEMPLATE = 37
 };
-enum  	{ CS_ACTIVE = 1, CS_INACTIVE = 2, CS_DISABLED = 3 };
-enum  	{ CBS_NORMAL = 1, CBS_HOT = 2, CBS_PUSHED = 3, CBS_DISABLED = 4 };
-enum  	{ FS_ACTIVE = 1, FS_INACTIVE = 2 };
-enum  	{ HBS_NORMAL = 1, HBS_HOT = 2, HBS_PUSHED = 3, HBS_DISABLED = 4 };
-enum  	{ HSS_NORMAL = 1, HSS_HOT = 2, HSS_PUSHED = 3, HSS_DISABLED = 4 };
-enum  	{ HTS_NORMAL = 1, HTS_HOT = 2, HTS_PUSHED = 3, HTS_DISABLED = 4 };
-enum  	{ MAXBS_NORMAL = 1, MAXBS_HOT = 2, MAXBS_PUSHED = 3, MAXBS_DISABLED = 4 };
-enum  	{ MXCS_ACTIVE = 1, MXCS_INACTIVE = 2, MXCS_DISABLED = 3 };
-enum  	{ MINBS_NORMAL = 1, MINBS_HOT = 2, MINBS_PUSHED = 3, MINBS_DISABLED = 4 };
-enum  	{ RBS_NORMAL = 1, RBS_HOT = 2, RBS_PUSHED = 3, RBS_DISABLED = 4 };
-enum  	{ SBS_NORMAL = 1, SBS_HOT = 2, SBS_PUSHED = 3, SBS_DISABLED = 4 };
-enum  	{ MNCS_ACTIVE = 1, MNCS_INACTIVE = 2, MNCS_DISABLED = 3 };
-enum  	{ VSS_NORMAL = 1, VSS_HOT = 2, VSS_PUSHED = 3, VSS_DISABLED = 4 };
-enum  	{ VTS_NORMAL = 1, VTS_HOT = 2, VTS_PUSHED = 3, VTS_DISABLED = 4 };
+
+enum {
+  CS_ACTIVE = 1,
+  CS_INACTIVE = 2,
+  CS_DISABLED = 3
+};
+
+enum {
+  CBS_NORMAL = 1,
+  CBS_HOT = 2,
+  CBS_PUSHED = 3,
+  CBS_DISABLED = 4
+};
+
+enum {
+  FS_ACTIVE = 1,
+  FS_INACTIVE = 2
+};
+
+enum {
+  HBS_NORMAL = 1,
+  HBS_HOT = 2,
+  HBS_PUSHED = 3,
+  HBS_DISABLED = 4
+};
+
+enum {
+  HSS_NORMAL = 1,
+  HSS_HOT = 2,
+  HSS_PUSHED = 3,
+  HSS_DISABLED = 4
+};
+
+enum {
+  HTS_NORMAL = 1,
+  HTS_HOT = 2,
+  HTS_PUSHED = 3,
+  HTS_DISABLED = 4
+};
+
+enum {
+  MAXBS_NORMAL = 1,
+  MAXBS_HOT = 2,
+  MAXBS_PUSHED = 3,
+  MAXBS_DISABLED = 4
+};
+
+enum {
+  MXCS_ACTIVE = 1,
+  MXCS_INACTIVE = 2,
+  MXCS_DISABLED = 3
+};
+
+enum {
+  MINBS_NORMAL = 1,
+  MINBS_HOT = 2,
+  MINBS_PUSHED = 3,
+  MINBS_DISABLED = 4
+};
+
+enum {
+  RBS_NORMAL = 1,
+  RBS_HOT = 2,
+  RBS_PUSHED = 3,
+  RBS_DISABLED = 4
+};
+
+enum {
+  SBS_NORMAL = 1,
+  SBS_HOT = 2,
+  SBS_PUSHED = 3,
+  SBS_DISABLED = 4
+};
+
+enum {
+  MNCS_ACTIVE = 1,
+  MNCS_INACTIVE = 2,
+  MNCS_DISABLED = 3
+};
+
+enum {
+  VSS_NORMAL = 1,
+  VSS_HOT = 2,
+  VSS_PUSHED = 3,
+  VSS_DISABLED = 4
+};
+
+enum {
+  VTS_NORMAL = 1,
+  VTS_HOT = 2,
+  VTS_PUSHED = 3,
+  VTS_DISABLED = 4
+};
 
 #endif /* XP_THEME_DFNS_H */



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]