]> git.deb.at Git - pkg/abook.git/blob - list.c
cleanup
[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                 wstandend(list);
115         }
116
117         wrefresh(list);
118 }
119
120 void
121 print_list_line(int i, int line, int highlight)
122 {
123         int extra = extra_column;
124         char tmp[MAX_EMAILSTR_LEN];
125         int real_emaillen = (extra_column > 0 || extra_alternative > 0) ?
126                 EMAILLEN : COLS - EMAILPOS;
127
128         scrollok(list, FALSE);
129         if(highlight)
130                 highlight_line(list, line);
131
132         if( selected[i] )
133                 mvwaddch(list, line, 0, '*' );
134         
135         mvwaddnstr(list, line, NAMEPOS, database[i][NAME], NAMELEN);
136         if( options_get_int( "show_all_emails"  ) )
137                 mvwaddnstr(list, line, EMAILPOS, database[i][EMAIL],
138                                 real_emaillen);
139         else {
140                 get_first_email(tmp, i);
141                 mvwaddnstr(list, line, EMAILPOS, tmp, real_emaillen);
142         }
143
144         if(extra < 0 || !database[i][extra])
145                 extra = extra_alternative;
146         if(extra >= 0)
147                 mvwaddnstr(list, line, EXTRAPOS,
148                                 safe_str(database[i][extra]),
149                                 EXTRALEN);
150
151         scrollok(list, TRUE);
152         if(highlight_line)
153                 wstandend(list);
154 }
155         
156
157 void
158 list_headerline()
159 {
160         attrset(A_BOLD);
161         mvaddstr(2, NAMEPOS, abook_fields[NAME].name);
162         mvaddstr(2, EMAILPOS, abook_fields[EMAIL].name);
163         if(extra_column > 0)
164                 mvaddnstr(2, EXTRAPOS, abook_fields[extra_column].name,
165                                 COLS-EXTRAPOS);
166         attrset(A_NORMAL);
167 }
168
169 void
170 scroll_up()
171 {
172         if( curitem < 1 )
173                 return;
174
175         curitem--;
176
177         refresh_list();
178 }
179
180 void
181 scroll_down()
182 {
183         if( curitem > items - 2 )
184                 return;
185
186         curitem++;
187
188         refresh_list();
189 }
190
191
192 void
193 page_up()
194 {
195         if( curitem < 1 )
196                 return;
197         
198         curitem = curitem == first_list_item ?
199                 ((curitem -= LIST_LINES) < 0 ? 0 : curitem) : first_list_item;
200         
201         refresh_list();
202 }
203
204 void
205 page_down()
206 {
207         if( curitem > items - 2 )
208                 return;
209
210         curitem = curitem == LAST_LIST_ITEM ?
211                 ((curitem += LIST_LINES) > LAST_ITEM ? LAST_ITEM : curitem) :
212                 min(LAST_LIST_ITEM, LAST_ITEM);
213
214         refresh_list();
215 }
216
217
218 void
219 select_none()
220 {
221         memset( selected, 0, items );
222 }
223
224 void
225 select_all()
226 {
227         memset( selected, 1, items );
228 }
229
230 void
231 move_curitem(int direction)
232 {
233         list_item tmp;
234
235         if( curitem < 0 || curitem > LAST_ITEM )
236                 return;
237
238         itemcpy(tmp, database[curitem]);
239
240         switch(direction) {
241                 case MOVE_ITEM_UP:
242                         if( curitem < 1 )
243                                 return;
244                         itemcpy(database[curitem], database[curitem - 1]);
245                         itemcpy(database[curitem-1], tmp);
246                         scroll_up();
247                         break;
248
249                 case MOVE_ITEM_DOWN:
250                         if( curitem >= LAST_ITEM )
251                                 return;
252                         itemcpy(database[curitem], database[curitem + 1]);
253                         itemcpy(database[curitem+1], tmp);
254                         scroll_down();
255                         break;
256         }
257 }
258
259 void
260 goto_home()
261 {
262         if(items > 0)
263                 curitem = 0;
264         
265         refresh_list();
266 }
267
268 void
269 goto_end()
270 {
271         if(items > 0)
272                 curitem = LAST_ITEM;
273
274         refresh_list();
275 }
276
277
278 void
279 highlight_line(WINDOW *win, int line)
280 {
281         wstandout(win);
282         
283 #ifdef mvwchgat
284         mvwchgat(win, line, 0, -1,  A_STANDOUT, 0, NULL);
285 #else
286         /*
287          * buggy function: FIXME
288          */
289         scrollok(win, FALSE);
290         {
291                 int i;
292                 wmove(win, line, 0);
293                 for(i = 0; i < COLS; i++)
294                         waddch(win, ' ');
295         /*wattrset(win, 0);*/
296         }
297         scrollok(win, TRUE);
298 #endif
299 }
300
301 int
302 selected_items()
303 {
304         int i, n = 0;
305
306         for(i = 0; i < items; i++)
307                 if(selected[i])
308                         n++;
309
310         return n;
311 }
312
313 void
314 invert_selection()
315 {
316         int i;
317
318         if( items < 1 )
319                 return;
320
321         for(i = 0; i < items; i++)
322                 selected[i] = !selected[i];
323 }
324
325 int
326 list_current_item()
327 {
328         return curitem;
329 }
330
331 int
332 list_is_empty()
333 {
334         return items < 1;
335 }
336
337