X-Git-Url: https://git.deb.at/?a=blobdiff_plain;f=edit.c;h=90cc07d763241195b57b322d7ed98cc993fec956;hb=e7c54d38271d82a22940c3f149ca67c89437c789;hp=b2e75084f0c4fb4d258d9f2567eef150cf32032e;hpb=3cea3c8809447c5d6658671b78b9af7137fd9b0d;p=pkg%2Fabook.git diff --git a/edit.c b/edit.c index b2e7508..90cc07d 100644 --- a/edit.c +++ b/edit.c @@ -120,12 +120,12 @@ print_editor_header(int item) { char *header; char email[MAX_EMAIL_LEN]; - + if( (header = (char *)malloc(EDITW_COLS)) == NULL ) return; get_first_email(email, item); - + if( *database[item][EMAIL] ) snprintf(header, EDITW_COLS, "%s <%s>", database[item][NAME], @@ -165,7 +165,7 @@ editor_print_data(int tab, int item) } continue; } - + if(j > 1) { getyx(editw, y, x); y++; } else @@ -182,42 +182,25 @@ editor_print_data(int tab, int item) } } -/* - * function: change_field - * - * parameters: - * (char *msg) - * message to display as a prompt - * (char **field) - * a pointer to pointer which will point a new string. if the latter - * pointer != NULL it will be freed (if user doesn't cancel) - * - * returns (int) - * a nonzero value if user has cancelled and zero if user has typed a - * valid string - */ - static int change_field(char *msg, char **field) { - char tmp[MAX_FIELD_LEN]; int max_len = MAX_FIELD_LEN; - int ret; - + char *old; + if( !strncmp("E-mail", msg, 6) ) max_len = MAX_EMAIL_LEN; - - statusline_addstr(msg); - if( (ret = statusline_getnstr( tmp, max_len - 1, 0 ) ? 1:0 ) ) { - my_free(*field); - if( *tmp ) - *field = strdup(tmp); - } + + old = *field; + + *field = ui_readline(msg, old, max_len - 1, 0); + + free(old); clear_statusline(); refresh_statusline(); - return !ret; + return 0; } static void @@ -246,25 +229,27 @@ fix_email_str(char *str) static void edit_emails(char c, int item) { - char *field = NULL; + char *field; char emails[MAX_EMAILS][MAX_EMAIL_LEN]; char tmp[MAX_EMAILSTR_LEN] = ""; int i, len; + int email_num = c - '2'; split_emailstr(item, emails); + field = strdup(emails[email_num]); if(change_field("E-mail: ", &field)) { #ifdef DEBUG fprintf(stderr, "change_field = TRUE\n"); #endif - return; /* user cancelled ( C-g ) */ + return; } if(field) { - strncpy(emails[c - '2'], field, MAX_EMAIL_LEN); - fix_email_str(emails[c - '2']); + strncpy(emails[email_num], field, MAX_EMAIL_LEN); + fix_email_str(emails[email_num]); } else - *emails[c - '2'] = 0; - + *emails[email_num] = 0; + my_free(database[item][EMAIL]); for(i = 0; i < MAX_EMAILS; i++) { @@ -361,7 +346,7 @@ edit_loop(int item) { static int tab = 0; /* first tab */ int c; - + werase(editw); headerline(EDITOR_HELPLINE); refresh_statusline();