From e8c7cf207113d0a21485a2ba69fe872f3266cb51 Mon Sep 17 00:00:00 2001 From: Benno Schulenberg <bensberg@justemail.net> Date: Tue, 17 Jan 2017 14:17:42 +0100 Subject: [PATCH] startup: report an error when the given line or column number is invalid This fixes https://savannah.gnu.org/bugs/?50028. --- src/nano.c | 10 ++++++---- src/search.c | 2 +- src/utils.c | 2 +- 3 files changed, 8 insertions(+), 6 deletions(-) diff --git a/src/nano.c b/src/nano.c index d1dba354..04782ea8 100644 --- a/src/nano.c +++ b/src/nano.c @@ -2557,7 +2557,8 @@ int main(int argc, char **argv) * non-option argument, and it is followed by at least one other * argument, the filename it applies to. */ if (0 < optind && optind < argc - 1 && argv[optind][0] == '+') { - parse_line_column(&argv[optind][1], &startline, &startcol); + if (!parse_line_column(&argv[optind][1], &startline, &startcol)) + statusline(ALERT, _("Invalid line or column number")); optind++; } @@ -2581,9 +2582,10 @@ int main(int argc, char **argv) for (; i < argc; i++) { /* If there's a +LINE or +LINE,COLUMN flag here, it is followed * by at least one other argument: the filename it applies to. */ - if (i < argc - 1 && argv[i][0] == '+') - parse_line_column(&argv[i][1], &iline, &icol); - else { + if (i < argc - 1 && argv[i][0] == '+') { + if (!parse_line_column(&argv[i][1], &iline, &icol)) + statusline(ALERT, _("Invalid line or column number")); + } else { /* If opening fails, don't try to position the cursor. */ if (!open_buffer(argv[i], FALSE)) continue; diff --git a/src/search.c b/src/search.c index bf6fcd84..7ca76e8d 100644 --- a/src/search.c +++ b/src/search.c @@ -894,7 +894,7 @@ void do_gotolinecolumn(ssize_t line, ssize_t column, bool use_answer, /* Try to extract one or two numbers from the user's response. */ if (!parse_line_column(answer, &line, &column)) { - statusbar(_("Invalid line or column number")); + statusline(ALERT, _("Invalid line or column number")); return; } } else { diff --git a/src/utils.c b/src/utils.c index bfd9d13c..74a18fa6 100644 --- a/src/utils.c +++ b/src/utils.c @@ -129,7 +129,7 @@ bool parse_line_column(const char *str, ssize_t *line, ssize_t *column) firstpart = mallocstrcpy(NULL, str); firstpart[comma - str] = '\0'; - retval = parse_num(firstpart, line); + retval = parse_num(firstpart, line) && retval; free(firstpart); -- GitLab