diff options
author | Benjamin Poirier <bpoirier@suse.de> | 2012-08-23 14:55:07 -0400 |
---|---|---|
committer | Michal Marek <mmarek@suse.cz> | 2012-09-27 12:09:24 -0400 |
commit | 1a374ae6191e9c440f1953a264a94d38173737be (patch) | |
tree | d242376e9d1d57e824e9b8c14a71ef5b446ee495 | |
parent | 5e609addb1bd963ce1a1929f2012c8dd04ca8620 (diff) |
menuconfig: Do not open code textbox scroll up/down
We don't need to explicitely use ncurses' scroll(). ncurses performs
vertical-motion optimization at wrefresh() time.
Using strace I confirmed that with the following patch curses still sends only
the new line of text to the terminal when scrolling up/down one line at a
time.
Signed-off-by: Benjamin Poirier <bpoirier@suse.de>
Signed-off-by: Michal Marek <mmarek@suse.cz>
-rw-r--r-- | scripts/kconfig/lxdialog/textbox.c | 55 |
1 files changed, 11 insertions, 44 deletions
diff --git a/scripts/kconfig/lxdialog/textbox.c b/scripts/kconfig/lxdialog/textbox.c index 506a095c387..3b3c5c470bf 100644 --- a/scripts/kconfig/lxdialog/textbox.c +++ b/scripts/kconfig/lxdialog/textbox.c | |||
@@ -166,40 +166,12 @@ do_resize: | |||
166 | case 'K': /* Previous line */ | 166 | case 'K': /* Previous line */ |
167 | case 'k': | 167 | case 'k': |
168 | case KEY_UP: | 168 | case KEY_UP: |
169 | if (!begin_reached) { | 169 | if (begin_reached) |
170 | int passed_end = 0; | 170 | break; |
171 | |||
172 | back_lines(page_length + 1); | ||
173 | |||
174 | /* We don't call print_page() here but use | ||
175 | * scrolling to ensure faster screen update. | ||
176 | * However, 'end_reached' and 'page_length' | ||
177 | * should still be updated, and 'page' should | ||
178 | * point to start of next page. This is done | ||
179 | * by calling get_line() in the following | ||
180 | * 'for' loop. */ | ||
181 | scrollok(box, TRUE); | ||
182 | wscrl(box, -1); /* Scroll box region down one line */ | ||
183 | scrollok(box, FALSE); | ||
184 | page_length = 0; | ||
185 | for (i = 0; i < boxh; i++) { | ||
186 | if (!i) { | ||
187 | /* print first line of page */ | ||
188 | print_line(box, 0, boxw); | ||
189 | wnoutrefresh(box); | ||
190 | } else | ||
191 | /* Called to update 'end_reached' and 'page' */ | ||
192 | get_line(); | ||
193 | if (!passed_end) | ||
194 | page_length++; | ||
195 | if (end_reached && !passed_end) | ||
196 | passed_end = 1; | ||
197 | } | ||
198 | 171 | ||
199 | print_position(dialog); | 172 | back_lines(page_length + 1); |
200 | wmove(dialog, cur_y, cur_x); /* Restore cursor position */ | 173 | refresh_text_box(dialog, box, boxh, boxw, cur_y, |
201 | wrefresh(dialog); | 174 | cur_x); |
202 | } | ||
203 | break; | 175 | break; |
204 | case 'B': /* Previous page */ | 176 | case 'B': /* Previous page */ |
205 | case 'b': | 177 | case 'b': |
@@ -214,17 +186,12 @@ do_resize: | |||
214 | case 'J': /* Next line */ | 186 | case 'J': /* Next line */ |
215 | case 'j': | 187 | case 'j': |
216 | case KEY_DOWN: | 188 | case KEY_DOWN: |
217 | if (!end_reached) { | 189 | if (end_reached) |
218 | begin_reached = 0; | 190 | break; |
219 | scrollok(box, TRUE); | 191 | |
220 | scroll(box); /* Scroll box region up one line */ | 192 | back_lines(page_length - 1); |
221 | scrollok(box, FALSE); | 193 | refresh_text_box(dialog, box, boxh, boxw, cur_y, |
222 | print_line(box, boxh - 1, boxw); | 194 | cur_x); |
223 | wnoutrefresh(box); | ||
224 | print_position(dialog); | ||
225 | wmove(dialog, cur_y, cur_x); /* Restore cursor position */ | ||
226 | wrefresh(dialog); | ||
227 | } | ||
228 | break; | 195 | break; |
229 | case KEY_NPAGE: /* Next page */ | 196 | case KEY_NPAGE: /* Next page */ |
230 | case ' ': | 197 | case ' ': |