ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/scrollbar.C
(Generate patch)

Comparing rxvt-unicode/src/scrollbar.C (file contents):
Revision 1.42 by ayin, Sat Dec 29 14:43:44 2007 UTC vs.
Revision 1.46 by ayin, Wed Jan 2 08:24:39 2008 UTC

145rxvt_term::scrollbar_show (int update) 145rxvt_term::scrollbar_show (int update)
146{ 146{
147 int ret = 0; 147 int ret = 0;
148#ifdef HAVE_SCROLLBARS 148#ifdef HAVE_SCROLLBARS
149 int top, bot, len, adj; 149 int top, bot, len, adj;
150 int scrollbar_len = 0;
151 150
152 if (!scrollBar.state) 151 if (!scrollBar.state)
153 return 0; 152 return 0;
154 153
155 if (update) 154 if (update)
158 bot = top + (nrow - 1); 157 bot = top + (nrow - 1);
159 len = max (nrow - 1 - top_row, 1); 158 len = max (nrow - 1 - top_row, 1);
160 adj = (((bot - top) * scrollbar_size ()) % len) > 0 ? 1 : 0; 159 adj = (((bot - top) * scrollbar_size ()) % len) > 0 ? 1 : 0;
161 160
162 scrollBar.top = (scrollBar.beg + (top * scrollbar_size ()) / len); 161 scrollBar.top = (scrollBar.beg + (top * scrollbar_size ()) / len);
163 scrollbar_len = ((bot - top) * scrollbar_size ()) / len + 162 scrollBar.len = ((bot - top) * scrollbar_size ()) / len +
164 scrollbar_minheight () + adj; 163 scrollbar_minheight () + adj;
165 scrollBar.bot = (scrollBar.top + scrollbar_len); 164 scrollBar.bot = (scrollBar.top + scrollBar.len);
166 /* no change */ 165 /* no change */
167 if (scrollBar.top == last_top 166 if (scrollBar.top == scrollBar.last_top
168 && scrollBar.bot == last_bot 167 && scrollBar.bot == scrollBar.last_bot
169 && (scrollBar.state == last_state || !scrollbar_isUpDn ())) 168 && (scrollBar.state == scrollBar.last_state || !scrollbar_isUpDn ()))
170 return 0; 169 return 0;
171 } 170 }
172 171
173 ret = (this->*scrollBar.update) (update, last_top, last_bot, scrollbar_len); 172 ret = (this->*scrollBar.update) (update, scrollBar.last_top, scrollBar.last_bot, scrollBar.len);
174 173
175 last_top = scrollBar.top; 174 scrollBar.last_top = scrollBar.top;
176 last_bot = scrollBar.bot; 175 scrollBar.last_bot = scrollBar.bot;
177 last_state = scrollBar.state; 176 scrollBar.last_state = scrollBar.state;
178#endif 177#endif
179 178
180 return ret; 179 return ret;
181} 180}
182 181
236# endif 235# endif
237 236
238 scrollBar.style = style; 237 scrollBar.style = style;
239 scrollBar.width = width; 238 scrollBar.width = width;
240 239
241 /* scrollbar_align = R_SB_ALIGN_CENTRE; */ 240 /* scrollBar.align = R_SB_ALIGN_CENTRE; */
242 if (scrollalign) 241 if (scrollalign)
243 { 242 {
244 if (strncasecmp (scrollalign, "top", 3) == 0) 243 if (strncasecmp (scrollalign, "top", 3) == 0)
245 scrollbar_align = R_SB_ALIGN_TOP; 244 scrollBar.align = R_SB_ALIGN_TOP;
246 else if (strncasecmp (scrollalign, "bottom", 6) == 0) 245 else if (strncasecmp (scrollalign, "bottom", 6) == 0)
247 scrollbar_align = R_SB_ALIGN_BOTTOM; 246 scrollBar.align = R_SB_ALIGN_BOTTOM;
248 } 247 }
248 scrollBar.last_bot = scrollBar.last_state = -1;
249#endif 249#endif
250} 250}
251 251
252/*----------------------- end-of-file (C source) -----------------------*/ 252/*----------------------- end-of-file (C source) -----------------------*/
253 253

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines