X-Git-Url: https://git.deb.at/?a=blobdiff_plain;f=database.c;h=973c0a5a0c3928c17b45e900aaf731ef5b2baf05;hb=e2826ae894d12e69674d1b624e87c05e6bbb2afd;hp=e324810eab04c0394a3476da1c3b5ab5d4dedb75;hpb=05b0f3753902043fa8476a59c9251ab176675945;p=pkg%2Fabook.git diff --git a/database.c b/database.c index e324810..973c0a5 100644 --- a/database.c +++ b/database.c @@ -2,7 +2,7 @@ /* * $Id$ * - * by JH + * by JH * * Copyright (C) Jaakko Heinonen */ @@ -107,9 +107,12 @@ parse_database(FILE *in) } else if((tmp = strchr(line, '=') ) && sec ) { *tmp++ = '\0'; for(i=0; i= LAST_ITEM) + if(list_is_empty() || !is_valid_item(start)) return -2; /* error */ findstr = strdup(str); findstr = strupper(findstr); - for( i = start; i < items; i++ ) { - tmp = strdup(database[i][NAME]); - if( strstr(strupper(tmp), findstr) != NULL ) { - ret = i; - goto out; + e.item = start - 1; /* must be "real start" - 1 */ + db_enumerate_items(e) { + for( i = 0; search_fields[i] >= 0; i++ ) { + tmp = safe_strdup(database[e.item][search_fields[i]]); + if( tmp && strstr(strupper(tmp), findstr) ) { + ret = e.item; + goto out; + } + my_free(tmp); } - my_free(tmp); } out: @@ -421,6 +430,12 @@ is_selected(int item) return selected[item]; } +int +is_valid_item(int item) +{ + return item <= LAST_ITEM && item >= 0; +} + int real_db_enumerate_items(struct db_enumerator e) {