--- rxvt-unicode/src/scrollbar-plain.C 2004/01/31 04:20:20 1.2 +++ rxvt-unicode/src/scrollbar-plain.C 2004/08/23 19:57:33 1.13 @@ -1,9 +1,10 @@ -/*--------------------------------*-C-*---------------------------------* - * File: scrollbar-plain.c +/*----------------------------------------------------------------------* + * File: scrollbar-plain.C *----------------------------------------------------------------------* * * Copyright (c) 1997,1998 mj olesen * Copyright (c) 1999-2001 Geoff Wing + * Copyright (c) 2004 Marc Lehmann * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -22,45 +23,50 @@ #include "../config.h" /* NECESSARY */ #include "rxvt.h" /* NECESSARY */ -#include "scrollbar-plain.intpro" /* PROTOS for internal routines */ /*----------------------------------------------------------------------*/ #if defined(PLAIN_SCROLLBAR) int -rxvt_term::scrollbar_show_plain (int update __attribute__((unused)), int last_top, int last_bot, int scrollbar_len) +rxvt_term::scrollbar_show_plain (int update, int last_top, int last_bot, int scrollbar_len) { - int xsb = 0; - int sbwidth = scrollBar.width - 1; + int xsb = 0; + int sbwidth = scrollBar.width - 1; - if ((scrollBar.init & R_SB_PLAIN) == 0) { - XGCValues gcvalue; + if ((scrollBar.init & R_SB_PLAIN) == 0) + { + XGCValues gcvalue; - scrollBar.init |= R_SB_PLAIN; - gcvalue.foreground = PixColors[Color_fg]; - gcvalue.background = PixColors[Color_bg]; - - pscrollbarGC = XCreateGC(Xdisplay, scrollBar.win, - GCForeground | GCBackground - | GCFillStyle, &gcvalue); + scrollBar.init |= R_SB_PLAIN; + gcvalue.foreground = pix_colors_focused[Color_scroll]; + + pscrollbarGC = XCreateGC (display->display, scrollBar.win, + GCForeground, &gcvalue); + } + + xsb = (options & Opt_scrollBar_right) ? 1 : 0; + + if (update) + { + if (last_top < scrollBar.top) + XClearArea (display->display, scrollBar.win, + sb_shadow + xsb, last_top, + sbwidth + 1, (scrollBar.top - last_top), False); + + if (scrollBar.bot < last_bot) + XClearArea (display->display, scrollBar.win, + sb_shadow + xsb, scrollBar.bot, + sbwidth + 1, (last_bot - scrollBar.bot), False); } -/* instead of XClearWindow (Xdisplay, scrollBar.win); */ - xsb = (Options & Opt_scrollBar_right) ? 1 : 0; - if (last_top < scrollBar.top) - XClearArea(Xdisplay, scrollBar.win, - sb_shadow + xsb, last_top, - sbwidth + 1, (scrollBar.top - last_top), False); - - if (scrollBar.bot < last_bot) - XClearArea(Xdisplay, scrollBar.win, - sb_shadow + xsb, scrollBar.bot, - sbwidth + 1, (last_bot - scrollBar.bot), False); - -/* scrollbar slider */ - XFillRectangle(Xdisplay, scrollBar.win, pscrollbarGC, - xsb + 1, scrollBar.top, sbwidth, scrollbar_len); + else + XClearWindow (display->display, scrollBar.win); - return 1; + /* scrollbar slider */ + XFillRectangle (display->display, scrollBar.win, pscrollbarGC, + xsb + 1, scrollBar.top, sbwidth, scrollbar_len); + + return 1; } -#endif /* XTERM_SCROLLBAR */ -/*----------------------- end-of-file (C source) -----------------------*/ + +#endif +