/*
* $Id$
*
- * by JH <jheinonen@bigfoot.com>
+ * by JH <jheinonen@users.sourceforge.net>
*
* Copyright (C) Jaakko Heinonen
*/
#include <stdio.h>
#include <string.h>
#include "abook.h"
+#include <assert.h>
#include "ui.h"
#include "database.h"
#include "edit.h"
#include "misc.h"
#include "options.h"
+#define MIN_EXTRA_COLUMN ADDRESS /* 2 */
+#define MAX_EXTRA_COLUMN LAST_FIELD
+
int curitem = -1;
int first_list_item = -1;
char *selected = NULL;
+int extra_column = -1;
+int extra_alternative = -1;
+
extern int items;
extern list_item *database;
extern struct abook_field abook_fields[];
WINDOW *list = NULL;
+static int
+init_extra_field(enum str_opts option)
+{
+ int i, ret = -1;
+ char *option_str;
+
+ option_str = opt_get_str(option);
+
+ if(option_str && *option_str) {
+ for(i = 0; i < ITEM_FIELDS; i++) {
+ if(!strcasecmp(option_str, abook_fields[i].key)) {
+ ret = i;
+ break;
+ }
+ }
+ if(ret < MIN_EXTRA_COLUMN || ret > MAX_EXTRA_COLUMN) {
+ ret = -1;
+ }
+ }
+
+ return ret;
+}
+
void
init_list()
{
list = newwin(LIST_LINES, LIST_COLS, LIST_TOP, 0);
scrollok(list, TRUE);
+
+ /*
+ * init extra_column and extra alternative
+ */
+
+ extra_column = init_extra_field(STR_EXTRA_COLUMN);
+ extra_alternative = init_extra_field(STR_EXTRA_ALTERNATIVE);
}
void
for( line = 0, i = first_list_item ; i <= LAST_LIST_ITEM && i < items;
line++, i++ ) {
- if(i == curitem)
- highlight_line(list, line);
-
- print_list_line(i, line);
-
- wstandend(list);
+ print_list_line(i, line, i == curitem);
}
wrefresh(list);
}
void
-print_list_line(int i, int line)
+print_list_line(int i, int line, int highlight)
{
+ int extra = extra_column;
char tmp[MAX_EMAILSTR_LEN];
- int extra_column = options_get_int("extra_column");
- int real_emaillen = (extra_column > 2 && extra_column < ITEM_FIELDS) ?
- EMAILLEN : EMAILPOS - COLS;
+ int real_emaillen = (extra_column > 0 || extra_alternative > 0) ?
+ EMAILLEN : COLS - EMAILPOS;
scrollok(list, FALSE);
+ if(highlight)
+ highlight_line(list, line);
if( selected[i] )
mvwaddch(list, line, 0, '*' );
mvwaddnstr(list, line, NAMEPOS, database[i][NAME], NAMELEN);
- if( options_get_int( "show_all_emails" ) )
+ if( opt_get_bool(BOOL_SHOW_ALL_EMAILS) )
mvwaddnstr(list, line, EMAILPOS, database[i][EMAIL],
real_emaillen);
else {
mvwaddnstr(list, line, EMAILPOS, tmp, real_emaillen);
}
- if(extra_column > 2 && extra_column < ITEM_FIELDS) {
- if( !database[i][extra_column] ) {
- int extra_alternative =
- options_get_int("extra_alternative");
-
- if(extra_alternative > 2 &&
- extra_alternative < ITEM_FIELDS)
- extra_column = extra_alternative;
- }
+ if(extra < 0 || !database[i][extra])
+ extra = extra_alternative;
+ if(extra >= 0)
mvwaddnstr(list, line, EXTRAPOS,
- safe_str(database[i][extra_column]),
+ safe_str(database[i][extra]),
EXTRALEN);
- }
scrollok(list, TRUE);
+ if(highlight)
+ wstandend(list);
}
void
list_headerline()
{
- int extra_column = options_get_int("extra_column");
-
+#ifdef A_BOLD
attrset(A_BOLD);
+#else
+ /* hmm, maybe something here */
+#endif
mvaddstr(2, NAMEPOS, abook_fields[NAME].name);
mvaddstr(2, EMAILPOS, abook_fields[EMAIL].name);
- if( extra_column > 2 && extra_column < ITEM_FIELDS )
+ if(extra_column > 0)
mvaddnstr(2, EXTRAPOS, abook_fields[extra_column].name,
COLS-EXTRAPOS);
+#ifdef A_BOLD
attrset(A_NORMAL);
+#endif
}
void
highlight_line(WINDOW *win, int line)
{
wstandout(win);
-
-#ifdef mvwchgat
+
+ /*
+ * this is a tricky one
+ */
+#if 0
+/*#ifdef mvwchgat*/
mvwchgat(win, line, 0, -1, A_STANDOUT, 0, NULL);
#else
/*
selected[i] = !selected[i];
}
-inline int
+int
list_current_item()
{
return curitem;
}
-inline int
+int
list_is_empty()
{
- return items < 1 ? 1 : 0;
+ return items < 1;
}