2011-05-26 Pedro Alves <pedro@codesourcery.com>
[deliverable/binutils-gdb.git] / gdb / linespec.c
CommitLineData
50641945 1/* Parser for linespec for the GNU debugger, GDB.
05ff989b 2
6aba47ca 3 Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995,
0fb0cc75 4 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008,
7b6bb8da 5 2009, 2010, 2011 Free Software Foundation, Inc.
50641945
FN
6
7 This file is part of GDB.
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
a9762ec7 11 the Free Software Foundation; either version 3 of the License, or
50641945
FN
12 (at your option) any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
a9762ec7 20 along with this program. If not, see <http://www.gnu.org/licenses/>. */
50641945
FN
21
22#include "defs.h"
23#include "symtab.h"
c5f0f3d0
FN
24#include "frame.h"
25#include "command.h"
50641945
FN
26#include "symfile.h"
27#include "objfiles.h"
0378c332 28#include "source.h"
50641945 29#include "demangle.h"
c5f0f3d0
FN
30#include "value.h"
31#include "completer.h"
015a42b4 32#include "cp-abi.h"
12907978 33#include "cp-support.h"
c38da1af 34#include "parser-defs.h"
fe898f56 35#include "block.h"
d2630e69 36#include "objc-lang.h"
b9362cc7 37#include "linespec.h"
05ff989b 38#include "exceptions.h"
53c5240f 39#include "language.h"
dc67126b
NR
40#include "interps.h"
41#include "mi/mi-cmds.h"
bccdca4a 42#include "target.h"
94af9270 43#include "arch-utils.h"
c00f8484
KS
44#include <ctype.h>
45#include "cli/cli-utils.h"
50641945 46
1777feb0 47/* We share this one with symtab.c, but it is not exported widely. */
50641945
FN
48
49extern char *operator_chars (char *, char **);
50
1777feb0 51/* Prototypes for local functions. */
50641945 52
44fe14ab
DC
53static void initialize_defaults (struct symtab **default_symtab,
54 int *default_line);
55
56static struct symtabs_and_lines decode_indirect (char **argptr);
57
0960f083
DC
58static char *locate_first_half (char **argptr, int *is_quote_enclosed);
59
d2630e69
AF
60static struct symtabs_and_lines decode_objc (char **argptr,
61 int funfirstline,
62 struct symtab *file_symtab,
7efd8fc2 63 struct linespec_result *canonical,
d2630e69
AF
64 char *saved_arg);
65
614b3b14
DC
66static struct symtabs_and_lines decode_compound (char **argptr,
67 int funfirstline,
7efd8fc2 68 struct linespec_result *canonical,
614b3b14 69 char *saved_arg,
58438ac1 70 char *p);
614b3b14 71
93d91629
DC
72static struct symbol *lookup_prefix_sym (char **argptr, char *p);
73
4224873a 74static struct symtabs_and_lines find_method (int funfirstline,
7efd8fc2 75 struct linespec_result *canonical,
4224873a
DC
76 char *saved_arg,
77 char *copy,
78 struct type *t,
58438ac1 79 struct symbol *sym_class);
4224873a 80
c25c4a8b
JK
81static void cplusplus_error (const char *name, const char *fmt, ...)
82 ATTRIBUTE_NORETURN ATTRIBUTE_PRINTF (2, 3);
50641945
FN
83
84static int total_number_of_methods (struct type *type);
85
53c5240f
PA
86static int find_methods (struct type *, char *,
87 enum language, struct symbol **);
50641945 88
aee8d8ba 89static int add_matching_methods (int method_counter, struct type *t,
53c5240f 90 enum language language,
aee8d8ba
DC
91 struct symbol **sym_arr);
92
93static int add_constructors (int method_counter, struct type *t,
53c5240f 94 enum language language,
aee8d8ba
DC
95 struct symbol **sym_arr);
96
50641945 97static void build_canonical_line_spec (struct symtab_and_line *,
7efd8fc2 98 char *, struct linespec_result *);
50641945
FN
99
100static char *find_toplevel_char (char *s, char c);
101
889f28e2
AF
102static int is_objc_method_format (const char *s);
103
50641945 104static struct symtabs_and_lines decode_line_2 (struct symbol *[],
7efd8fc2
TT
105 int, int,
106 struct linespec_result *);
50641945 107
f3c39e76 108static struct symtab *symtab_from_filename (char **argptr,
58438ac1 109 char *p, int is_quote_enclosed);
f3c39e76 110
9ef07c8c
TT
111static struct symbol *find_function_symbol (char **argptr, char *p,
112 int is_quote_enclosed);
113
84fba31b
DC
114static struct
115symtabs_and_lines decode_all_digits (char **argptr,
116 struct symtab *default_symtab,
117 int default_line,
7efd8fc2 118 struct linespec_result *canonical,
88d262ca 119 struct symtab *file_symtab,
84fba31b
DC
120 char *q);
121
14e91ac5
DC
122static struct symtabs_and_lines decode_dollar (char *copy,
123 int funfirstline,
124 struct symtab *default_symtab,
7efd8fc2 125 struct linespec_result *canonical,
88d262ca 126 struct symtab *file_symtab);
14e91ac5 127
9ef07c8c
TT
128static int decode_label (struct symbol *function_symbol,
129 char *copy, struct linespec_result *canonical,
0f5238ed
TT
130 struct symtabs_and_lines *result);
131
bca02a8a
DC
132static struct symtabs_and_lines decode_variable (char *copy,
133 int funfirstline,
7efd8fc2 134 struct linespec_result *canonical,
58438ac1 135 struct symtab *file_symtab);
bca02a8a 136
413dad4d
DC
137static struct
138symtabs_and_lines symbol_found (int funfirstline,
7efd8fc2 139 struct linespec_result *canonical,
413dad4d
DC
140 char *copy,
141 struct symbol *sym,
9ef07c8c
TT
142 struct symtab *file_symtab,
143 struct symbol *function_symbol);
413dad4d
DC
144
145static struct
146symtabs_and_lines minsym_found (int funfirstline,
147 struct minimal_symbol *msymbol);
148
1777feb0 149/* Helper functions. */
50641945 150
255e7dbf
AC
151/* Issue a helpful hint on using the command completion feature on
152 single quoted demangled C++ symbols as part of the completion
153 error. */
50641945 154
c25c4a8b 155static void
255e7dbf 156cplusplus_error (const char *name, const char *fmt, ...)
50641945 157{
255e7dbf 158 struct ui_file *tmp_stream;
f3a5f1de 159 char *message;
e0881a8e 160
255e7dbf
AC
161 tmp_stream = mem_fileopen ();
162 make_cleanup_ui_file_delete (tmp_stream);
163
164 {
165 va_list args;
e0881a8e 166
255e7dbf
AC
167 va_start (args, fmt);
168 vfprintf_unfiltered (tmp_stream, fmt, args);
169 va_end (args);
170 }
171
50641945
FN
172 while (*name == '\'')
173 name++;
255e7dbf
AC
174 fprintf_unfiltered (tmp_stream,
175 ("Hint: try '%s<TAB> or '%s<ESC-?>\n"
176 "(Note leading single quote.)"),
177 name, name);
f3a5f1de 178
759ef836
PA
179 message = ui_file_xstrdup (tmp_stream, NULL);
180 make_cleanup (xfree, message);
181 throw_error (NOT_FOUND_ERROR, "%s", message);
50641945
FN
182}
183
184/* Return the number of methods described for TYPE, including the
1777feb0 185 methods from types it derives from. This can't be done in the symbol
50641945
FN
186 reader because the type of the baseclass might still be stubbed
187 when the definition of the derived class is parsed. */
188
189static int
190total_number_of_methods (struct type *type)
191{
192 int n;
193 int count;
194
195 CHECK_TYPEDEF (type);
b4ba55a1 196 if (! HAVE_CPLUS_STRUCT (type))
50641945
FN
197 return 0;
198 count = TYPE_NFN_FIELDS_TOTAL (type);
199
200 for (n = 0; n < TYPE_N_BASECLASSES (type); n++)
201 count += total_number_of_methods (TYPE_BASECLASS (type, n));
202
203 return count;
204}
205
206/* Recursive helper function for decode_line_1.
207 Look for methods named NAME in type T.
208 Return number of matches.
209 Put matches in SYM_ARR, which should have been allocated with
210 a size of total_number_of_methods (T) * sizeof (struct symbol *).
211 Note that this function is g++ specific. */
212
213static int
53c5240f
PA
214find_methods (struct type *t, char *name, enum language language,
215 struct symbol **sym_arr)
50641945
FN
216{
217 int i1 = 0;
218 int ibase;
50641945 219 char *class_name = type_name_no_tag (t);
c00f8484
KS
220 struct cleanup *cleanup;
221 char *canon;
222
223 /* NAME is typed by the user: it needs to be canonicalized before
224 passing to lookup_symbol. */
225 canon = cp_canonicalize_string (name);
226 if (canon != NULL)
227 {
228 name = canon;
229 cleanup = make_cleanup (xfree, name);
230 }
231 else
232 cleanup = make_cleanup (null_cleanup, NULL);
50641945
FN
233
234 /* Ignore this class if it doesn't have a name. This is ugly, but
235 unless we figure out how to get the physname without the name of
236 the class, then the loop can't do any good. */
237 if (class_name
53c5240f 238 && (lookup_symbol_in_language (class_name, (struct block *) NULL,
2570f2b7 239 STRUCT_DOMAIN, language, (int *) NULL)))
50641945
FN
240 {
241 int method_counter;
5c717440 242 int name_len = strlen (name);
50641945 243
8bd1f2c6 244 CHECK_TYPEDEF (t);
50641945
FN
245
246 /* Loop over each method name. At this level, all overloads of a name
247 are counted as a single name. There is an inner loop which loops over
248 each overload. */
249
250 for (method_counter = TYPE_NFN_FIELDS (t) - 1;
251 method_counter >= 0;
252 --method_counter)
253 {
50641945
FN
254 char *method_name = TYPE_FN_FIELDLIST_NAME (t, method_counter);
255 char dem_opname[64];
256
257 if (strncmp (method_name, "__", 2) == 0 ||
258 strncmp (method_name, "op", 2) == 0 ||
259 strncmp (method_name, "type", 4) == 0)
260 {
261 if (cplus_demangle_opname (method_name, dem_opname, DMGL_ANSI))
262 method_name = dem_opname;
263 else if (cplus_demangle_opname (method_name, dem_opname, 0))
264 method_name = dem_opname;
265 }
266
13b57657 267 if (strcmp_iw (name, method_name) == 0)
50641945 268 /* Find all the overloaded methods with that name. */
53c5240f 269 i1 += add_matching_methods (method_counter, t, language,
aee8d8ba 270 sym_arr + i1);
5c717440
DJ
271 else if (strncmp (class_name, name, name_len) == 0
272 && (class_name[name_len] == '\0'
273 || class_name[name_len] == '<'))
53c5240f 274 i1 += add_constructors (method_counter, t, language,
aee8d8ba 275 sym_arr + i1);
50641945
FN
276 }
277 }
278
279 /* Only search baseclasses if there is no match yet, since names in
280 derived classes override those in baseclasses.
281
282 FIXME: The above is not true; it is only true of member functions
283 if they have the same number of arguments (??? - section 13.1 of the
284 ARM says the function members are not in the same scope but doesn't
285 really spell out the rules in a way I understand. In any case, if
286 the number of arguments differ this is a case in which we can overload
287 rather than hiding without any problem, and gcc 2.4.5 does overload
288 rather than hiding in this case). */
289
290 if (i1 == 0)
291 for (ibase = 0; ibase < TYPE_N_BASECLASSES (t); ibase++)
53c5240f
PA
292 i1 += find_methods (TYPE_BASECLASS (t, ibase), name,
293 language, sym_arr + i1);
50641945 294
c00f8484 295 do_cleanups (cleanup);
50641945
FN
296 return i1;
297}
298
aee8d8ba
DC
299/* Add the symbols associated to methods of the class whose type is T
300 and whose name matches the method indexed by METHOD_COUNTER in the
301 array SYM_ARR. Return the number of methods added. */
302
303static int
304add_matching_methods (int method_counter, struct type *t,
53c5240f 305 enum language language, struct symbol **sym_arr)
aee8d8ba
DC
306{
307 int field_counter;
308 int i1 = 0;
309
310 for (field_counter = TYPE_FN_FIELDLIST_LENGTH (t, method_counter) - 1;
311 field_counter >= 0;
312 --field_counter)
313 {
314 struct fn_field *f;
1d06ead6 315 const char *phys_name;
aee8d8ba
DC
316
317 f = TYPE_FN_FIELDLIST1 (t, method_counter);
318
319 if (TYPE_FN_FIELD_STUB (f, field_counter))
320 {
1d06ead6 321 char *tmp_name, *tmp2;
aee8d8ba
DC
322
323 tmp_name = gdb_mangle_name (t,
324 method_counter,
325 field_counter);
1d06ead6
TT
326 tmp2 = alloca (strlen (tmp_name) + 1);
327 strcpy (tmp2, tmp_name);
aee8d8ba 328 xfree (tmp_name);
1d06ead6 329 phys_name = tmp2;
aee8d8ba
DC
330 }
331 else
332 phys_name = TYPE_FN_FIELD_PHYSNAME (f, field_counter);
53c5240f 333
53c5240f 334 sym_arr[i1] = lookup_symbol_in_language (phys_name,
aee8d8ba 335 NULL, VAR_DOMAIN,
53c5240f 336 language,
2570f2b7 337 (int *) NULL);
aee8d8ba
DC
338 if (sym_arr[i1])
339 i1++;
340 else
341 {
342 /* This error message gets printed, but the method
1777feb0 343 still seems to be found.
aee8d8ba
DC
344 fputs_filtered("(Cannot find method ", gdb_stdout);
345 fprintf_symbol_filtered (gdb_stdout, phys_name,
1777feb0
MS
346 language_cplus,
347 DMGL_PARAMS | DMGL_ANSI);
aee8d8ba
DC
348 fputs_filtered(" - possibly inlined.)\n", gdb_stdout);
349 */
350 }
351 }
352
353 return i1;
354}
355
356/* Add the symbols associated to constructors of the class whose type
357 is CLASS_TYPE and which are indexed by by METHOD_COUNTER to the
358 array SYM_ARR. Return the number of methods added. */
359
360static int
361add_constructors (int method_counter, struct type *t,
53c5240f 362 enum language language, struct symbol **sym_arr)
aee8d8ba
DC
363{
364 int field_counter;
365 int i1 = 0;
366
367 /* For GCC 3.x and stabs, constructors and destructors
368 have names like __base_ctor and __complete_dtor.
369 Check the physname for now if we're looking for a
370 constructor. */
371 for (field_counter
372 = TYPE_FN_FIELDLIST_LENGTH (t, method_counter) - 1;
373 field_counter >= 0;
374 --field_counter)
375 {
376 struct fn_field *f;
1d06ead6 377 const char *phys_name;
53c5240f 378
aee8d8ba
DC
379 f = TYPE_FN_FIELDLIST1 (t, method_counter);
380
381 /* GCC 3.x will never produce stabs stub methods, so
382 we don't need to handle this case. */
383 if (TYPE_FN_FIELD_STUB (f, field_counter))
384 continue;
385 phys_name = TYPE_FN_FIELD_PHYSNAME (f, field_counter);
386 if (! is_constructor_name (phys_name))
387 continue;
388
389 /* If this method is actually defined, include it in the
390 list. */
53c5240f 391 sym_arr[i1] = lookup_symbol_in_language (phys_name,
aee8d8ba 392 NULL, VAR_DOMAIN,
53c5240f 393 language,
2570f2b7 394 (int *) NULL);
aee8d8ba
DC
395 if (sym_arr[i1])
396 i1++;
397 }
398
399 return i1;
400}
401
50641945
FN
402/* Helper function for decode_line_1.
403 Build a canonical line spec in CANONICAL if it is non-NULL and if
404 the SAL has a symtab.
405 If SYMNAME is non-NULL the canonical line spec is `filename:symname'.
406 If SYMNAME is NULL the line number from SAL is used and the canonical
407 line spec is `filename:linenum'. */
408
409static void
410build_canonical_line_spec (struct symtab_and_line *sal, char *symname,
7efd8fc2 411 struct linespec_result *canonical)
50641945
FN
412{
413 char **canonical_arr;
414 char *canonical_name;
415 char *filename;
416 struct symtab *s = sal->symtab;
417
418 if (s == (struct symtab *) NULL
419 || s->filename == (char *) NULL
7efd8fc2 420 || canonical == NULL)
50641945
FN
421 return;
422
423 canonical_arr = (char **) xmalloc (sizeof (char *));
7efd8fc2 424 canonical->canonical = canonical_arr;
50641945
FN
425
426 filename = s->filename;
427 if (symname != NULL)
428 {
429 canonical_name = xmalloc (strlen (filename) + strlen (symname) + 2);
430 sprintf (canonical_name, "%s:%s", filename, symname);
431 }
432 else
433 {
434 canonical_name = xmalloc (strlen (filename) + 30);
435 sprintf (canonical_name, "%s:%d", filename, sal->line);
436 }
437 canonical_arr[0] = canonical_name;
438}
439
440
441
442/* Find an instance of the character C in the string S that is outside
443 of all parenthesis pairs, single-quoted strings, and double-quoted
8120c9d5
EZ
444 strings. Also, ignore the char within a template name, like a ','
445 within foo<int, int>. */
446
50641945
FN
447static char *
448find_toplevel_char (char *s, char c)
449{
450 int quoted = 0; /* zero if we're not in quotes;
451 '"' if we're in a double-quoted string;
452 '\'' if we're in a single-quoted string. */
a04257e6 453 int depth = 0; /* Number of unclosed parens we've seen. */
50641945
FN
454 char *scan;
455
456 for (scan = s; *scan; scan++)
457 {
458 if (quoted)
459 {
460 if (*scan == quoted)
461 quoted = 0;
462 else if (*scan == '\\' && *(scan + 1))
463 scan++;
464 }
465 else if (*scan == c && ! quoted && depth == 0)
466 return scan;
467 else if (*scan == '"' || *scan == '\'')
468 quoted = *scan;
8120c9d5 469 else if (*scan == '(' || *scan == '<')
50641945 470 depth++;
8120c9d5 471 else if ((*scan == ')' || *scan == '>') && depth > 0)
50641945
FN
472 depth--;
473 }
474
475 return 0;
476}
477
889f28e2 478/* Determines if the gives string corresponds to an Objective-C method
1777feb0 479 representation, such as -[Foo bar:] or +[Foo bar]. Objective-C symbols
889f28e2
AF
480 are allowed to have spaces and parentheses in them. */
481
482static int
483is_objc_method_format (const char *s)
484{
485 if (s == NULL || *s == '\0')
486 return 0;
487 /* Handle arguments with the format FILENAME:SYMBOL. */
488 if ((s[0] == ':') && (strchr ("+-", s[1]) != NULL)
489 && (s[2] == '[') && strchr(s, ']'))
490 return 1;
491 /* Handle arguments that are just SYMBOL. */
492 else if ((strchr ("+-", s[0]) != NULL) && (s[1] == '[') && strchr(s, ']'))
493 return 1;
494 return 0;
495}
496
50641945
FN
497/* Given a list of NELTS symbols in SYM_ARR, return a list of lines to
498 operate on (ask user if necessary).
499 If CANONICAL is non-NULL return a corresponding array of mangled names
500 as canonical line specs there. */
501
502static struct symtabs_and_lines
503decode_line_2 (struct symbol *sym_arr[], int nelts, int funfirstline,
7efd8fc2 504 struct linespec_result *canonical)
50641945
FN
505{
506 struct symtabs_and_lines values, return_values;
507 char *args, *arg1;
508 int i;
509 char *prompt;
510 char *symname;
511 struct cleanup *old_chain;
512 char **canonical_arr = (char **) NULL;
717d2f5a 513 const char *select_mode = multiple_symbols_select_mode ();
50641945 514
717d2f5a 515 if (select_mode == multiple_symbols_cancel)
3e43a32a
MS
516 error (_("canceled because the command is ambiguous\n"
517 "See set/show multiple-symbol."));
717d2f5a 518
50641945
FN
519 values.sals = (struct symtab_and_line *)
520 alloca (nelts * sizeof (struct symtab_and_line));
521 return_values.sals = (struct symtab_and_line *)
522 xmalloc (nelts * sizeof (struct symtab_and_line));
b8c9b27d 523 old_chain = make_cleanup (xfree, return_values.sals);
50641945
FN
524
525 if (canonical)
526 {
527 canonical_arr = (char **) xmalloc (nelts * sizeof (char *));
b8c9b27d 528 make_cleanup (xfree, canonical_arr);
50641945 529 memset (canonical_arr, 0, nelts * sizeof (char *));
7efd8fc2 530 canonical->canonical = canonical_arr;
50641945
FN
531 }
532
533 i = 0;
50641945
FN
534 while (i < nelts)
535 {
a04257e6 536 init_sal (&return_values.sals[i]); /* Initialize to zeroes. */
fe39c653 537 init_sal (&values.sals[i]);
50641945 538 if (sym_arr[i] && SYMBOL_CLASS (sym_arr[i]) == LOC_BLOCK)
717d2f5a 539 values.sals[i] = find_function_start_sal (sym_arr[i], funfirstline);
50641945
FN
540 i++;
541 }
542
717d2f5a
JB
543 /* If select_mode is "all", then do not print the multiple-choice
544 menu and act as if the user had chosen choice "1" (all). */
dc67126b
NR
545 if (select_mode == multiple_symbols_all
546 || ui_out_is_mi_like_p (interp_ui_out (top_level_interpreter ())))
717d2f5a
JB
547 args = "1";
548 else
50641945 549 {
717d2f5a
JB
550 i = 0;
551 printf_unfiltered (_("[0] cancel\n[1] all\n"));
552 while (i < nelts)
553 {
554 if (sym_arr[i] && SYMBOL_CLASS (sym_arr[i]) == LOC_BLOCK)
555 {
556 if (values.sals[i].symtab)
557 printf_unfiltered ("[%d] %s at %s:%d\n",
558 (i + 2),
559 SYMBOL_PRINT_NAME (sym_arr[i]),
560 values.sals[i].symtab->filename,
561 values.sals[i].line);
562 else
3e43a32a
MS
563 printf_unfiltered (_("[%d] %s at ?FILE:%d [No symtab? "
564 "Probably broken debug info...]\n"),
717d2f5a
JB
565 (i + 2),
566 SYMBOL_PRINT_NAME (sym_arr[i]),
567 values.sals[i].line);
568
569 }
570 else
571 printf_unfiltered (_("?HERE\n"));
572 i++;
573 }
574
575 prompt = getenv ("PS2");
576 if (prompt == NULL)
577 {
578 prompt = "> ";
579 }
580 args = command_line_input (prompt, 0, "overload-choice");
50641945 581 }
50641945
FN
582
583 if (args == 0 || *args == 0)
e2e0b3e5 584 error_no_arg (_("one or more choice numbers"));
50641945
FN
585
586 i = 0;
587 while (*args)
588 {
589 int num;
590
591 arg1 = args;
592 while (*arg1 >= '0' && *arg1 <= '9')
593 arg1++;
594 if (*arg1 && *arg1 != ' ' && *arg1 != '\t')
8a3fe4f8 595 error (_("Arguments must be choice numbers."));
50641945
FN
596
597 num = atoi (args);
598
599 if (num == 0)
8a3fe4f8 600 error (_("canceled"));
50641945
FN
601 else if (num == 1)
602 {
603 if (canonical_arr)
604 {
605 for (i = 0; i < nelts; i++)
606 {
607 if (canonical_arr[i] == NULL)
608 {
3567439c 609 symname = SYMBOL_LINKAGE_NAME (sym_arr[i]);
1b36a34b 610 canonical_arr[i] = xstrdup (symname);
50641945
FN
611 }
612 }
613 }
614 memcpy (return_values.sals, values.sals,
615 (nelts * sizeof (struct symtab_and_line)));
616 return_values.nelts = nelts;
617 discard_cleanups (old_chain);
618 return return_values;
619 }
620
621 if (num >= nelts + 2)
622 {
a3f17187 623 printf_unfiltered (_("No choice number %d.\n"), num);
50641945
FN
624 }
625 else
626 {
627 num -= 2;
628 if (values.sals[num].pc)
629 {
630 if (canonical_arr)
631 {
3567439c 632 symname = SYMBOL_LINKAGE_NAME (sym_arr[num]);
b8c9b27d 633 make_cleanup (xfree, symname);
1b36a34b 634 canonical_arr[i] = xstrdup (symname);
50641945
FN
635 }
636 return_values.sals[i++] = values.sals[num];
637 values.sals[num].pc = 0;
638 }
639 else
640 {
3e43a32a
MS
641 printf_unfiltered (_("duplicate request for %d ignored.\n"),
642 num);
50641945
FN
643 }
644 }
645
646 args = arg1;
647 while (*args == ' ' || *args == '\t')
648 args++;
649 }
650 return_values.nelts = i;
651 discard_cleanups (old_chain);
652 return return_values;
653}
94af9270
KS
654
655/* A helper function for decode_line_1 and friends which skips P
656 past any method overload information at the beginning of P, e.g.,
657 "(const struct foo *)".
658
659 This function assumes that P has already been validated to contain
660 overload information, and it will assert if *P != '('. */
661static char *
662find_method_overload_end (char *p)
663{
664 int depth = 0;
665
666 gdb_assert (*p == '(');
667
668 while (*p)
669 {
670 if (*p == '(')
671 ++depth;
672 else if (*p == ')')
673 {
674 if (--depth == 0)
675 {
676 ++p;
677 break;
678 }
679 }
680 ++p;
681 }
682
683 return p;
684}
c00f8484
KS
685
686/* Does P point to a sequence of characters which implies the end
687 of a name? Terminals include "if" and "thread" clauses. */
688
689static int
690name_end (char *p)
691{
692 while (isspace (*p))
693 ++p;
694 if (*p == 'i' && p[1] == 'f'
695 && (isspace (p[2]) || p[2] == '\0' || p[2] == '('))
696 return 1;
697
698 if (strncmp (p, "thread", 6) == 0
699 && (isspace (p[6]) || p[6] == '\0'))
700 return 1;
701
702 return 0;
703}
704
705/* Keep important information used when looking up a name. This includes
706 template parameters, overload information, and important keywords. */
707
708static char *
709keep_name_info (char *ptr)
710{
711 char *p = ptr;
712 char *start = ptr;
713
714 /* Keep any template parameters. */
715 if (name_end (ptr))
716 return remove_trailing_whitespace (start, ptr);
717
f17170e5 718 p = skip_spaces (p);
c00f8484
KS
719 if (*p == '<')
720 ptr = p = find_template_name_end (ptr);
721
722 if (name_end (ptr))
723 return remove_trailing_whitespace (start, ptr);
724
725 /* Keep method overload information. */
726 if (*p == '(')
727 ptr = p = find_method_overload_end (p);
728
729 if (name_end (ptr))
730 return remove_trailing_whitespace (start, ptr);
731
732 /* Keep important keywords. */
f17170e5
KS
733 while (1)
734 {
735 char *quotes = get_gdb_completer_quote_characters ();
736 p = skip_spaces (p);
737 if (strncmp (p, "const", 5) == 0
738 && (isspace (p[5]) || p[5] == '\0'
739 || strchr (quotes, p[5]) != NULL))
740 ptr = p = p + 5;
741 else if (strncmp (p, "volatile", 8) == 0
742 && (isspace (p[8]) || p[8] == '\0'
743 || strchr (quotes, p[8]) != NULL))
744 ptr = p = p + 8;
745 else
746 break;
747 }
c00f8484
KS
748
749 return remove_trailing_whitespace (start, ptr);
750}
751
50641945 752\f
1777feb0 753/* The parser of linespec itself. */
50641945
FN
754
755/* Parse a string that specifies a line number.
756 Pass the address of a char * variable; that variable will be
757 advanced over the characters actually parsed.
758
759 The string can be:
760
761 LINENUM -- that line number in current file. PC returned is 0.
762 FILE:LINENUM -- that line in that file. PC returned is 0.
763 FUNCTION -- line number of openbrace of that function.
764 PC returned is the start of the function.
0f5238ed 765 LABEL -- a label in the current scope
50641945
FN
766 VARIABLE -- line number of definition of that variable.
767 PC returned is 0.
768 FILE:FUNCTION -- likewise, but prefer functions in that file.
769 *EXPR -- line in which address EXPR appears.
770
771 This may all be followed by an "if EXPR", which we ignore.
772
773 FUNCTION may be an undebuggable function found in minimal symbol table.
774
775 If the argument FUNFIRSTLINE is nonzero, we want the first line
776 of real code inside a function when a function is specified, and it is
777 not OK to specify a variable or type to get its line number.
778
779 DEFAULT_SYMTAB specifies the file to use if none is specified.
780 It defaults to current_source_symtab.
781 DEFAULT_LINE specifies the line number to use for relative
782 line numbers (that start with signs). Defaults to current_source_line.
783 If CANONICAL is non-NULL, store an array of strings containing the canonical
1777feb0 784 line specs there if necessary. Currently overloaded member functions and
50641945 785 line numbers or static functions without a filename yield a canonical
1777feb0 786 line spec. The array and the line spec strings are allocated on the heap,
50641945
FN
787 it is the callers responsibility to free them.
788
789 Note that it is possible to return zero for the symtab
790 if no file is validly specified. Callers must check that.
58438ac1 791 Also, the line number returned may be invalid. */
50641945
FN
792
793/* We allow single quotes in various places. This is a hideous
794 kludge, which exists because the completer can't yet deal with the
795 lack of single quotes. FIXME: write a linespec_completer which we
796 can use as appropriate instead of make_symbol_completion_list. */
797
798struct symtabs_and_lines
799decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
58438ac1 800 int default_line, struct linespec_result *canonical)
50641945 801{
f3c39e76 802 char *p;
614b3b14 803 char *q;
88d262ca
DC
804 /* If a file name is specified, this is its symtab. */
805 struct symtab *file_symtab = NULL;
50641945 806
50641945 807 char *copy;
636b1a6d
DC
808 /* This says whether or not something in *ARGPTR is quoted with
809 completer_quotes (i.e. with single quotes). */
e325fb69 810 int is_quoted;
0e0b460e 811 /* Is *ARGPTR is enclosed in double quotes? */
50641945 812 int is_quote_enclosed;
d2630e69 813 int is_objc_method = 0;
50641945 814 char *saved_arg = *argptr;
791dfb64
DJ
815 /* If IS_QUOTED, the end of the quoted bit. */
816 char *end_quote = NULL;
0e0b460e
KS
817 /* The "first half" of the linespec. */
818 char *first_half;
50641945 819
9ef07c8c
TT
820 /* If we are parsing `function:label', this holds the symbol for the
821 function. */
822 struct symbol *function_symbol = NULL;
823 /* If FUNCTION_SYMBOL is not NULL, then this is the exception that
824 was thrown when trying to parse a filename. */
825 volatile struct gdb_exception file_exception;
826
50641945
FN
827 /* Defaults have defaults. */
828
44fe14ab
DC
829 initialize_defaults (&default_symtab, &default_line);
830
a04257e6 831 /* See if arg is *PC. */
50641945 832
e325fb69
MS
833 if (**argptr == '*')
834 return decode_indirect (argptr);
5f01dbc0 835
e325fb69
MS
836 is_quoted = (strchr (get_gdb_completer_quote_characters (),
837 **argptr) != NULL);
50641945 838
791dfb64
DJ
839 if (is_quoted)
840 end_quote = skip_quoted (*argptr);
50641945 841
0960f083
DC
842 /* Check to see if it's a multipart linespec (with colons or
843 periods). */
50641945 844
17763fd9
EZ
845 /* Locate the end of the first half of the linespec.
846 After the call, for instance, if the argptr string is "foo.c:123"
847 p will point at "123". If there is only one part, like "foo", p
1777feb0
MS
848 will point to "". If this is a C++ name, like "A::B::foo", p will
849 point to "::B::foo". Argptr is not changed by this call. */
50641945 850
0e0b460e 851 first_half = p = locate_first_half (argptr, &is_quote_enclosed);
50641945 852
d2630e69
AF
853 /* Check if this is an Objective-C method (anything that starts with
854 a '+' or '-' and a '['). */
889f28e2 855 if (is_objc_method_format (p))
94af9270 856 is_objc_method = 1;
d2630e69
AF
857
858 /* Check if the symbol could be an Objective-C selector. */
859
860 {
861 struct symtabs_and_lines values;
e0881a8e 862
d2630e69
AF
863 values = decode_objc (argptr, funfirstline, NULL,
864 canonical, saved_arg);
865 if (values.sals != NULL)
866 return values;
867 }
868
0960f083 869 /* Does it look like there actually were two parts? */
50641945 870
791dfb64 871 if (p[0] == ':' || p[0] == '.')
50641945 872 {
17763fd9
EZ
873 /* Is it a C++ or Java compound data structure?
874 The check on p[1] == ':' is capturing the case of "::",
1777feb0 875 since p[0]==':' was checked above.
17763fd9
EZ
876 Note that the call to decode_compound does everything
877 for us, including the lookup on the symbol table, so we
1777feb0 878 can return now. */
17763fd9 879
50641945 880 if (p[0] == '.' || p[1] == ':')
791dfb64 881 {
94af9270
KS
882 struct symtabs_and_lines values;
883
884 if (is_quote_enclosed)
885 ++saved_arg;
886 values = decode_compound (argptr, funfirstline, canonical,
58438ac1 887 saved_arg, p);
94af9270
KS
888 if (is_quoted && **argptr == '\'')
889 *argptr = *argptr + 1;
890 return values;
791dfb64 891 }
50641945 892
94af9270
KS
893 /* No, the first part is a filename; set file_symtab to be that file's
894 symtab. Also, move argptr past the filename. */
50641945 895
9ef07c8c
TT
896 TRY_CATCH (file_exception, RETURN_MASK_ERROR)
897 {
58438ac1 898 file_symtab = symtab_from_filename (argptr, p, is_quote_enclosed);
9ef07c8c
TT
899 }
900 /* If that failed, maybe we have `function:label'. */
901 if (file_exception.reason < 0)
902 {
903 function_symbol = find_function_symbol (argptr, p, is_quote_enclosed);
904 /* If we did not find a function, re-throw the original
905 exception. */
906 if (!function_symbol)
907 throw_exception (file_exception);
9ef07c8c 908 }
50641945 909
94af9270
KS
910 /* Check for single quotes on the non-filename part. */
911 if (!is_quoted)
50641945 912 {
94af9270
KS
913 is_quoted = (**argptr
914 && strchr (get_gdb_completer_quote_characters (),
915 **argptr) != NULL);
916 if (is_quoted)
917 end_quote = skip_quoted (*argptr);
50641945 918 }
50641945 919 }
50641945 920
bc882aa9 921 /* file_symtab is specified file's symtab, or 0 if no file specified.
9ef07c8c
TT
922 If we are parsing `function:symbol', then FUNCTION_SYMBOL is the
923 function before the `:'.
50641945
FN
924 arg no longer contains the file name. */
925
0e0b460e
KS
926 /* If the filename was quoted, we must re-check the quotation. */
927
928 if (end_quote == first_half && *end_quote!= '\0')
929 {
930 is_quoted = (**argptr
931 && strchr (get_gdb_completer_quote_characters (),
932 **argptr) != NULL);
933 if (is_quoted)
934 end_quote = skip_quoted (*argptr);
935 }
936
a04257e6 937 /* Check whether arg is all digits (and sign). */
50641945
FN
938
939 q = *argptr;
940 if (*q == '-' || *q == '+')
941 q++;
942 while (*q >= '0' && *q <= '9')
943 q++;
944
9ef07c8c
TT
945 if (q != *argptr && (*q == 0 || *q == ' ' || *q == '\t' || *q == ',')
946 && function_symbol == NULL)
84fba31b
DC
947 /* We found a token consisting of all digits -- at least one digit. */
948 return decode_all_digits (argptr, default_symtab, default_line,
88d262ca 949 canonical, file_symtab, q);
50641945
FN
950
951 /* Arg token is not digits => try it as a variable name
952 Find the next token (everything up to end or next whitespace). */
953
a04257e6
DC
954 if (**argptr == '$') /* May be a convenience variable. */
955 /* One or two $ chars possible. */
956 p = skip_quoted (*argptr + (((*argptr)[1] == '$') ? 2 : 1));
50641945
FN
957 else if (is_quoted)
958 {
791dfb64 959 p = end_quote;
50641945 960 if (p[-1] != '\'')
8a3fe4f8 961 error (_("Unmatched single quote."));
50641945 962 }
d2630e69
AF
963 else if (is_objc_method)
964 {
1777feb0 965 /* allow word separators in method names for Obj-C. */
d2630e69
AF
966 p = skip_quoted_chars (*argptr, NULL, "");
967 }
50641945
FN
968 else
969 {
970 p = skip_quoted (*argptr);
971 }
972
c00f8484
KS
973 /* Keep any important naming information. */
974 p = keep_name_info (p);
94af9270 975
50641945
FN
976 copy = (char *) alloca (p - *argptr + 1);
977 memcpy (copy, *argptr, p - *argptr);
978 copy[p - *argptr] = '\0';
979 if (p != *argptr
980 && copy[0]
981 && copy[0] == copy[p - *argptr - 1]
c5f0f3d0 982 && strchr (get_gdb_completer_quote_characters (), copy[0]) != NULL)
50641945
FN
983 {
984 copy[p - *argptr - 1] = '\0';
985 copy++;
986 }
791dfb64
DJ
987 else if (is_quoted)
988 copy[p - *argptr - 1] = '\0';
50641945
FN
989 while (*p == ' ' || *p == '\t')
990 p++;
991 *argptr = p;
992
993 /* If it starts with $: may be a legitimate variable or routine name
994 (e.g. HP-UX millicode routines such as $$dyncall), or it may
a04257e6 995 be history value, or it may be a convenience variable. */
50641945 996
9ef07c8c 997 if (*copy == '$' && function_symbol == NULL)
14e91ac5 998 return decode_dollar (copy, funfirstline, default_symtab,
88d262ca 999 canonical, file_symtab);
50641945 1000
0f5238ed
TT
1001 /* Try the token as a label, but only if no file was specified,
1002 because we can only really find labels in the current scope. */
1003
1004 if (!file_symtab)
1005 {
1006 struct symtabs_and_lines label_result;
9ef07c8c 1007 if (decode_label (function_symbol, copy, canonical, &label_result))
0f5238ed
TT
1008 return label_result;
1009 }
1010
9ef07c8c 1011 if (function_symbol)
58438ac1 1012 throw_exception (file_exception);
9ef07c8c 1013
50641945
FN
1014 /* Look up that token as a variable.
1015 If file specified, use that file's per-file block to start with. */
1016
58438ac1 1017 return decode_variable (copy, funfirstline, canonical, file_symtab);
413dad4d 1018}
50641945 1019
44fe14ab
DC
1020\f
1021
614b3b14
DC
1022/* Now, more helper functions for decode_line_1. Some conventions
1023 that these functions follow:
1024
1025 Decode_line_1 typically passes along some of its arguments or local
1026 variables to the subfunctions. It passes the variables by
1027 reference if they are modified by the subfunction, and by value
1028 otherwise.
1029
1030 Some of the functions have side effects that don't arise from
1031 variables that are passed by reference. In particular, if a
1032 function is passed ARGPTR as an argument, it modifies what ARGPTR
1033 points to; typically, it advances *ARGPTR past whatever substring
1034 it has just looked at. (If it doesn't modify *ARGPTR, then the
94af9270
KS
1035 function gets passed *ARGPTR instead, which is then called ARG.)
1036 Also, functions that return a struct symtabs_and_lines may modify
1037 CANONICAL, as in the description of decode_line_1.
614b3b14
DC
1038
1039 If a function returns a struct symtabs_and_lines, then that struct
1040 will immediately make its way up the call chain to be returned by
1041 decode_line_1. In particular, all of the functions decode_XXX
1042 calculate the appropriate struct symtabs_and_lines, under the
1043 assumption that their argument is of the form XXX. */
44fe14ab
DC
1044
1045/* First, some functions to initialize stuff at the beggining of the
1046 function. */
1047
1048static void
1049initialize_defaults (struct symtab **default_symtab, int *default_line)
1050{
1051 if (*default_symtab == 0)
1052 {
1053 /* Use whatever we have for the default source line. We don't use
1054 get_current_or_default_symtab_and_line as it can recurse and call
1777feb0 1055 us back! */
44fe14ab
DC
1056 struct symtab_and_line cursal =
1057 get_current_source_symtab_and_line ();
1058
1059 *default_symtab = cursal.symtab;
1060 *default_line = cursal.line;
1061 }
1062}
1063
1064\f
1065
1066/* Decode arg of the form *PC. */
1067
1068static struct symtabs_and_lines
1069decode_indirect (char **argptr)
1070{
1071 struct symtabs_and_lines values;
1072 CORE_ADDR pc;
1073
1074 (*argptr)++;
63ffa6ee 1075 pc = value_as_address (parse_to_comma_and_eval (argptr));
44fe14ab
DC
1076
1077 values.sals = (struct symtab_and_line *)
1078 xmalloc (sizeof (struct symtab_and_line));
1079
1080 values.nelts = 1;
1081 values.sals[0] = find_pc_line (pc, 0);
1082 values.sals[0].pc = pc;
1083 values.sals[0].section = find_pc_overlay (pc);
ed0616c6 1084 values.sals[0].explicit_pc = 1;
44fe14ab
DC
1085
1086 return values;
1087}
413dad4d
DC
1088
1089\f
1090
0960f083
DC
1091/* Locate the first half of the linespec, ending in a colon, period,
1092 or whitespace. (More or less.) Also, check to see if *ARGPTR is
1093 enclosed in double quotes; if so, set is_quote_enclosed, advance
17763fd9
EZ
1094 ARGPTR past that and zero out the trailing double quote.
1095 If ARGPTR is just a simple name like "main", p will point to ""
1096 at the end. */
0960f083
DC
1097
1098static char *
1099locate_first_half (char **argptr, int *is_quote_enclosed)
1100{
1101 char *ii;
1102 char *p, *p1;
1103 int has_comma;
1104
1105 /* Maybe we were called with a line range FILENAME:LINENUM,FILENAME:LINENUM
1106 and we must isolate the first half. Outer layers will call again later
1107 for the second half.
1108
1109 Don't count commas that appear in argument lists of overloaded
1110 functions, or in quoted strings. It's stupid to go to this much
1111 trouble when the rest of the function is such an obvious roach hotel. */
1112 ii = find_toplevel_char (*argptr, ',');
1113 has_comma = (ii != 0);
1114
a04257e6 1115 /* Temporarily zap out second half to not confuse the code below.
1777feb0 1116 This is undone below. Do not change ii!! */
0960f083
DC
1117 if (has_comma)
1118 {
1119 *ii = '\0';
1120 }
1121
a04257e6
DC
1122 /* Maybe arg is FILE : LINENUM or FILE : FUNCTION. May also be
1123 CLASS::MEMBER, or NAMESPACE::NAME. Look for ':', but ignore
1124 inside of <>. */
0960f083
DC
1125
1126 p = *argptr;
1127 if (p[0] == '"')
1128 {
1129 *is_quote_enclosed = 1;
1130 (*argptr)++;
1131 p++;
1132 }
1133 else
0e0b460e
KS
1134 {
1135 *is_quote_enclosed = 0;
1136 if (strchr (get_gdb_completer_quote_characters (), *p))
1137 {
1138 ++(*argptr);
1139 ++p;
1140 }
1141 }
0960f083
DC
1142 for (; *p; p++)
1143 {
1144 if (p[0] == '<')
1145 {
1146 char *temp_end = find_template_name_end (p);
e0881a8e 1147
0960f083 1148 if (!temp_end)
8a3fe4f8 1149 error (_("malformed template specification in command"));
0960f083
DC
1150 p = temp_end;
1151 }
c00f8484
KS
1152
1153 if (p[0] == '(')
1154 p = find_method_overload_end (p);
1155
d2630e69 1156 /* Check for a colon and a plus or minus and a [ (which
1777feb0 1157 indicates an Objective-C method). */
889f28e2 1158 if (is_objc_method_format (p))
d2630e69
AF
1159 {
1160 break;
1161 }
a04257e6
DC
1162 /* Check for the end of the first half of the linespec. End of
1163 line, a tab, a double colon or the last single colon, or a
1164 space. But if enclosed in double quotes we do not break on
1165 enclosed spaces. */
0960f083
DC
1166 if (!*p
1167 || p[0] == '\t'
1168 || ((p[0] == ':')
1169 && ((p[1] == ':') || (strchr (p + 1, ':') == NULL)))
1170 || ((p[0] == ' ') && !*is_quote_enclosed))
1171 break;
a04257e6 1172 if (p[0] == '.' && strchr (p, ':') == NULL)
0960f083 1173 {
a04257e6 1174 /* Java qualified method. Find the *last* '.', since the
94af9270
KS
1175 others are package qualifiers. Stop at any open parenthesis
1176 which might provide overload information. */
1177 for (p1 = p; *p1 && *p1 != '('; p1++)
0960f083
DC
1178 {
1179 if (*p1 == '.')
1180 p = p1;
1181 }
1182 break;
1183 }
1184 }
1185 while (p[0] == ' ' || p[0] == '\t')
1186 p++;
1187
a04257e6 1188 /* If the closing double quote was left at the end, remove it. */
0960f083
DC
1189 if (*is_quote_enclosed)
1190 {
1191 char *closing_quote = strchr (p - 1, '"');
e0881a8e 1192
0960f083
DC
1193 if (closing_quote && closing_quote[1] == '\0')
1194 *closing_quote = '\0';
1195 }
1196
a04257e6
DC
1197 /* Now that we've safely parsed the first half, put back ',' so
1198 outer layers can see it. */
0960f083
DC
1199 if (has_comma)
1200 *ii = ',';
1201
1202 return p;
1203}
1204
1205\f
1206
d2630e69
AF
1207/* Here's where we recognise an Objective-C Selector. An Objective C
1208 selector may be implemented by more than one class, therefore it
1209 may represent more than one method/function. This gives us a
1210 situation somewhat analogous to C++ overloading. If there's more
1211 than one method that could represent the selector, then use some of
1212 the existing C++ code to let the user choose one. */
1213
1214struct symtabs_and_lines
1215decode_objc (char **argptr, int funfirstline, struct symtab *file_symtab,
7efd8fc2 1216 struct linespec_result *canonical, char *saved_arg)
d2630e69
AF
1217{
1218 struct symtabs_and_lines values;
1219 struct symbol **sym_arr = NULL;
1220 struct symbol *sym = NULL;
d2630e69 1221 struct block *block = NULL;
15550d6b
MK
1222 unsigned i1 = 0;
1223 unsigned i2 = 0;
d2630e69
AF
1224
1225 values.sals = NULL;
1226 values.nelts = 0;
1227
1228 if (file_symtab != NULL)
1229 block = BLOCKVECTOR_BLOCK (BLOCKVECTOR (file_symtab), STATIC_BLOCK);
1230 else
c4fc331b
AS
1231 {
1232 enum language save_language;
1233
1234 /* get_selected_block can change the current language when there is
1235 no selected frame yet. */
1236 save_language = current_language->la_language;
1237 block = get_selected_block (0);
1238 set_language (save_language);
1239 }
1240
5715d26e 1241 find_imps (file_symtab, block, *argptr, NULL, &i1, &i2);
d2630e69
AF
1242
1243 if (i1 > 0)
1244 {
1777feb0
MS
1245 sym_arr = (struct symbol **)
1246 alloca ((i1 + 1) * sizeof (struct symbol *));
46be51c4 1247 sym_arr[i1] = NULL;
d2630e69 1248
5715d26e 1249 *argptr = find_imps (file_symtab, block, *argptr, sym_arr, &i1, &i2);
d2630e69
AF
1250 }
1251
1252 /* i1 now represents the TOTAL number of matches found.
1253 i2 represents how many HIGH-LEVEL (struct symbol) matches,
1254 which will come first in the sym_arr array. Any low-level
1255 (minimal_symbol) matches will follow those. */
1256
1257 if (i1 == 1)
1258 {
1259 if (i2 > 0)
1260 {
1261 /* Already a struct symbol. */
1262 sym = sym_arr[0];
1263 }
1264 else
1265 {
1266 sym = find_pc_function (SYMBOL_VALUE_ADDRESS (sym_arr[0]));
3e43a32a
MS
1267 if ((sym != NULL) && strcmp (SYMBOL_LINKAGE_NAME (sym_arr[0]),
1268 SYMBOL_LINKAGE_NAME (sym)) != 0)
d2630e69 1269 {
3e43a32a
MS
1270 warning (_("debugging symbol \"%s\" does "
1271 "not match selector; ignoring"),
1272 SYMBOL_LINKAGE_NAME (sym));
d2630e69
AF
1273 sym = NULL;
1274 }
1275 }
1276
3e43a32a
MS
1277 values.sals = (struct symtab_and_line *)
1278 xmalloc (sizeof (struct symtab_and_line));
d2630e69
AF
1279 values.nelts = 1;
1280
1281 if (sym && SYMBOL_CLASS (sym) == LOC_BLOCK)
1282 {
1283 /* Canonicalize this, so it remains resolved for dylib loads. */
1284 values.sals[0] = find_function_start_sal (sym, funfirstline);
3e43a32a
MS
1285 build_canonical_line_spec (values.sals,
1286 SYMBOL_NATURAL_NAME (sym), canonical);
d2630e69
AF
1287 }
1288 else
1289 {
69368a60
UW
1290 /* The only match was a non-debuggable symbol, which might point
1291 to a function descriptor; resolve it to the actual code address
1292 instead. */
1293 struct minimal_symbol *msymbol = (struct minimal_symbol *)sym_arr[0];
1294 struct objfile *objfile = msymbol_objfile (msymbol);
1295 struct gdbarch *gdbarch = get_objfile_arch (objfile);
1296 CORE_ADDR pc = SYMBOL_VALUE_ADDRESS (msymbol);
1297
1298 pc = gdbarch_convert_from_func_ptr_addr (gdbarch, pc,
1299 &current_target);
1300
1301 init_sal (&values.sals[0]);
1302 values.sals[0].pc = pc;
d2630e69
AF
1303 }
1304 return values;
1305 }
1306
1307 if (i1 > 1)
1308 {
1777feb0 1309 /* More than one match. The user must choose one or more. */
d2630e69
AF
1310 return decode_line_2 (sym_arr, i2, funfirstline, canonical);
1311 }
1312
1313 return values;
1314}
1315
614b3b14 1316/* This handles C++ and Java compound data structures. P should point
17763fd9
EZ
1317 at the first component separator, i.e. double-colon or period. As
1318 an example, on entrance to this function we could have ARGPTR
1319 pointing to "AAA::inA::fun" and P pointing to "::inA::fun". */
614b3b14
DC
1320
1321static struct symtabs_and_lines
7efd8fc2
TT
1322decode_compound (char **argptr, int funfirstline,
1323 struct linespec_result *canonical,
58438ac1 1324 char *the_real_saved_arg, char *p)
614b3b14
DC
1325{
1326 struct symtabs_and_lines values;
93d91629 1327 char *p2;
614b3b14
DC
1328 char *saved_arg2 = *argptr;
1329 char *temp_end;
1330 struct symbol *sym;
614b3b14
DC
1331 char *copy;
1332 struct symbol *sym_class;
614b3b14 1333 struct type *t;
94af9270 1334 char *saved_java_argptr = NULL;
c00f8484
KS
1335 char *saved_arg;
1336
1337 /* If the user specified any completer quote characters in the input,
1338 strip them. They are superfluous. */
1339 saved_arg = alloca (strlen (the_real_saved_arg) + 1);
1340 {
1341 char *dst = saved_arg;
1342 char *src = the_real_saved_arg;
1343 char *quotes = get_gdb_completer_quote_characters ();
1344 while (*src != '\0')
1345 {
1346 if (strchr (quotes, *src) == NULL)
1347 *dst++ = *src;
1348 ++src;
1349 }
1350 *dst = '\0';
1351 }
614b3b14 1352
17763fd9
EZ
1353 /* First check for "global" namespace specification, of the form
1354 "::foo". If found, skip over the colons and jump to normal
1355 symbol processing. I.e. the whole line specification starts with
1777feb0 1356 "::" (note the condition that *argptr == p). */
614b3b14
DC
1357 if (p[0] == ':'
1358 && ((*argptr == p) || (p[-1] == ' ') || (p[-1] == '\t')))
1359 saved_arg2 += 2;
1360
87b3ede8
DC
1361 /* Given our example "AAA::inA::fun", we have two cases to consider:
1362
1363 1) AAA::inA is the name of a class. In that case, presumably it
1364 has a method called "fun"; we then look up that method using
1365 find_method.
1366
1367 2) AAA::inA isn't the name of a class. In that case, either the
c00f8484
KS
1368 user made a typo, AAA::inA is the name of a namespace, or it is
1369 the name of a minimal symbol.
1370 We just look up AAA::inA::fun with lookup_symbol. If that fails,
1371 try lookup_minimal_symbol.
87b3ede8
DC
1372
1373 Thus, our first task is to find everything before the last set of
1374 double-colons and figure out if it's the name of a class. So we
1375 first loop through all of the double-colons. */
614b3b14 1376
a04257e6 1377 p2 = p; /* Save for restart. */
17763fd9 1378
1777feb0 1379 /* This is very messy. Following the example above we have now the
17763fd9
EZ
1380 following pointers:
1381 p -> "::inA::fun"
1382 argptr -> "AAA::inA::fun
1383 saved_arg -> "AAA::inA::fun
1384 saved_arg2 -> "AAA::inA::fun
1777feb0 1385 p2 -> "::inA::fun". */
17763fd9
EZ
1386
1387 /* In the loop below, with these strings, we'll make 2 passes, each
1777feb0 1388 is marked in comments. */
17763fd9 1389
614b3b14
DC
1390 while (1)
1391 {
c00f8484
KS
1392 static char *break_characters = " \t(";
1393
a04257e6 1394 /* Move pointer up to next possible class/namespace token. */
17763fd9 1395
a04257e6 1396 p = p2 + 1; /* Restart with old value +1. */
17763fd9
EZ
1397
1398 /* PASS1: at this point p2->"::inA::fun", so p->":inA::fun",
1399 i.e. if there is a double-colon, p will now point to the
1777feb0 1400 second colon. */
87b3ede8 1401 /* PASS2: p2->"::fun", p->":fun" */
17763fd9 1402
a04257e6 1403 /* Move pointer ahead to next double-colon. */
c00f8484
KS
1404 while (*p
1405 && strchr (break_characters, *p) == NULL
1406 && strchr (get_gdb_completer_quote_characters (), *p) == NULL)
614b3b14 1407 {
12907978
KS
1408 if (current_language->la_language == language_cplus)
1409 p += cp_validate_operator (p);
1410
614b3b14
DC
1411 if (p[0] == '<')
1412 {
1413 temp_end = find_template_name_end (p);
1414 if (!temp_end)
8a3fe4f8 1415 error (_("malformed template specification in command"));
614b3b14
DC
1416 p = temp_end;
1417 }
17763fd9
EZ
1418 /* Note that, since, at the start of this loop, p would be
1419 pointing to the second colon in a double-colon, we only
1420 satisfy the condition below if there is another
1777feb0
MS
1421 double-colon to the right (after). I.e. there is another
1422 component that can be a class or a namespace. I.e, if at
17763fd9
EZ
1423 the beginning of this loop (PASS1), we had
1424 p->":inA::fun", we'll trigger this when p has been
1425 advanced to point to "::fun". */
1777feb0 1426 /* PASS2: we will not trigger this. */
614b3b14 1427 else if ((p[0] == ':') && (p[1] == ':'))
a04257e6 1428 break; /* Found double-colon. */
614b3b14 1429 else
c00f8484
KS
1430 {
1431 /* PASS2: We'll keep getting here, until P points to one of the
1432 break characters, at which point we exit this loop. */
1433 if (*p && strchr (break_characters, *p) == NULL)
1434 p++;
1435 }
614b3b14
DC
1436 }
1437
1438 if (*p != ':')
17763fd9
EZ
1439 break; /* Out of the while (1). This would happen
1440 for instance if we have looked up
1441 unsuccessfully all the components of the
1777feb0 1442 string, and p->""(PASS2). */
17763fd9 1443
c00f8484 1444 /* We get here if p points to one of the break characters or "" (i.e.,
1777feb0 1445 string ended). */
17763fd9
EZ
1446 /* Save restart for next time around. */
1447 p2 = p;
1448 /* Restore argptr as it was on entry to this function. */
1449 *argptr = saved_arg2;
87b3ede8
DC
1450 /* PASS1: at this point p->"::fun" argptr->"AAA::inA::fun",
1451 p2->"::fun". */
17763fd9
EZ
1452
1453 /* All ready for next pass through the loop. */
614b3b14
DC
1454 } /* while (1) */
1455
87b3ede8 1456
1777feb0 1457 /* Start of lookup in the symbol tables. */
87b3ede8
DC
1458
1459 /* Lookup in the symbol table the substring between argptr and
1777feb0 1460 p. Note, this call changes the value of argptr. */
87b3ede8
DC
1461 /* Before the call, argptr->"AAA::inA::fun",
1462 p->"", p2->"::fun". After the call: argptr->"fun", p, p2
1463 unchanged. */
1464 sym_class = lookup_prefix_sym (argptr, p2);
1465
1466 /* If sym_class has been found, and if "AAA::inA" is a class, then
1467 we're in case 1 above. So we look up "fun" as a method of that
1468 class. */
1469 if (sym_class &&
1470 (t = check_typedef (SYMBOL_TYPE (sym_class)),
1471 (TYPE_CODE (t) == TYPE_CODE_STRUCT
1472 || TYPE_CODE (t) == TYPE_CODE_UNION)))
1473 {
1474 /* Arg token is not digits => try it as a function name.
1475 Find the next token (everything up to end or next
1476 blank). */
1477 if (**argptr
1478 && strchr (get_gdb_completer_quote_characters (),
1479 **argptr) != NULL)
1480 {
1481 p = skip_quoted (*argptr);
1482 *argptr = *argptr + 1;
1483 }
1484 else
1485 {
1486 /* At this point argptr->"fun". */
94af9270 1487 char *a;
e0881a8e 1488
87b3ede8 1489 p = *argptr;
94af9270
KS
1490 while (*p && *p != ' ' && *p != '\t' && *p != ',' && *p != ':'
1491 && *p != '(')
87b3ede8
DC
1492 p++;
1493 /* At this point p->"". String ended. */
12907978
KS
1494 /* Nope, C++ operators could have spaces in them
1495 ("foo::operator <" or "foo::operator delete []").
1496 I apologize, this is a bit hacky... */
1497 if (current_language->la_language == language_cplus
1498 && *p == ' ' && p - 8 - *argptr + 1 > 0)
1499 {
1500 /* The above loop has already swallowed "operator". */
1501 p += cp_validate_operator (p - 8) - 8;
1502 }
94af9270 1503
c00f8484
KS
1504 /* Keep any important naming information. */
1505 p = keep_name_info (p);
94af9270
KS
1506
1507 /* Java may append typenames, so assume that if there is
1508 anything else left in *argptr, it must be a typename. */
1509 if (*p && current_language->la_language == language_java)
1510 {
1511 struct type *type;
e0881a8e 1512
94af9270
KS
1513 p2 = p;
1514 while (*p2)
1515 ++p2;
1516 copy = (char *) alloca (p2 - p + 1);
1517 memcpy (copy, p, p2 - p);
1518 copy[p2 - p] = '\0';
1519 type = lookup_typename (current_language, get_current_arch (),
1520 copy, NULL, 1);
1521 if (type != NULL)
1522 {
1523 /* Save the location of this just in case this
1524 method/type combination isn't actually defined.
1525 It will be checked later. */
1526 saved_java_argptr = p;
1527 p = p2;
1528 }
1529 }
87b3ede8
DC
1530 }
1531
1532 /* Allocate our own copy of the substring between argptr and
1777feb0 1533 p. */
87b3ede8
DC
1534 copy = (char *) alloca (p - *argptr + 1);
1535 memcpy (copy, *argptr, p - *argptr);
1536 copy[p - *argptr] = '\0';
1537 if (p != *argptr
1538 && copy[p - *argptr - 1]
1539 && strchr (get_gdb_completer_quote_characters (),
1540 copy[p - *argptr - 1]) != NULL)
1541 copy[p - *argptr - 1] = '\0';
1542
1777feb0 1543 /* At this point copy->"fun", p->"". */
87b3ede8
DC
1544
1545 /* No line number may be specified. */
1546 while (*p == ' ' || *p == '\t')
1547 p++;
1548 *argptr = p;
1549 /* At this point arptr->"". */
1550
1777feb0 1551 /* Look for copy as a method of sym_class. */
87b3ede8
DC
1552 /* At this point copy->"fun", sym_class is "AAA:inA",
1553 saved_arg->"AAA::inA::fun". This concludes the scanning of
1554 the string for possible components matches. If we find it
1777feb0 1555 here, we return. If not, and we are at the and of the string,
87b3ede8
DC
1556 we'll lookup the whole string in the symbol tables. */
1557
94af9270 1558 values = find_method (funfirstline, canonical, saved_arg,
58438ac1 1559 copy, t, sym_class);
94af9270
KS
1560 if (saved_java_argptr != NULL && values.nelts == 1)
1561 {
1562 /* The user specified a specific return type for a java method.
1563 Double-check that it really is the one the user specified.
1564 [This is a necessary evil because strcmp_iw_ordered stops
1565 comparisons too prematurely.] */
1566 sym = find_pc_sect_function (values.sals[0].pc,
1567 values.sals[0].section);
1568 /* We just found a SAL, we had better be able to go backwards! */
1569 gdb_assert (sym != NULL);
1570 if (strcmp_iw (SYMBOL_LINKAGE_NAME (sym), saved_arg) != 0)
1571 {
1572 xfree (values.sals);
3e43a32a 1573 error (_("the class `%s' does not have "
8f7e195f 1574 "any method instance named %s"),
94af9270
KS
1575 SYMBOL_PRINT_NAME (sym_class), copy);
1576 }
1577 }
1578 return values;
1777feb0 1579 } /* End if symbol found. */
87b3ede8
DC
1580
1581
1582 /* We couldn't find a class, so we're in case 2 above. We check the
1583 entire name as a symbol instead. */
1584
f17170e5 1585 p = keep_name_info (p);
c00f8484 1586
614b3b14
DC
1587 copy = (char *) alloca (p - saved_arg2 + 1);
1588 memcpy (copy, saved_arg2, p - saved_arg2);
a04257e6
DC
1589 /* Note: if is_quoted should be true, we snuff out quote here
1590 anyway. */
614b3b14 1591 copy[p - saved_arg2] = '\000';
a04257e6 1592 /* Set argptr to skip over the name. */
614b3b14 1593 *argptr = (*p == '\'') ? p + 1 : p;
17763fd9 1594
1777feb0 1595 /* Look up entire name. */
c00f8484 1596 sym = lookup_symbol (copy, get_selected_block (0), VAR_DOMAIN, 0);
614b3b14 1597 if (sym)
9ef07c8c 1598 return symbol_found (funfirstline, canonical, copy, sym, NULL, NULL);
c00f8484
KS
1599 else
1600 {
1601 struct minimal_symbol *msym;
1602
1603 /* Couldn't find any interpretation as classes/namespaces. As a last
1604 resort, try the minimal symbol tables. */
1605 msym = lookup_minimal_symbol (copy, NULL, NULL);
1606 if (msym != NULL)
1607 return minsym_found (funfirstline, msym);
1608 }
614b3b14 1609
c00f8484 1610 /* Couldn't find a minimal symbol, either, so give up. */
c00f8484 1611 cplusplus_error (the_real_saved_arg,
3e43a32a
MS
1612 "Can't find member of namespace, "
1613 "class, struct, or union named \"%s\"\n",
614b3b14
DC
1614 copy);
1615}
1616
93d91629
DC
1617/* Next come some helper functions for decode_compound. */
1618
1619/* Return the symbol corresponding to the substring of *ARGPTR ending
1620 at P, allowing whitespace. Also, advance *ARGPTR past the symbol
1621 name in question, the compound object separator ("::" or "."), and
17763fd9
EZ
1622 whitespace. Note that *ARGPTR is changed whether or not the
1623 lookup_symbol call finds anything (i.e we return NULL). As an
1624 example, say ARGPTR is "AAA::inA::fun" and P is "::inA::fun". */
93d91629
DC
1625
1626static struct symbol *
1627lookup_prefix_sym (char **argptr, char *p)
1628{
1629 char *p1;
1630 char *copy;
1e5a1abc 1631 struct symbol *sym;
93d91629
DC
1632
1633 /* Extract the class name. */
1634 p1 = p;
1635 while (p != *argptr && p[-1] == ' ')
1636 --p;
1637 copy = (char *) alloca (p - *argptr + 1);
1638 memcpy (copy, *argptr, p - *argptr);
1639 copy[p - *argptr] = 0;
1640
17763fd9 1641 /* Discard the class name from the argptr. */
93d91629
DC
1642 p = p1 + (p1[0] == ':' ? 2 : 1);
1643 while (*p == ' ' || *p == '\t')
1644 p++;
1645 *argptr = p;
1646
17763fd9 1647 /* At this point p1->"::inA::fun", p->"inA::fun" copy->"AAA",
1777feb0 1648 argptr->"inA::fun". */
17763fd9 1649
c00f8484 1650 sym = lookup_symbol (copy, get_selected_block (0), STRUCT_DOMAIN, 0);
1e5a1abc
KS
1651 if (sym == NULL)
1652 {
1653 /* Typedefs are in VAR_DOMAIN so the above symbol lookup will
1654 fail when the user attempts to lookup a method of a class
1655 via a typedef'd name (NOT via the class's name, which is already
1656 handled in symbol_matches_domain). So try the lookup again
1657 using VAR_DOMAIN (where typedefs live) and double-check that we
1658 found a struct/class type. */
1659 struct symbol *s = lookup_symbol (copy, 0, VAR_DOMAIN, 0);
e0881a8e 1660
1e5a1abc
KS
1661 if (s != NULL)
1662 {
1663 struct type *t = SYMBOL_TYPE (s);
e0881a8e 1664
1e5a1abc
KS
1665 CHECK_TYPEDEF (t);
1666 if (TYPE_CODE (t) == TYPE_CODE_STRUCT)
1667 return s;
1668 }
1669 }
1670
1671 return sym;
93d91629
DC
1672}
1673
4224873a
DC
1674/* This finds the method COPY in the class whose type is T and whose
1675 symbol is SYM_CLASS. */
1676
1677static struct symtabs_and_lines
7efd8fc2
TT
1678find_method (int funfirstline, struct linespec_result *canonical,
1679 char *saved_arg,
58438ac1 1680 char *copy, struct type *t, struct symbol *sym_class)
4224873a
DC
1681{
1682 struct symtabs_and_lines values;
46be51c4 1683 struct symbol *sym = NULL;
78a11fb4 1684 int i1; /* Counter for the symbol array. */
4224873a
DC
1685 struct symbol **sym_arr = alloca (total_number_of_methods (t)
1686 * sizeof (struct symbol *));
1687
78a11fb4
DC
1688 /* Find all methods with a matching name, and put them in
1689 sym_arr. */
4224873a 1690
19ef5c71 1691 i1 = find_methods (t, copy, SYMBOL_LANGUAGE (sym_class), sym_arr);
4224873a 1692
4224873a
DC
1693 if (i1 == 1)
1694 {
1695 /* There is exactly one field with that name. */
1696 sym = sym_arr[0];
1697
1698 if (sym && SYMBOL_CLASS (sym) == LOC_BLOCK)
1699 {
1700 values.sals = (struct symtab_and_line *)
1701 xmalloc (sizeof (struct symtab_and_line));
1702 values.nelts = 1;
1703 values.sals[0] = find_function_start_sal (sym,
1704 funfirstline);
1705 }
1706 else
1707 {
15550d6b 1708 values.sals = NULL;
4224873a
DC
1709 values.nelts = 0;
1710 }
1711 return values;
1712 }
1713 if (i1 > 0)
1714 {
94af9270
KS
1715 /* If we were given a specific overload instance, use that
1716 (or error if no matches were found). Otherwise ask the user
1717 which one to use. */
c00f8484 1718 if (strchr (copy, '('))
94af9270
KS
1719 {
1720 int i;
c00f8484
KS
1721 char *name;
1722 char *canon;
d03a3acf 1723 struct cleanup *cleanup;
e0881a8e 1724
c00f8484
KS
1725 /* Construct the proper search name based on SYM_CLASS and COPY.
1726 SAVED_ARG may contain a valid name, but that name might not be
1727 what is actually stored in the symbol table. For example,
1728 if SAVED_ARG (and SYM_CLASS) were found via an import
1729 ("using namespace" in C++), then the physname of
1730 SYM_CLASS ("A::myclass") may not be the same as SAVED_ARG
1731 ("myclass"). */
1732 name = xmalloc (strlen (SYMBOL_NATURAL_NAME (sym_class))
1733 + 2 /* "::" */ + strlen (copy) + 1);
1734 strcpy (name, SYMBOL_NATURAL_NAME (sym_class));
1735 strcat (name, "::");
1736 strcat (name, copy);
1737 canon = cp_canonicalize_string (name);
d03a3acf 1738 if (canon != NULL)
94af9270 1739 {
c00f8484 1740 xfree (name);
d03a3acf 1741 name = canon;
d03a3acf 1742 }
c00f8484 1743 cleanup = make_cleanup (xfree, name);
94af9270 1744
d03a3acf
KS
1745 for (i = 0; i < i1; ++i)
1746 {
94af9270
KS
1747 if (strcmp_iw (name, SYMBOL_LINKAGE_NAME (sym_arr[i])) == 0)
1748 {
1749 values.sals = (struct symtab_and_line *)
1750 xmalloc (sizeof (struct symtab_and_line));
1751 values.nelts = 1;
1752 values.sals[0] = find_function_start_sal (sym_arr[i],
1753 funfirstline);
d03a3acf 1754 do_cleanups (cleanup);
94af9270
KS
1755 return values;
1756 }
94af9270
KS
1757 }
1758
3e43a32a 1759 error (_("the class `%s' does not have "
8f7e195f 1760 "any method instance named %s"),
94af9270
KS
1761 SYMBOL_PRINT_NAME (sym_class), copy);
1762 }
1763
4224873a
DC
1764 return decode_line_2 (sym_arr, i1, funfirstline, canonical);
1765 }
1766 else
1767 {
12907978 1768 if (copy[0] == '~')
4224873a
DC
1769 cplusplus_error (saved_arg,
1770 "the class `%s' does not have destructor defined\n",
1771 SYMBOL_PRINT_NAME (sym_class));
1772 else
1773 cplusplus_error (saved_arg,
1774 "the class %s does not have any method named %s\n",
12907978 1775 SYMBOL_PRINT_NAME (sym_class), copy);
4224873a
DC
1776 }
1777}
1778
f3c39e76
DC
1779\f
1780
1781/* Return the symtab associated to the filename given by the substring
58438ac1 1782 of *ARGPTR ending at P, and advance ARGPTR past that filename. */
f3c39e76
DC
1783
1784static struct symtab *
58438ac1 1785symtab_from_filename (char **argptr, char *p, int is_quote_enclosed)
f3c39e76
DC
1786{
1787 char *p1;
1788 char *copy;
94cd26f8 1789 struct symtab *file_symtab;
f3c39e76
DC
1790
1791 p1 = p;
1792 while (p != *argptr && p[-1] == ' ')
1793 --p;
1794 if ((*p == '"') && is_quote_enclosed)
1795 --p;
1796 copy = (char *) alloca (p - *argptr + 1);
1797 memcpy (copy, *argptr, p - *argptr);
a04257e6 1798 /* It may have the ending quote right after the file name. */
0e0b460e
KS
1799 if ((is_quote_enclosed && copy[p - *argptr - 1] == '"')
1800 || copy[p - *argptr - 1] == '\'')
f3c39e76
DC
1801 copy[p - *argptr - 1] = 0;
1802 else
1803 copy[p - *argptr] = 0;
1804
1805 /* Find that file's data. */
94cd26f8
DC
1806 file_symtab = lookup_symtab (copy);
1807 if (file_symtab == 0)
f3c39e76 1808 {
b96e2927
PA
1809 if (!have_full_symbols () && !have_partial_symbols ())
1810 throw_error (NOT_FOUND_ERROR,
3e43a32a
MS
1811 _("No symbol table is loaded. "
1812 "Use the \"file\" command."));
109c3e39 1813 throw_error (NOT_FOUND_ERROR, _("No source file named %s."), copy);
f3c39e76
DC
1814 }
1815
1816 /* Discard the file name from the arg. */
1817 p = p1 + 1;
1818 while (*p == ' ' || *p == '\t')
1819 p++;
1820 *argptr = p;
1821
94cd26f8 1822 return file_symtab;
f3c39e76
DC
1823}
1824
9ef07c8c
TT
1825/* Look up a function symbol in *ARGPTR. If found, advance *ARGPTR
1826 and return the symbol. If not found, return NULL. */
1827
1828static struct symbol *
1829find_function_symbol (char **argptr, char *p, int is_quote_enclosed)
1830{
1831 char *p1;
1832 char *copy;
1833 struct symbol *function_symbol;
1834
1835 p1 = p;
1836 while (p != *argptr && p[-1] == ' ')
1837 --p;
1838 if ((*p == '"') && is_quote_enclosed)
1839 --p;
1840 copy = (char *) alloca (p - *argptr + 1);
1841 memcpy (copy, *argptr, p - *argptr);
1842 /* It may have the ending quote right after the file name. */
1843 if ((is_quote_enclosed && copy[p - *argptr - 1] == '"')
1844 || copy[p - *argptr - 1] == '\'')
1845 copy[p - *argptr - 1] = 0;
1846 else
1847 copy[p - *argptr] = 0;
1848
1849 function_symbol = lookup_symbol (copy, get_selected_block (0),
1850 VAR_DOMAIN, 0);
1851 if (!function_symbol || SYMBOL_CLASS (function_symbol) != LOC_BLOCK)
1852 return NULL;
1853
1854 /* Discard the file name from the arg. */
1855 p = p1 + 1;
1856 while (*p == ' ' || *p == '\t')
1857 p++;
1858 *argptr = p;
1859
1860 return function_symbol;
1861}
1862
84fba31b
DC
1863\f
1864
1865/* This decodes a line where the argument is all digits (possibly
1866 preceded by a sign). Q should point to the end of those digits;
1867 the other arguments are as usual. */
1868
1869static struct symtabs_and_lines
1870decode_all_digits (char **argptr, struct symtab *default_symtab,
7efd8fc2 1871 int default_line, struct linespec_result *canonical,
88d262ca 1872 struct symtab *file_symtab, char *q)
84fba31b
DC
1873
1874{
1875 struct symtabs_and_lines values;
1876 struct symtab_and_line val;
1877
1878 enum sign
1879 {
1880 none, plus, minus
1881 }
1882 sign = none;
1883
1884 /* We might need a canonical line spec if no file was specified. */
46be51c4 1885 int need_canonical = (file_symtab == NULL) ? 1 : 0;
84fba31b
DC
1886
1887 init_sal (&val);
1888
6c95b8df
PA
1889 val.pspace = current_program_space;
1890
84fba31b
DC
1891 /* This is where we need to make sure that we have good defaults.
1892 We must guarantee that this section of code is never executed
1893 when we are called with just a function name, since
1894 set_default_source_symtab_and_line uses
a04257e6 1895 select_source_symtab that calls us with such an argument. */
84fba31b 1896
88d262ca 1897 if (file_symtab == 0 && default_symtab == 0)
84fba31b 1898 {
a04257e6 1899 /* Make sure we have at least a default source file. */
84fba31b
DC
1900 set_default_source_symtab_and_line ();
1901 initialize_defaults (&default_symtab, &default_line);
1902 }
1903
1904 if (**argptr == '+')
1905 sign = plus, (*argptr)++;
1906 else if (**argptr == '-')
1907 sign = minus, (*argptr)++;
1908 val.line = atoi (*argptr);
1909 switch (sign)
1910 {
1911 case plus:
1912 if (q == *argptr)
1913 val.line = 5;
88d262ca 1914 if (file_symtab == 0)
84fba31b
DC
1915 val.line = default_line + val.line;
1916 break;
1917 case minus:
1918 if (q == *argptr)
1919 val.line = 15;
88d262ca 1920 if (file_symtab == 0)
84fba31b
DC
1921 val.line = default_line - val.line;
1922 else
1923 val.line = 1;
1924 break;
1925 case none:
1926 break; /* No need to adjust val.line. */
1927 }
1928
1929 while (*q == ' ' || *q == '\t')
1930 q++;
1931 *argptr = q;
88d262ca
DC
1932 if (file_symtab == 0)
1933 file_symtab = default_symtab;
84fba31b
DC
1934
1935 /* It is possible that this source file has more than one symtab,
1936 and that the new line number specification has moved us from the
88d262ca
DC
1937 default (in file_symtab) to a new one. */
1938 val.symtab = find_line_symtab (file_symtab, val.line, NULL, NULL);
84fba31b 1939 if (val.symtab == 0)
88d262ca 1940 val.symtab = file_symtab;
84fba31b 1941
6c95b8df 1942 val.pspace = SYMTAB_PSPACE (val.symtab);
84fba31b
DC
1943 val.pc = 0;
1944 values.sals = (struct symtab_and_line *)
1945 xmalloc (sizeof (struct symtab_and_line));
1946 values.sals[0] = val;
1947 values.nelts = 1;
1948 if (need_canonical)
1949 build_canonical_line_spec (values.sals, NULL, canonical);
ed0616c6 1950 values.sals[0].explicit_line = 1;
84fba31b
DC
1951 return values;
1952}
f3c39e76 1953
614b3b14
DC
1954\f
1955
14e91ac5
DC
1956/* Decode a linespec starting with a dollar sign. */
1957
1958static struct symtabs_and_lines
1959decode_dollar (char *copy, int funfirstline, struct symtab *default_symtab,
7efd8fc2 1960 struct linespec_result *canonical, struct symtab *file_symtab)
14e91ac5 1961{
4fa62494 1962 LONGEST valx;
14e91ac5
DC
1963 int index = 0;
1964 int need_canonical = 0;
1965 struct symtabs_and_lines values;
1966 struct symtab_and_line val;
1967 char *p;
1968 struct symbol *sym;
14e91ac5
DC
1969 struct minimal_symbol *msymbol;
1970
1971 p = (copy[1] == '$') ? copy + 2 : copy + 1;
1972 while (*p >= '0' && *p <= '9')
1973 p++;
a04257e6 1974 if (!*p) /* Reached end of token without hitting non-digit. */
14e91ac5 1975 {
a04257e6 1976 /* We have a value history reference. */
4fa62494 1977 struct value *val_history;
e0881a8e 1978
14e91ac5 1979 sscanf ((copy[1] == '$') ? copy + 2 : copy + 1, "%d", &index);
4fa62494
UW
1980 val_history = access_value_history ((copy[1] == '$') ? -index : index);
1981 if (TYPE_CODE (value_type (val_history)) != TYPE_CODE_INT)
3e43a32a
MS
1982 error (_("History values used in line "
1983 "specs must have integer values."));
4fa62494 1984 valx = value_as_long (val_history);
14e91ac5
DC
1985 }
1986 else
1987 {
1988 /* Not all digits -- may be user variable/function or a
a04257e6 1989 convenience variable. */
14e91ac5 1990
a04257e6 1991 /* Look up entire name as a symbol first. */
2570f2b7 1992 sym = lookup_symbol (copy, 0, VAR_DOMAIN, 0);
46be51c4 1993 file_symtab = (struct symtab *) NULL;
14e91ac5
DC
1994 need_canonical = 1;
1995 /* Symbol was found --> jump to normal symbol processing. */
1996 if (sym)
9ef07c8c 1997 return symbol_found (funfirstline, canonical, copy, sym, NULL, NULL);
14e91ac5 1998
a04257e6 1999 /* If symbol was not found, look in minimal symbol tables. */
14e91ac5 2000 msymbol = lookup_minimal_symbol (copy, NULL, NULL);
a04257e6 2001 /* Min symbol was found --> jump to minsym processing. */
14e91ac5
DC
2002 if (msymbol)
2003 return minsym_found (funfirstline, msymbol);
2004
a04257e6 2005 /* Not a user variable or function -- must be convenience variable. */
4fa62494 2006 if (!get_internalvar_integer (lookup_internalvar (copy + 1), &valx))
3e43a32a
MS
2007 error (_("Convenience variables used in line "
2008 "specs must have integer values."));
14e91ac5
DC
2009 }
2010
2011 init_sal (&val);
2012
a04257e6 2013 /* Either history value or convenience value from above, in valx. */
88d262ca 2014 val.symtab = file_symtab ? file_symtab : default_symtab;
4fa62494 2015 val.line = valx;
14e91ac5 2016 val.pc = 0;
6c95b8df 2017 val.pspace = current_program_space;
14e91ac5
DC
2018
2019 values.sals = (struct symtab_and_line *) xmalloc (sizeof val);
2020 values.sals[0] = val;
2021 values.nelts = 1;
2022
2023 if (need_canonical)
2024 build_canonical_line_spec (values.sals, NULL, canonical);
2025
2026 return values;
2027}
2028
bca02a8a
DC
2029\f
2030
0f5238ed
TT
2031/* A helper for decode_line_1 that tries to find a label. The label
2032 is searched for in the current block.
9ef07c8c
TT
2033 FUNCTION_SYMBOL is the enclosing function; or NULL if none
2034 specified.
0f5238ed
TT
2035 COPY is the name of the label to find.
2036 CANONICAL is the same as the "canonical" argument to decode_line_1.
2037 RESULT is a pointer to a symtabs_and_lines structure which will be
2038 filled in on success.
2039 This function returns 1 if a label was found, 0 otherwise. */
2040
2041static int
9ef07c8c
TT
2042decode_label (struct symbol *function_symbol, char *copy,
2043 struct linespec_result *canonical,
7efd8fc2 2044 struct symtabs_and_lines *result)
0f5238ed
TT
2045{
2046 struct symbol *sym;
9ef07c8c
TT
2047 struct block *block;
2048
2049 if (function_symbol)
2050 block = SYMBOL_BLOCK_VALUE (function_symbol);
2051 else
2052 {
2053 block = get_selected_block (0);
2054 for (;
2055 block && !BLOCK_FUNCTION (block);
2056 block = BLOCK_SUPERBLOCK (block))
2057 ;
2058 if (!block)
2059 return 0;
2060 function_symbol = BLOCK_FUNCTION (block);
2061 }
0f5238ed 2062
9ef07c8c 2063 sym = lookup_symbol (copy, block, LABEL_DOMAIN, 0);
0f5238ed
TT
2064
2065 if (sym != NULL)
9ef07c8c 2066 *result = symbol_found (0, canonical, copy, sym, NULL, function_symbol);
0f5238ed
TT
2067
2068 return sym != NULL;
2069}
2070
88d262ca 2071/* Decode a linespec that's a variable. If FILE_SYMTAB is non-NULL,
58438ac1 2072 look in that symtab's static variables first. */
bca02a8a
DC
2073
2074static struct symtabs_and_lines
7efd8fc2
TT
2075decode_variable (char *copy, int funfirstline,
2076 struct linespec_result *canonical,
58438ac1 2077 struct symtab *file_symtab)
bca02a8a
DC
2078{
2079 struct symbol *sym;
bca02a8a
DC
2080 struct minimal_symbol *msymbol;
2081
2082 sym = lookup_symbol (copy,
88d262ca
DC
2083 (file_symtab
2084 ? BLOCKVECTOR_BLOCK (BLOCKVECTOR (file_symtab),
2085 STATIC_BLOCK)
bca02a8a 2086 : get_selected_block (0)),
2570f2b7 2087 VAR_DOMAIN, 0);
bca02a8a
DC
2088
2089 if (sym != NULL)
9ef07c8c 2090 return symbol_found (funfirstline, canonical, copy, sym, file_symtab, NULL);
bca02a8a
DC
2091
2092 msymbol = lookup_minimal_symbol (copy, NULL, NULL);
2093
2094 if (msymbol != NULL)
2095 return minsym_found (funfirstline, msymbol);
2096
b96e2927
PA
2097 if (!have_full_symbols ()
2098 && !have_partial_symbols ()
2099 && !have_minimal_symbols ())
2100 throw_error (NOT_FOUND_ERROR,
2101 _("No symbol table is loaded. Use the \"file\" command."));
109c3e39 2102 throw_error (NOT_FOUND_ERROR, _("Function \"%s\" not defined."), copy);
bca02a8a
DC
2103}
2104
2105
14e91ac5
DC
2106\f
2107
413dad4d
DC
2108/* Now come some functions that are called from multiple places within
2109 decode_line_1. */
2110
2111/* We've found a symbol SYM to associate with our linespec; build a
2112 corresponding struct symtabs_and_lines. */
2113
2114static struct symtabs_and_lines
7efd8fc2 2115symbol_found (int funfirstline, struct linespec_result *canonical, char *copy,
9ef07c8c
TT
2116 struct symbol *sym, struct symtab *file_symtab,
2117 struct symbol *function_symbol)
413dad4d
DC
2118{
2119 struct symtabs_and_lines values;
2120
2121 if (SYMBOL_CLASS (sym) == LOC_BLOCK)
50641945 2122 {
1777feb0 2123 /* Arg is the name of a function. */
50641945
FN
2124 values.sals = (struct symtab_and_line *)
2125 xmalloc (sizeof (struct symtab_and_line));
413dad4d
DC
2126 values.sals[0] = find_function_start_sal (sym, funfirstline);
2127 values.nelts = 1;
2128
2129 /* Don't use the SYMBOL_LINE; if used at all it points to
2130 the line containing the parameters or thereabouts, not
2131 the first line of code. */
2132
2133 /* We might need a canonical line spec if it is a static
2134 function. */
88d262ca 2135 if (file_symtab == 0)
50641945 2136 {
2570f2b7 2137 struct blockvector *bv = BLOCKVECTOR (SYMBOL_SYMTAB (sym));
413dad4d 2138 struct block *b = BLOCKVECTOR_BLOCK (bv, STATIC_BLOCK);
e0881a8e 2139
94af9270 2140 if (lookup_block_symbol (b, copy, VAR_DOMAIN) != NULL)
413dad4d 2141 build_canonical_line_spec (values.sals, copy, canonical);
50641945 2142 }
50641945
FN
2143 return values;
2144 }
413dad4d
DC
2145 else
2146 {
62853458 2147 if (SYMBOL_CLASS (sym) == LOC_LABEL && SYMBOL_VALUE_ADDRESS (sym) != 0)
413dad4d
DC
2148 {
2149 /* We know its line number. */
2150 values.sals = (struct symtab_and_line *)
2151 xmalloc (sizeof (struct symtab_and_line));
2152 values.nelts = 1;
9ef07c8c 2153 init_sal (&values.sals[0]);
2570f2b7 2154 values.sals[0].symtab = SYMBOL_SYMTAB (sym);
413dad4d 2155 values.sals[0].line = SYMBOL_LINE (sym);
9ef07c8c 2156 values.sals[0].pc = SYMBOL_VALUE_ADDRESS (sym);
0f5238ed 2157 values.sals[0].pspace = SYMTAB_PSPACE (SYMBOL_SYMTAB (sym));
9ef07c8c
TT
2158 values.sals[0].explicit_pc = 1;
2159
2160 if (canonical)
2161 {
2162 canonical->special_display = 1;
2163 canonical->canonical = xmalloc (sizeof (char *));
2164 canonical->canonical[0]
2165 = xstrprintf ("%s:%s",
2166 SYMBOL_NATURAL_NAME (function_symbol),
2167 SYMBOL_NATURAL_NAME (sym));
2168 }
2169
413dad4d
DC
2170 return values;
2171 }
62853458
TT
2172 else if (funfirstline)
2173 error (_("\"%s\" is not a function"), copy);
2174 else if (SYMBOL_LINE (sym) != 0)
2175 {
2176 /* We know its line number. */
2177 values.sals = (struct symtab_and_line *)
2178 xmalloc (sizeof (struct symtab_and_line));
2179 values.nelts = 1;
2180 memset (&values.sals[0], 0, sizeof (values.sals[0]));
2181 values.sals[0].symtab = SYMBOL_SYMTAB (sym);
2182 values.sals[0].line = SYMBOL_LINE (sym);
2183 values.sals[0].pspace = SYMTAB_PSPACE (SYMBOL_SYMTAB (sym));
2184 return values;
2185 }
413dad4d
DC
2186 else
2187 /* This can happen if it is compiled with a compiler which doesn't
2188 put out line numbers for variables. */
2189 /* FIXME: Shouldn't we just set .line and .symtab to zero
2190 and return? For example, "info line foo" could print
2191 the address. */
8a3fe4f8 2192 error (_("Line number not known for symbol \"%s\""), copy);
413dad4d
DC
2193 }
2194}
50641945 2195
413dad4d
DC
2196/* We've found a minimal symbol MSYMBOL to associate with our
2197 linespec; build a corresponding struct symtabs_and_lines. */
50641945 2198
413dad4d
DC
2199static struct symtabs_and_lines
2200minsym_found (int funfirstline, struct minimal_symbol *msymbol)
2201{
bccdca4a
UW
2202 struct objfile *objfile = msymbol_objfile (msymbol);
2203 struct gdbarch *gdbarch = get_objfile_arch (objfile);
413dad4d 2204 struct symtabs_and_lines values;
bccdca4a 2205 CORE_ADDR pc;
413dad4d
DC
2206
2207 values.sals = (struct symtab_and_line *)
2208 xmalloc (sizeof (struct symtab_and_line));
2209 values.sals[0] = find_pc_sect_line (SYMBOL_VALUE_ADDRESS (msymbol),
714835d5
UW
2210 (struct obj_section *) 0, 0);
2211 values.sals[0].section = SYMBOL_OBJ_SECTION (msymbol);
bccdca4a
UW
2212
2213 /* The minimal symbol might point to a function descriptor;
2214 resolve it to the actual code address instead. */
2215 pc = gdbarch_convert_from_func_ptr_addr (gdbarch,
2216 values.sals[0].pc,
2217 &current_target);
2218 if (pc != values.sals[0].pc)
2219 values.sals[0] = find_pc_sect_line (pc, NULL, 0);
2220
413dad4d 2221 if (funfirstline)
059acae7 2222 skip_prologue_sal (&values.sals[0]);
e48883f7 2223
413dad4d
DC
2224 values.nelts = 1;
2225 return values;
50641945 2226}
7efd8fc2
TT
2227
2228void
2229init_linespec_result (struct linespec_result *lr)
2230{
2231 memset (lr, 0, sizeof (*lr));
2232}
This page took 1.013615 seconds and 4 git commands to generate.