From dad9c43549621da2ff75da3eddf737e003eed324 Mon Sep 17 00:00:00 2001 From: Martin Hunt Date: Thu, 15 Mar 2001 18:02:14 +0000 Subject: [PATCH] 2001-03-15 Martin Hunt * linespec.c (decode_line_1): Remove trailing quote when parsing double quotes. --- gdb/ChangeLog | 5 +++++ gdb/linespec.c | 10 ++++------ 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 94d31940c3..8f2cbd2a10 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2001-03-15 Martin Hunt + + * linespec.c (decode_line_1): Remove trailing quote + when parsing double quotes. + 2001-03-15 Kevin Buettner * uw-thread.c (read_thr_debug, read_map, read_lwp, thread_iter) diff --git a/gdb/linespec.c b/gdb/linespec.c index 3f790cc49c..d70d63426d 100644 --- a/gdb/linespec.c +++ b/gdb/linespec.c @@ -1,6 +1,6 @@ /* Parser for linespec for the GNU debugger, GDB. Copyright 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, - 1996, 1997, 1998, 1999, 2000 + 1996, 1997, 1998, 1999, 2000, 2001 Free Software Foundation, Inc. This file is part of GDB. @@ -612,10 +612,11 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab, s = NULL; p = *argptr; - if (**argptr == '"') + if (p[0] == '"') { is_quote_enclosed = 1; (*argptr)++; + p++; } else is_quote_enclosed = 0; @@ -654,7 +655,7 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab, /* if the closing double quote was left at the end, remove it */ if (is_quote_enclosed) { - char *closing_quote = strchr (p, '"'); + char *closing_quote = strchr (p - 1, '"'); if (closing_quote && closing_quote[1] == '\0') *closing_quote = '\0'; } @@ -1092,9 +1093,6 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab, p = skip_quoted (*argptr); } - if (is_quote_enclosed && **argptr == '"') - (*argptr)++; - copy = (char *) alloca (p - *argptr + 1); memcpy (copy, *argptr, p - *argptr); copy[p - *argptr] = '\0'; -- 2.11.0