]> git.deb.at Git - pkg/abook.git/blob - list.c
removed unnecessary wstandend call
[pkg/abook.git] / list.c
1
2 /*
3  * $Id$
4  *
5  * by JH <jheinonen@users.sourceforge.net>
6  *
7  * Copyright (C) Jaakko Heinonen
8  */
9
10 #include <stdio.h>
11 #include <string.h>
12 #include <assert.h>
13 #include "abook.h"
14 #include "ui.h"
15 #include "database.h"
16 #include "edit.h"
17 #include "list.h"
18 #include "misc.h"
19 #include "options.h"
20
21 #define MIN_EXTRA_COLUMN        ADDRESS /* 2 */
22 #define MAX_EXTRA_COLUMN        LAST_FIELD
23
24 int curitem = -1;
25 int first_list_item = -1;
26 char *selected = NULL;
27
28 int extra_column = -1;
29 int extra_alternative = -1;
30
31 extern int items;
32 extern list_item *database;
33 extern struct abook_field abook_fields[];
34
35 WINDOW *list = NULL;
36
37 static int
38 init_extra_field(char *option_name)
39 {
40         int i, ret = -1;
41         char *option_str;
42
43         assert(option_name != NULL);
44         
45         option_str = options_get_str(option_name);
46
47         if(option_str && *option_str) {
48                 for(i = 0; i < ITEM_FIELDS; i++) {
49                         if(!strcasecmp(option_str, abook_fields[i].key)) {
50                                 ret = i;
51                                 break;
52                         }
53                 }
54                 if(ret < MIN_EXTRA_COLUMN || ret > MAX_EXTRA_COLUMN) {
55                         ret = -1;
56                 }
57         }
58
59         return ret;
60 }
61
62 void
63 init_list()
64 {
65         list = newwin(LIST_LINES, LIST_COLS, LIST_TOP, 0);
66         scrollok(list, TRUE);
67
68         /*
69          * init extra_column and extra alternative
70          */
71
72         extra_column = init_extra_field("extra_column");
73         extra_alternative = init_extra_field("extra_alternative");
74 }
75
76 void
77 close_list()
78 {
79         delwin(list);
80         list = NULL;
81 }
82
83 void
84 refresh_list()
85 {
86         int i, line;
87         
88         werase(list);
89
90         ui_print_number_of_items();
91         
92         if( items < 1 ) {
93                 refresh();
94                 wrefresh(list);
95                 return;
96         }
97         
98         if(curitem < 0)
99                 curitem = 0;
100
101         if(first_list_item < 0)
102                 first_list_item = 0;
103
104         if(curitem < first_list_item)
105                 first_list_item = curitem;
106         else if(curitem > LAST_LIST_ITEM)
107                 first_list_item = max(curitem - LIST_LINES + 1, 0);
108
109         for( line = 0, i = first_list_item ; i <= LAST_LIST_ITEM && i < items;
110                         line++, i++ ) {
111
112                 print_list_line(i, line, i == curitem);
113         }
114
115         wrefresh(list);
116 }
117
118 void
119 print_list_line(int i, int line, int highlight)
120 {
121         int extra = extra_column;
122         char tmp[MAX_EMAILSTR_LEN];
123         int real_emaillen = (extra_column > 0 || extra_alternative > 0) ?
124                 EMAILLEN : COLS - EMAILPOS;
125
126         scrollok(list, FALSE);
127         if(highlight)
128                 highlight_line(list, line);
129
130         if( selected[i] )
131                 mvwaddch(list, line, 0, '*' );
132         
133         mvwaddnstr(list, line, NAMEPOS, database[i][NAME], NAMELEN);
134         if( options_get_int( "show_all_emails"  ) )
135                 mvwaddnstr(list, line, EMAILPOS, database[i][EMAIL],
136                                 real_emaillen);
137         else {
138                 get_first_email(tmp, i);
139                 mvwaddnstr(list, line, EMAILPOS, tmp, real_emaillen);
140         }
141
142         if(extra < 0 || !database[i][extra])
143                 extra = extra_alternative;
144         if(extra >= 0)
145                 mvwaddnstr(list, line, EXTRAPOS,
146                                 safe_str(database[i][extra]),
147                                 EXTRALEN);
148
149         scrollok(list, TRUE);
150         if(highlight_line)
151                 wstandend(list);
152 }
153         
154
155 void
156 list_headerline()
157 {
158         attrset(A_BOLD);
159         mvaddstr(2, NAMEPOS, abook_fields[NAME].name);
160         mvaddstr(2, EMAILPOS, abook_fields[EMAIL].name);
161         if(extra_column > 0)
162                 mvaddnstr(2, EXTRAPOS, abook_fields[extra_column].name,
163                                 COLS-EXTRAPOS);
164         attrset(A_NORMAL);
165 }
166
167 void
168 scroll_up()
169 {
170         if( curitem < 1 )
171                 return;
172
173         curitem--;
174
175         refresh_list();
176 }
177
178 void
179 scroll_down()
180 {
181         if( curitem > items - 2 )
182                 return;
183
184         curitem++;
185
186         refresh_list();
187 }
188
189
190 void
191 page_up()
192 {
193         if( curitem < 1 )
194                 return;
195         
196         curitem = curitem == first_list_item ?
197                 ((curitem -= LIST_LINES) < 0 ? 0 : curitem) : first_list_item;
198         
199         refresh_list();
200 }
201
202 void
203 page_down()
204 {
205         if( curitem > items - 2 )
206                 return;
207
208         curitem = curitem == LAST_LIST_ITEM ?
209                 ((curitem += LIST_LINES) > LAST_ITEM ? LAST_ITEM : curitem) :
210                 min(LAST_LIST_ITEM, LAST_ITEM);
211
212         refresh_list();
213 }
214
215
216 void
217 select_none()
218 {
219         memset( selected, 0, items );
220 }
221
222 void
223 select_all()
224 {
225         memset( selected, 1, items );
226 }
227
228 void
229 move_curitem(int direction)
230 {
231         list_item tmp;
232
233         if( curitem < 0 || curitem > LAST_ITEM )
234                 return;
235
236         itemcpy(tmp, database[curitem]);
237
238         switch(direction) {
239                 case MOVE_ITEM_UP:
240                         if( curitem < 1 )
241                                 return;
242                         itemcpy(database[curitem], database[curitem - 1]);
243                         itemcpy(database[curitem-1], tmp);
244                         scroll_up();
245                         break;
246
247                 case MOVE_ITEM_DOWN:
248                         if( curitem >= LAST_ITEM )
249                                 return;
250                         itemcpy(database[curitem], database[curitem + 1]);
251                         itemcpy(database[curitem+1], tmp);
252                         scroll_down();
253                         break;
254         }
255 }
256
257 void
258 goto_home()
259 {
260         if(items > 0)
261                 curitem = 0;
262         
263         refresh_list();
264 }
265
266 void
267 goto_end()
268 {
269         if(items > 0)
270                 curitem = LAST_ITEM;
271
272         refresh_list();
273 }
274
275
276 void
277 highlight_line(WINDOW *win, int line)
278 {
279         wstandout(win);
280         
281 #ifdef mvwchgat
282         mvwchgat(win, line, 0, -1,  A_STANDOUT, 0, NULL);
283 #else
284         /*
285          * buggy function: FIXME
286          */
287         scrollok(win, FALSE);
288         {
289                 int i;
290                 wmove(win, line, 0);
291                 for(i = 0; i < COLS; i++)
292                         waddch(win, ' ');
293         /*wattrset(win, 0);*/
294         }
295         scrollok(win, TRUE);
296 #endif
297 }
298
299 int
300 selected_items()
301 {
302         int i, n = 0;
303
304         for(i = 0; i < items; i++)
305                 if(selected[i])
306                         n++;
307
308         return n;
309 }
310
311 void
312 invert_selection()
313 {
314         int i;
315
316         if( items < 1 )
317                 return;
318
319         for(i = 0; i < items; i++)
320                 selected[i] = !selected[i];
321 }
322
323 int
324 list_current_item()
325 {
326         return curitem;
327 }
328
329 int
330 list_is_empty()
331 {
332         return items < 1;
333 }
334
335