1 /* Parse expressions for GDB.
3 Copyright (C) 1986-2017 Free Software Foundation, Inc.
5 Modified from expread.y by the Department of Computer Science at the
6 State University of New York at Buffalo, 1991.
8 This file is part of GDB.
10 This program is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 3 of the License, or
13 (at your option) any later version.
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
20 You should have received a copy of the GNU General Public License
21 along with this program. If not, see <http://www.gnu.org/licenses/>. */
23 /* Parse an expression from text in a string,
24 and return the result as a struct expression pointer.
25 That structure contains arithmetic operations in reverse polish,
26 with constants represented by operations that are followed by special data.
27 See expression.h for the details of the format.
28 What is important here is that it can be built up sequentially
29 during the process of parsing; the lower levels of the tree always
30 come first in the result. */
34 #include "arch-utils.h"
38 #include "expression.h"
43 #include "parser-defs.h"
45 #include "symfile.h" /* for overlay functions */
51 #include "user-regs.h"
53 #include "common/gdb_optional.h"
55 /* Standard set of definitions for printing, dumping, prefixifying,
56 * and evaluating expressions. */
58 const struct exp_descriptor exp_descriptor_standard =
60 print_subexp_standard,
61 operator_length_standard,
62 operator_check_standard,
64 dump_subexp_body_standard,
65 evaluate_subexp_standard
68 /* Global variables declared in parser-defs.h (and commented there). */
69 const struct block *expression_context_block;
70 CORE_ADDR expression_context_pc;
71 const struct block *innermost_block;
73 static struct type_stack type_stack;
75 const char *prev_lexptr;
79 /* True if parsing an expression to attempt completion. */
82 /* The index of the last struct expression directly before a '.' or
83 '->'. This is set when parsing and is only used when completing a
84 field name. It is -1 if no dereference operation was found. */
85 static int expout_last_struct = -1;
87 /* If we are completing a tagged type name, this will be nonzero. */
88 static enum type_code expout_tag_completion_type = TYPE_CODE_UNDEF;
90 /* The token for tagged type name completion. */
91 static char *expout_completion_name;
94 static unsigned int expressiondebug = 0;
96 show_expressiondebug (struct ui_file *file, int from_tty,
97 struct cmd_list_element *c, const char *value)
99 fprintf_filtered (file, _("Expression debugging is %s.\n"), value);
103 /* Non-zero if an expression parser should set yydebug. */
107 show_parserdebug (struct ui_file *file, int from_tty,
108 struct cmd_list_element *c, const char *value)
110 fprintf_filtered (file, _("Parser debugging is %s.\n"), value);
114 static void free_funcalls (void *ignore);
116 static int prefixify_subexp (struct expression *, struct expression *, int,
119 static expression_up parse_exp_in_context (const char **, CORE_ADDR,
120 const struct block *, int,
122 static expression_up parse_exp_in_context_1 (const char **, CORE_ADDR,
123 const struct block *, int,
126 void _initialize_parse (void);
128 /* Data structure for saving values of arglist_len for function calls whose
129 arguments contain other function calls. */
133 struct funcall *next;
137 static struct funcall *funcall_chain;
139 /* Begin counting arguments for a function call,
140 saving the data about any containing call. */
145 struct funcall *newobj;
147 newobj = XNEW (struct funcall);
148 newobj->next = funcall_chain;
149 newobj->arglist_len = arglist_len;
151 funcall_chain = newobj;
154 /* Return the number of arguments in a function call just terminated,
155 and restore the data for the containing function call. */
160 int val = arglist_len;
161 struct funcall *call = funcall_chain;
163 funcall_chain = call->next;
164 arglist_len = call->arglist_len;
169 /* Free everything in the funcall chain.
170 Used when there is an error inside parsing. */
173 free_funcalls (void *ignore)
175 struct funcall *call, *next;
177 for (call = funcall_chain; call; call = next)
185 /* See definition in parser-defs.h. */
188 initialize_expout (struct parser_state *ps, size_t initial_size,
189 const struct language_defn *lang,
190 struct gdbarch *gdbarch)
192 ps->expout_size = initial_size;
195 = (struct expression *) xmalloc (sizeof (struct expression)
196 + EXP_ELEM_TO_BYTES (ps->expout_size));
197 ps->expout->language_defn = lang;
198 ps->expout->gdbarch = gdbarch;
201 /* See definition in parser-defs.h. */
204 reallocate_expout (struct parser_state *ps)
206 /* Record the actual number of expression elements, and then
207 reallocate the expression memory so that we free up any
210 ps->expout->nelts = ps->expout_ptr;
211 ps->expout = (struct expression *)
212 xrealloc (ps->expout,
213 sizeof (struct expression)
214 + EXP_ELEM_TO_BYTES (ps->expout_ptr));
217 /* This page contains the functions for adding data to the struct expression
218 being constructed. */
220 /* Add one element to the end of the expression. */
222 /* To avoid a bug in the Sun 4 compiler, we pass things that can fit into
223 a register through here. */
226 write_exp_elt (struct parser_state *ps, const union exp_element *expelt)
228 if (ps->expout_ptr >= ps->expout_size)
230 ps->expout_size *= 2;
231 ps->expout = (struct expression *)
232 xrealloc (ps->expout, sizeof (struct expression)
233 + EXP_ELEM_TO_BYTES (ps->expout_size));
235 ps->expout->elts[ps->expout_ptr++] = *expelt;
239 write_exp_elt_opcode (struct parser_state *ps, enum exp_opcode expelt)
241 union exp_element tmp;
243 memset (&tmp, 0, sizeof (union exp_element));
245 write_exp_elt (ps, &tmp);
249 write_exp_elt_sym (struct parser_state *ps, struct symbol *expelt)
251 union exp_element tmp;
253 memset (&tmp, 0, sizeof (union exp_element));
255 write_exp_elt (ps, &tmp);
259 write_exp_elt_block (struct parser_state *ps, const struct block *b)
261 union exp_element tmp;
263 memset (&tmp, 0, sizeof (union exp_element));
265 write_exp_elt (ps, &tmp);
269 write_exp_elt_objfile (struct parser_state *ps, struct objfile *objfile)
271 union exp_element tmp;
273 memset (&tmp, 0, sizeof (union exp_element));
274 tmp.objfile = objfile;
275 write_exp_elt (ps, &tmp);
279 write_exp_elt_longcst (struct parser_state *ps, LONGEST expelt)
281 union exp_element tmp;
283 memset (&tmp, 0, sizeof (union exp_element));
284 tmp.longconst = expelt;
285 write_exp_elt (ps, &tmp);
289 write_exp_elt_dblcst (struct parser_state *ps, DOUBLEST expelt)
291 union exp_element tmp;
293 memset (&tmp, 0, sizeof (union exp_element));
294 tmp.doubleconst = expelt;
295 write_exp_elt (ps, &tmp);
299 write_exp_elt_decfloatcst (struct parser_state *ps, gdb_byte expelt[16])
301 union exp_element tmp;
304 for (index = 0; index < 16; index++)
305 tmp.decfloatconst[index] = expelt[index];
307 write_exp_elt (ps, &tmp);
311 write_exp_elt_type (struct parser_state *ps, struct type *expelt)
313 union exp_element tmp;
315 memset (&tmp, 0, sizeof (union exp_element));
317 write_exp_elt (ps, &tmp);
321 write_exp_elt_intern (struct parser_state *ps, struct internalvar *expelt)
323 union exp_element tmp;
325 memset (&tmp, 0, sizeof (union exp_element));
326 tmp.internalvar = expelt;
327 write_exp_elt (ps, &tmp);
330 /* Add a string constant to the end of the expression.
332 String constants are stored by first writing an expression element
333 that contains the length of the string, then stuffing the string
334 constant itself into however many expression elements are needed
335 to hold it, and then writing another expression element that contains
336 the length of the string. I.e. an expression element at each end of
337 the string records the string length, so you can skip over the
338 expression elements containing the actual string bytes from either
339 end of the string. Note that this also allows gdb to handle
340 strings with embedded null bytes, as is required for some languages.
342 Don't be fooled by the fact that the string is null byte terminated,
343 this is strictly for the convenience of debugging gdb itself.
344 Gdb does not depend up the string being null terminated, since the
345 actual length is recorded in expression elements at each end of the
346 string. The null byte is taken into consideration when computing how
347 many expression elements are required to hold the string constant, of
352 write_exp_string (struct parser_state *ps, struct stoken str)
354 int len = str.length;
358 /* Compute the number of expression elements required to hold the string
359 (including a null byte terminator), along with one expression element
360 at each end to record the actual string length (not including the
361 null byte terminator). */
363 lenelt = 2 + BYTES_TO_EXP_ELEM (len + 1);
365 increase_expout_size (ps, lenelt);
367 /* Write the leading length expression element (which advances the current
368 expression element index), then write the string constant followed by a
369 terminating null byte, and then write the trailing length expression
372 write_exp_elt_longcst (ps, (LONGEST) len);
373 strdata = (char *) &ps->expout->elts[ps->expout_ptr];
374 memcpy (strdata, str.ptr, len);
375 *(strdata + len) = '\0';
376 ps->expout_ptr += lenelt - 2;
377 write_exp_elt_longcst (ps, (LONGEST) len);
380 /* Add a vector of string constants to the end of the expression.
382 This adds an OP_STRING operation, but encodes the contents
383 differently from write_exp_string. The language is expected to
384 handle evaluation of this expression itself.
386 After the usual OP_STRING header, TYPE is written into the
387 expression as a long constant. The interpretation of this field is
388 up to the language evaluator.
390 Next, each string in VEC is written. The length is written as a
391 long constant, followed by the contents of the string. */
394 write_exp_string_vector (struct parser_state *ps, int type,
395 struct stoken_vector *vec)
400 /* Compute the size. We compute the size in number of slots to
401 avoid issues with string padding. */
403 for (i = 0; i < vec->len; ++i)
405 /* One slot for the length of this element, plus the number of
406 slots needed for this string. */
407 n_slots += 1 + BYTES_TO_EXP_ELEM (vec->tokens[i].length);
410 /* One more slot for the type of the string. */
413 /* Now compute a phony string length. */
414 len = EXP_ELEM_TO_BYTES (n_slots) - 1;
417 increase_expout_size (ps, n_slots);
419 write_exp_elt_opcode (ps, OP_STRING);
420 write_exp_elt_longcst (ps, len);
421 write_exp_elt_longcst (ps, type);
423 for (i = 0; i < vec->len; ++i)
425 write_exp_elt_longcst (ps, vec->tokens[i].length);
426 memcpy (&ps->expout->elts[ps->expout_ptr], vec->tokens[i].ptr,
427 vec->tokens[i].length);
428 ps->expout_ptr += BYTES_TO_EXP_ELEM (vec->tokens[i].length);
431 write_exp_elt_longcst (ps, len);
432 write_exp_elt_opcode (ps, OP_STRING);
435 /* Add a bitstring constant to the end of the expression.
437 Bitstring constants are stored by first writing an expression element
438 that contains the length of the bitstring (in bits), then stuffing the
439 bitstring constant itself into however many expression elements are
440 needed to hold it, and then writing another expression element that
441 contains the length of the bitstring. I.e. an expression element at
442 each end of the bitstring records the bitstring length, so you can skip
443 over the expression elements containing the actual bitstring bytes from
444 either end of the bitstring. */
447 write_exp_bitstring (struct parser_state *ps, struct stoken str)
449 int bits = str.length; /* length in bits */
450 int len = (bits + HOST_CHAR_BIT - 1) / HOST_CHAR_BIT;
454 /* Compute the number of expression elements required to hold the bitstring,
455 along with one expression element at each end to record the actual
456 bitstring length in bits. */
458 lenelt = 2 + BYTES_TO_EXP_ELEM (len);
460 increase_expout_size (ps, lenelt);
462 /* Write the leading length expression element (which advances the current
463 expression element index), then write the bitstring constant, and then
464 write the trailing length expression element. */
466 write_exp_elt_longcst (ps, (LONGEST) bits);
467 strdata = (char *) &ps->expout->elts[ps->expout_ptr];
468 memcpy (strdata, str.ptr, len);
469 ps->expout_ptr += lenelt - 2;
470 write_exp_elt_longcst (ps, (LONGEST) bits);
473 /* Add the appropriate elements for a minimal symbol to the end of
477 write_exp_msymbol (struct parser_state *ps,
478 struct bound_minimal_symbol bound_msym)
480 struct minimal_symbol *msymbol = bound_msym.minsym;
481 struct objfile *objfile = bound_msym.objfile;
482 struct gdbarch *gdbarch = get_objfile_arch (objfile);
484 CORE_ADDR addr = BMSYMBOL_VALUE_ADDRESS (bound_msym);
485 struct obj_section *section = MSYMBOL_OBJ_SECTION (objfile, msymbol);
486 enum minimal_symbol_type type = MSYMBOL_TYPE (msymbol);
489 /* The minimal symbol might point to a function descriptor;
490 resolve it to the actual code address instead. */
491 pc = gdbarch_convert_from_func_ptr_addr (gdbarch, addr, ¤t_target);
494 struct bound_minimal_symbol ifunc_msym = lookup_minimal_symbol_by_pc (pc);
496 /* In this case, assume we have a code symbol instead of
499 if (ifunc_msym.minsym != NULL
500 && MSYMBOL_TYPE (ifunc_msym.minsym) == mst_text_gnu_ifunc
501 && BMSYMBOL_VALUE_ADDRESS (ifunc_msym) == pc)
503 /* A function descriptor has been resolved but PC is still in the
504 STT_GNU_IFUNC resolver body (such as because inferior does not
505 run to be able to call it). */
507 type = mst_text_gnu_ifunc;
515 if (overlay_debugging)
516 addr = symbol_overlayed_address (addr, section);
518 write_exp_elt_opcode (ps, OP_LONG);
519 /* Let's make the type big enough to hold a 64-bit address. */
520 write_exp_elt_type (ps, objfile_type (objfile)->builtin_core_addr);
521 write_exp_elt_longcst (ps, (LONGEST) addr);
522 write_exp_elt_opcode (ps, OP_LONG);
524 if (section && section->the_bfd_section->flags & SEC_THREAD_LOCAL)
526 write_exp_elt_opcode (ps, UNOP_MEMVAL_TLS);
527 write_exp_elt_objfile (ps, objfile);
528 write_exp_elt_type (ps, objfile_type (objfile)->nodebug_tls_symbol);
529 write_exp_elt_opcode (ps, UNOP_MEMVAL_TLS);
533 write_exp_elt_opcode (ps, UNOP_MEMVAL);
538 case mst_solib_trampoline:
539 write_exp_elt_type (ps, objfile_type (objfile)->nodebug_text_symbol);
542 case mst_text_gnu_ifunc:
543 write_exp_elt_type (ps, objfile_type (objfile)
544 ->nodebug_text_gnu_ifunc_symbol);
551 write_exp_elt_type (ps, objfile_type (objfile)->nodebug_data_symbol);
554 case mst_slot_got_plt:
555 write_exp_elt_type (ps, objfile_type (objfile)->nodebug_got_plt_symbol);
559 write_exp_elt_type (ps, objfile_type (objfile)->nodebug_unknown_symbol);
562 write_exp_elt_opcode (ps, UNOP_MEMVAL);
565 /* Mark the current index as the starting location of a structure
566 expression. This is used when completing on field names. */
569 mark_struct_expression (struct parser_state *ps)
571 gdb_assert (parse_completion
572 && expout_tag_completion_type == TYPE_CODE_UNDEF);
573 expout_last_struct = ps->expout_ptr;
576 /* Indicate that the current parser invocation is completing a tag.
577 TAG is the type code of the tag, and PTR and LENGTH represent the
578 start of the tag name. */
581 mark_completion_tag (enum type_code tag, const char *ptr, int length)
583 gdb_assert (parse_completion
584 && expout_tag_completion_type == TYPE_CODE_UNDEF
585 && expout_completion_name == NULL
586 && expout_last_struct == -1);
587 gdb_assert (tag == TYPE_CODE_UNION
588 || tag == TYPE_CODE_STRUCT
589 || tag == TYPE_CODE_ENUM);
590 expout_tag_completion_type = tag;
591 expout_completion_name = (char *) xmalloc (length + 1);
592 memcpy (expout_completion_name, ptr, length);
593 expout_completion_name[length] = '\0';
597 /* Recognize tokens that start with '$'. These include:
599 $regname A native register name or a "standard
602 $variable A convenience variable with a name chosen
605 $digits Value history with index <digits>, starting
606 from the first value which has index 1.
608 $$digits Value history with index <digits> relative
609 to the last value. I.e. $$0 is the last
610 value, $$1 is the one previous to that, $$2
611 is the one previous to $$1, etc.
613 $ | $0 | $$0 The last value in the value history.
615 $$ An abbreviation for the second to the last
616 value in the value history, I.e. $$1 */
619 write_dollar_variable (struct parser_state *ps, struct stoken str)
621 struct block_symbol sym;
622 struct bound_minimal_symbol msym;
623 struct internalvar *isym = NULL;
625 /* Handle the tokens $digits; also $ (short for $0) and $$ (short for $$1)
626 and $$digits (equivalent to $<-digits> if you could type that). */
630 /* Double dollar means negate the number and add -1 as well.
631 Thus $$ alone means -1. */
632 if (str.length >= 2 && str.ptr[1] == '$')
639 /* Just dollars (one or two). */
643 /* Is the rest of the token digits? */
644 for (; i < str.length; i++)
645 if (!(str.ptr[i] >= '0' && str.ptr[i] <= '9'))
649 i = atoi (str.ptr + 1 + negate);
655 /* Handle tokens that refer to machine registers:
656 $ followed by a register name. */
657 i = user_reg_map_name_to_regnum (parse_gdbarch (ps),
658 str.ptr + 1, str.length - 1);
660 goto handle_register;
662 /* Any names starting with $ are probably debugger internal variables. */
664 isym = lookup_only_internalvar (copy_name (str) + 1);
667 write_exp_elt_opcode (ps, OP_INTERNALVAR);
668 write_exp_elt_intern (ps, isym);
669 write_exp_elt_opcode (ps, OP_INTERNALVAR);
673 /* On some systems, such as HP-UX and hppa-linux, certain system routines
674 have names beginning with $ or $$. Check for those, first. */
676 sym = lookup_symbol (copy_name (str), (struct block *) NULL,
680 write_exp_elt_opcode (ps, OP_VAR_VALUE);
681 write_exp_elt_block (ps, sym.block);
682 write_exp_elt_sym (ps, sym.symbol);
683 write_exp_elt_opcode (ps, OP_VAR_VALUE);
686 msym = lookup_bound_minimal_symbol (copy_name (str));
689 write_exp_msymbol (ps, msym);
693 /* Any other names are assumed to be debugger internal variables. */
695 write_exp_elt_opcode (ps, OP_INTERNALVAR);
696 write_exp_elt_intern (ps, create_internalvar (copy_name (str) + 1));
697 write_exp_elt_opcode (ps, OP_INTERNALVAR);
700 write_exp_elt_opcode (ps, OP_LAST);
701 write_exp_elt_longcst (ps, (LONGEST) i);
702 write_exp_elt_opcode (ps, OP_LAST);
705 write_exp_elt_opcode (ps, OP_REGISTER);
708 write_exp_string (ps, str);
709 write_exp_elt_opcode (ps, OP_REGISTER);
715 find_template_name_end (const char *p)
718 int just_seen_right = 0;
719 int just_seen_colon = 0;
720 int just_seen_space = 0;
722 if (!p || (*p != '<'))
733 /* In future, may want to allow these?? */
736 depth++; /* start nested template */
737 if (just_seen_colon || just_seen_right || just_seen_space)
738 return 0; /* but not after : or :: or > or space */
741 if (just_seen_colon || just_seen_right)
742 return 0; /* end a (nested?) template */
743 just_seen_right = 1; /* but not after : or :: */
744 if (--depth == 0) /* also disallow >>, insist on > > */
745 return ++p; /* if outermost ended, return */
748 if (just_seen_space || (just_seen_colon > 1))
749 return 0; /* nested class spec coming up */
750 just_seen_colon++; /* we allow :: but not :::: */
755 if (!((*p >= 'a' && *p <= 'z') || /* allow token chars */
756 (*p >= 'A' && *p <= 'Z') ||
757 (*p >= '0' && *p <= '9') ||
758 (*p == '_') || (*p == ',') || /* commas for template args */
759 (*p == '&') || (*p == '*') || /* pointer and ref types */
760 (*p == '(') || (*p == ')') || /* function types */
761 (*p == '[') || (*p == ']'))) /* array types */
775 /* Return a null-terminated temporary copy of the name of a string token.
777 Tokens that refer to names do so with explicit pointer and length,
778 so they can share the storage that lexptr is parsing.
779 When it is necessary to pass a name to a function that expects
780 a null-terminated string, the substring is copied out
781 into a separate block of storage.
783 N.B. A single buffer is reused on each call. */
786 copy_name (struct stoken token)
788 /* A temporary buffer for identifiers, so we can null-terminate them.
789 We allocate this with xrealloc. parse_exp_1 used to allocate with
790 alloca, using the size of the whole expression as a conservative
791 estimate of the space needed. However, macro expansion can
792 introduce names longer than the original expression; there's no
793 practical way to know beforehand how large that might be. */
794 static char *namecopy;
795 static size_t namecopy_size;
797 /* Make sure there's enough space for the token. */
798 if (namecopy_size < token.length + 1)
800 namecopy_size = token.length + 1;
801 namecopy = (char *) xrealloc (namecopy, token.length + 1);
804 memcpy (namecopy, token.ptr, token.length);
805 namecopy[token.length] = 0;
811 /* See comments on parser-defs.h. */
814 prefixify_expression (struct expression *expr)
816 int len = sizeof (struct expression) + EXP_ELEM_TO_BYTES (expr->nelts);
817 struct expression *temp;
818 int inpos = expr->nelts, outpos = 0;
820 temp = (struct expression *) alloca (len);
822 /* Copy the original expression into temp. */
823 memcpy (temp, expr, len);
825 return prefixify_subexp (temp, expr, inpos, outpos);
828 /* Return the number of exp_elements in the postfix subexpression
829 of EXPR whose operator is at index ENDPOS - 1 in EXPR. */
832 length_of_subexp (struct expression *expr, int endpos)
836 operator_length (expr, endpos, &oplen, &args);
840 oplen += length_of_subexp (expr, endpos - oplen);
847 /* Sets *OPLENP to the length of the operator whose (last) index is
848 ENDPOS - 1 in EXPR, and sets *ARGSP to the number of arguments that
852 operator_length (const struct expression *expr, int endpos, int *oplenp,
855 expr->language_defn->la_exp_desc->operator_length (expr, endpos,
859 /* Default value for operator_length in exp_descriptor vectors. */
862 operator_length_standard (const struct expression *expr, int endpos,
863 int *oplenp, int *argsp)
867 enum range_type range_type;
871 error (_("?error in operator_length_standard"));
873 i = (int) expr->elts[endpos - 1].opcode;
879 oplen = longest_to_int (expr->elts[endpos - 2].longconst);
880 oplen = 5 + BYTES_TO_EXP_ELEM (oplen + 1);
894 case OP_VAR_ENTRY_VALUE:
904 case OP_F77_UNDETERMINED_ARGLIST:
906 args = 1 + longest_to_int (expr->elts[endpos - 2].longconst);
910 oplen = 4 + longest_to_int (expr->elts[endpos - 2].longconst);
914 case OP_OBJC_MSGCALL: /* Objective C message (method) call. */
916 args = 1 + longest_to_int (expr->elts[endpos - 2].longconst);
925 case UNOP_DYNAMIC_CAST:
926 case UNOP_REINTERPRET_CAST:
927 case UNOP_MEMVAL_TYPE:
939 case UNOP_MEMVAL_TLS:
960 oplen = longest_to_int (expr->elts[endpos - 2].longconst);
961 oplen = 4 + BYTES_TO_EXP_ELEM (oplen + 1);
966 case STRUCTOP_STRUCT:
973 case OP_OBJC_NSSTRING: /* Objective C Foundation Class
974 NSString constant. */
975 case OP_OBJC_SELECTOR: /* Objective C "@selector" pseudo-op. */
977 oplen = longest_to_int (expr->elts[endpos - 2].longconst);
978 oplen = 4 + BYTES_TO_EXP_ELEM (oplen + 1);
983 args = longest_to_int (expr->elts[endpos - 2].longconst);
984 args -= longest_to_int (expr->elts[endpos - 3].longconst);
994 case MULTI_SUBSCRIPT:
996 args = 1 + longest_to_int (expr->elts[endpos - 2].longconst);
999 case BINOP_ASSIGN_MODIFY:
1011 range_type = (enum range_type)
1012 longest_to_int (expr->elts[endpos - 2].longconst);
1016 case LOW_BOUND_DEFAULT:
1017 case HIGH_BOUND_DEFAULT:
1020 case BOTH_BOUND_DEFAULT:
1023 case NONE_BOUND_DEFAULT:
1031 args = 1 + (i < (int) BINOP_END);
1038 /* Copy the subexpression ending just before index INEND in INEXPR
1039 into OUTEXPR, starting at index OUTBEG.
1040 In the process, convert it from suffix to prefix form.
1041 If EXPOUT_LAST_STRUCT is -1, then this function always returns -1.
1042 Otherwise, it returns the index of the subexpression which is the
1043 left-hand-side of the expression at EXPOUT_LAST_STRUCT. */
1046 prefixify_subexp (struct expression *inexpr,
1047 struct expression *outexpr, int inend, int outbeg)
1055 operator_length (inexpr, inend, &oplen, &args);
1057 /* Copy the final operator itself, from the end of the input
1058 to the beginning of the output. */
1060 memcpy (&outexpr->elts[outbeg], &inexpr->elts[inend],
1061 EXP_ELEM_TO_BYTES (oplen));
1064 if (expout_last_struct == inend)
1065 result = outbeg - oplen;
1067 /* Find the lengths of the arg subexpressions. */
1068 arglens = (int *) alloca (args * sizeof (int));
1069 for (i = args - 1; i >= 0; i--)
1071 oplen = length_of_subexp (inexpr, inend);
1076 /* Now copy each subexpression, preserving the order of
1077 the subexpressions, but prefixifying each one.
1078 In this loop, inend starts at the beginning of
1079 the expression this level is working on
1080 and marches forward over the arguments.
1081 outbeg does similarly in the output. */
1082 for (i = 0; i < args; i++)
1088 r = prefixify_subexp (inexpr, outexpr, inend, outbeg);
1091 /* Return immediately. We probably have only parsed a
1092 partial expression, so we don't want to try to reverse
1093 the other operands. */
1102 /* Read an expression from the string *STRINGPTR points to,
1103 parse it, and return a pointer to a struct expression that we malloc.
1104 Use block BLOCK as the lexical context for variable names;
1105 if BLOCK is zero, use the block of the selected stack frame.
1106 Meanwhile, advance *STRINGPTR to point after the expression,
1107 at the first nonwhite character that is not part of the expression
1108 (possibly a null character).
1110 If COMMA is nonzero, stop if a comma is reached. */
1113 parse_exp_1 (const char **stringptr, CORE_ADDR pc, const struct block *block,
1116 return parse_exp_in_context (stringptr, pc, block, comma, 0, NULL);
1119 static expression_up
1120 parse_exp_in_context (const char **stringptr, CORE_ADDR pc,
1121 const struct block *block,
1122 int comma, int void_context_p, int *out_subexp)
1124 return parse_exp_in_context_1 (stringptr, pc, block, comma,
1125 void_context_p, out_subexp);
1128 /* As for parse_exp_1, except that if VOID_CONTEXT_P, then
1129 no value is expected from the expression.
1130 OUT_SUBEXP is set when attempting to complete a field name; in this
1131 case it is set to the index of the subexpression on the
1132 left-hand-side of the struct op. If not doing such completion, it
1133 is left untouched. */
1135 static expression_up
1136 parse_exp_in_context_1 (const char **stringptr, CORE_ADDR pc,
1137 const struct block *block,
1138 int comma, int void_context_p, int *out_subexp)
1140 struct cleanup *old_chain;
1141 const struct language_defn *lang = NULL;
1142 struct parser_state ps;
1145 lexptr = *stringptr;
1149 type_stack.depth = 0;
1150 expout_last_struct = -1;
1151 expout_tag_completion_type = TYPE_CODE_UNDEF;
1152 xfree (expout_completion_name);
1153 expout_completion_name = NULL;
1155 comma_terminates = comma;
1157 if (lexptr == 0 || *lexptr == 0)
1158 error_no_arg (_("expression to compute"));
1160 old_chain = make_cleanup (free_funcalls, 0 /*ignore*/);
1163 expression_context_block = block;
1165 /* If no context specified, try using the current frame, if any. */
1166 if (!expression_context_block)
1167 expression_context_block = get_selected_block (&expression_context_pc);
1169 expression_context_pc = BLOCK_START (expression_context_block);
1171 expression_context_pc = pc;
1173 /* Fall back to using the current source static context, if any. */
1175 if (!expression_context_block)
1177 struct symtab_and_line cursal = get_current_source_symtab_and_line ();
1179 expression_context_block
1180 = BLOCKVECTOR_BLOCK (SYMTAB_BLOCKVECTOR (cursal.symtab),
1182 if (expression_context_block)
1183 expression_context_pc = BLOCK_START (expression_context_block);
1186 if (language_mode == language_mode_auto && block != NULL)
1188 /* Find the language associated to the given context block.
1189 Default to the current language if it can not be determined.
1191 Note that using the language corresponding to the current frame
1192 can sometimes give unexpected results. For instance, this
1193 routine is often called several times during the inferior
1194 startup phase to re-parse breakpoint expressions after
1195 a new shared library has been loaded. The language associated
1196 to the current frame at this moment is not relevant for
1197 the breakpoint. Using it would therefore be silly, so it seems
1198 better to rely on the current language rather than relying on
1199 the current frame language to parse the expression. That's why
1200 we do the following language detection only if the context block
1201 has been specifically provided. */
1202 struct symbol *func = block_linkage_function (block);
1205 lang = language_def (SYMBOL_LANGUAGE (func));
1206 if (lang == NULL || lang->la_language == language_unknown)
1207 lang = current_language;
1210 lang = current_language;
1212 /* get_current_arch may reset CURRENT_LANGUAGE via select_frame.
1213 While we need CURRENT_LANGUAGE to be set to LANG (for lookup_symbol
1214 and others called from *.y) ensure CURRENT_LANGUAGE gets restored
1215 to the value matching SELECTED_FRAME as set by get_current_arch. */
1217 initialize_expout (&ps, 10, lang, get_current_arch ());
1219 scoped_restore_current_language lang_saver;
1220 set_language (lang->la_language);
1224 if (lang->la_parser (&ps))
1225 lang->la_error (NULL);
1227 CATCH (except, RETURN_MASK_ALL)
1229 if (! parse_completion)
1232 throw_exception (except);
1237 reallocate_expout (&ps);
1239 /* Convert expression from postfix form as generated by yacc
1240 parser, to a prefix form. */
1242 if (expressiondebug)
1243 dump_raw_expression (ps.expout, gdb_stdlog,
1244 "before conversion to prefix form");
1246 subexp = prefixify_expression (ps.expout);
1248 *out_subexp = subexp;
1250 lang->la_post_parser (&ps.expout, void_context_p);
1252 if (expressiondebug)
1253 dump_prefix_expression (ps.expout, gdb_stdlog);
1255 discard_cleanups (old_chain);
1257 *stringptr = lexptr;
1258 return expression_up (ps.expout);
1261 /* Parse STRING as an expression, and complain if this fails
1262 to use up all of the contents of STRING. */
1265 parse_expression (const char *string)
1267 expression_up exp = parse_exp_1 (&string, 0, 0, 0);
1269 error (_("Junk after end of expression."));
1273 /* Same as parse_expression, but using the given language (LANG)
1274 to parse the expression. */
1277 parse_expression_with_language (const char *string, enum language lang)
1279 gdb::optional<scoped_restore_current_language> lang_saver;
1280 if (current_language->la_language != lang)
1282 lang_saver.emplace ();
1283 set_language (lang);
1286 return parse_expression (string);
1289 /* Parse STRING as an expression. If parsing ends in the middle of a
1290 field reference, return the type of the left-hand-side of the
1291 reference; furthermore, if the parsing ends in the field name,
1292 return the field name in *NAME. If the parsing ends in the middle
1293 of a field reference, but the reference is somehow invalid, throw
1294 an exception. In all other cases, return NULL. Returned non-NULL
1295 *NAME must be freed by the caller. */
1298 parse_expression_for_completion (const char *string, char **name,
1299 enum type_code *code)
1307 parse_completion = 1;
1308 exp = parse_exp_in_context (&string, 0, 0, 0, 0, &subexp);
1310 CATCH (except, RETURN_MASK_ERROR)
1312 /* Nothing, EXP remains NULL. */
1316 parse_completion = 0;
1320 if (expout_tag_completion_type != TYPE_CODE_UNDEF)
1322 *code = expout_tag_completion_type;
1323 *name = expout_completion_name;
1324 expout_completion_name = NULL;
1328 if (expout_last_struct == -1)
1331 *name = extract_field_op (exp.get (), &subexp);
1335 /* This might throw an exception. If so, we want to let it
1337 val = evaluate_subexpression_type (exp.get (), subexp);
1338 /* (*NAME) is a part of the EXP memory block freed below. */
1339 *name = xstrdup (*name);
1341 return value_type (val);
1344 /* A post-parser that does nothing. */
1347 null_post_parser (struct expression **exp, int void_context_p)
1351 /* Parse floating point value P of length LEN.
1352 Return 0 (false) if invalid, 1 (true) if valid.
1353 The successfully parsed number is stored in D.
1354 *SUFFIX points to the suffix of the number in P.
1356 NOTE: This accepts the floating point syntax that sscanf accepts. */
1359 parse_float (const char *p, int len, DOUBLEST *d, const char **suffix)
1364 copy = (char *) xmalloc (len + 1);
1365 memcpy (copy, p, len);
1368 num = sscanf (copy, "%" DOUBLEST_SCAN_FORMAT "%n", d, &n);
1371 /* The sscanf man page suggests not making any assumptions on the effect
1372 of %n on the result, so we don't.
1373 That is why we simply test num == 0. */
1381 /* Parse floating point value P of length LEN, using the C syntax for floats.
1382 Return 0 (false) if invalid, 1 (true) if valid.
1383 The successfully parsed number is stored in *D.
1384 Its type is taken from builtin_type (gdbarch) and is stored in *T. */
1387 parse_c_float (struct gdbarch *gdbarch, const char *p, int len,
1388 DOUBLEST *d, struct type **t)
1392 const struct builtin_type *builtin_types = builtin_type (gdbarch);
1394 if (! parse_float (p, len, d, &suffix))
1397 suffix_len = p + len - suffix;
1399 if (suffix_len == 0)
1400 *t = builtin_types->builtin_double;
1401 else if (suffix_len == 1)
1403 /* Handle suffixes: 'f' for float, 'l' for long double. */
1404 if (tolower (*suffix) == 'f')
1405 *t = builtin_types->builtin_float;
1406 else if (tolower (*suffix) == 'l')
1407 *t = builtin_types->builtin_long_double;
1417 /* Stuff for maintaining a stack of types. Currently just used by C, but
1418 probably useful for any language which declares its types "backwards". */
1420 /* Ensure that there are HOWMUCH open slots on the type stack STACK. */
1423 type_stack_reserve (struct type_stack *stack, int howmuch)
1425 if (stack->depth + howmuch >= stack->size)
1428 if (stack->size < howmuch)
1429 stack->size = howmuch;
1430 stack->elements = XRESIZEVEC (union type_stack_elt, stack->elements,
1435 /* Ensure that there is a single open slot in the global type stack. */
1438 check_type_stack_depth (void)
1440 type_stack_reserve (&type_stack, 1);
1443 /* A helper function for insert_type and insert_type_address_space.
1444 This does work of expanding the type stack and inserting the new
1445 element, ELEMENT, into the stack at location SLOT. */
1448 insert_into_type_stack (int slot, union type_stack_elt element)
1450 check_type_stack_depth ();
1452 if (slot < type_stack.depth)
1453 memmove (&type_stack.elements[slot + 1], &type_stack.elements[slot],
1454 (type_stack.depth - slot) * sizeof (union type_stack_elt));
1455 type_stack.elements[slot] = element;
1459 /* Insert a new type, TP, at the bottom of the type stack. If TP is
1460 tp_pointer, tp_reference or tp_rvalue_reference, it is inserted at the
1461 bottom. If TP is a qualifier, it is inserted at slot 1 (just above a
1462 previous tp_pointer) if there is anything on the stack, or simply pushed
1463 if the stack is empty. Other values for TP are invalid. */
1466 insert_type (enum type_pieces tp)
1468 union type_stack_elt element;
1471 gdb_assert (tp == tp_pointer || tp == tp_reference
1472 || tp == tp_rvalue_reference || tp == tp_const
1473 || tp == tp_volatile);
1475 /* If there is anything on the stack (we know it will be a
1476 tp_pointer), insert the qualifier above it. Otherwise, simply
1477 push this on the top of the stack. */
1478 if (type_stack.depth && (tp == tp_const || tp == tp_volatile))
1484 insert_into_type_stack (slot, element);
1488 push_type (enum type_pieces tp)
1490 check_type_stack_depth ();
1491 type_stack.elements[type_stack.depth++].piece = tp;
1495 push_type_int (int n)
1497 check_type_stack_depth ();
1498 type_stack.elements[type_stack.depth++].int_val = n;
1501 /* Insert a tp_space_identifier and the corresponding address space
1502 value into the stack. STRING is the name of an address space, as
1503 recognized by address_space_name_to_int. If the stack is empty,
1504 the new elements are simply pushed. If the stack is not empty,
1505 this function assumes that the first item on the stack is a
1506 tp_pointer, and the new values are inserted above the first
1510 insert_type_address_space (struct parser_state *pstate, char *string)
1512 union type_stack_elt element;
1515 /* If there is anything on the stack (we know it will be a
1516 tp_pointer), insert the address space qualifier above it.
1517 Otherwise, simply push this on the top of the stack. */
1518 if (type_stack.depth)
1523 element.piece = tp_space_identifier;
1524 insert_into_type_stack (slot, element);
1525 element.int_val = address_space_name_to_int (parse_gdbarch (pstate),
1527 insert_into_type_stack (slot, element);
1533 if (type_stack.depth)
1534 return type_stack.elements[--type_stack.depth].piece;
1541 if (type_stack.depth)
1542 return type_stack.elements[--type_stack.depth].int_val;
1543 /* "Can't happen". */
1547 /* Pop a type list element from the global type stack. */
1549 static VEC (type_ptr) *
1552 gdb_assert (type_stack.depth);
1553 return type_stack.elements[--type_stack.depth].typelist_val;
1556 /* Pop a type_stack element from the global type stack. */
1558 static struct type_stack *
1559 pop_type_stack (void)
1561 gdb_assert (type_stack.depth);
1562 return type_stack.elements[--type_stack.depth].stack_val;
1565 /* Append the elements of the type stack FROM to the type stack TO.
1566 Always returns TO. */
1569 append_type_stack (struct type_stack *to, struct type_stack *from)
1571 type_stack_reserve (to, from->depth);
1573 memcpy (&to->elements[to->depth], &from->elements[0],
1574 from->depth * sizeof (union type_stack_elt));
1575 to->depth += from->depth;
1580 /* Push the type stack STACK as an element on the global type stack. */
1583 push_type_stack (struct type_stack *stack)
1585 check_type_stack_depth ();
1586 type_stack.elements[type_stack.depth++].stack_val = stack;
1587 push_type (tp_type_stack);
1590 /* Copy the global type stack into a newly allocated type stack and
1591 return it. The global stack is cleared. The returned type stack
1592 must be freed with type_stack_cleanup. */
1595 get_type_stack (void)
1597 struct type_stack *result = XNEW (struct type_stack);
1599 *result = type_stack;
1600 type_stack.depth = 0;
1601 type_stack.size = 0;
1602 type_stack.elements = NULL;
1607 /* A cleanup function that destroys a single type stack. */
1610 type_stack_cleanup (void *arg)
1612 struct type_stack *stack = (struct type_stack *) arg;
1614 xfree (stack->elements);
1618 /* Push a function type with arguments onto the global type stack.
1619 LIST holds the argument types. If the final item in LIST is NULL,
1620 then the function will be varargs. */
1623 push_typelist (VEC (type_ptr) *list)
1625 check_type_stack_depth ();
1626 type_stack.elements[type_stack.depth++].typelist_val = list;
1627 push_type (tp_function_with_arguments);
1630 /* Pop the type stack and return the type which corresponds to FOLLOW_TYPE
1631 as modified by all the stuff on the stack. */
1633 follow_types (struct type *follow_type)
1637 int make_volatile = 0;
1638 int make_addr_space = 0;
1642 switch (pop_type ())
1647 follow_type = make_cv_type (make_const,
1648 TYPE_VOLATILE (follow_type),
1651 follow_type = make_cv_type (TYPE_CONST (follow_type),
1654 if (make_addr_space)
1655 follow_type = make_type_with_address_space (follow_type,
1657 make_const = make_volatile = 0;
1658 make_addr_space = 0;
1666 case tp_space_identifier:
1667 make_addr_space = pop_type_int ();
1670 follow_type = lookup_pointer_type (follow_type);
1672 follow_type = make_cv_type (make_const,
1673 TYPE_VOLATILE (follow_type),
1676 follow_type = make_cv_type (TYPE_CONST (follow_type),
1679 if (make_addr_space)
1680 follow_type = make_type_with_address_space (follow_type,
1682 make_const = make_volatile = 0;
1683 make_addr_space = 0;
1686 follow_type = lookup_lvalue_reference_type (follow_type);
1687 goto process_reference;
1688 case tp_rvalue_reference:
1689 follow_type = lookup_rvalue_reference_type (follow_type);
1692 follow_type = make_cv_type (make_const,
1693 TYPE_VOLATILE (follow_type),
1696 follow_type = make_cv_type (TYPE_CONST (follow_type),
1699 if (make_addr_space)
1700 follow_type = make_type_with_address_space (follow_type,
1702 make_const = make_volatile = 0;
1703 make_addr_space = 0;
1706 array_size = pop_type_int ();
1707 /* FIXME-type-allocation: need a way to free this type when we are
1710 lookup_array_range_type (follow_type,
1711 0, array_size >= 0 ? array_size - 1 : 0);
1713 TYPE_HIGH_BOUND_KIND (TYPE_INDEX_TYPE (follow_type))
1717 /* FIXME-type-allocation: need a way to free this type when we are
1719 follow_type = lookup_function_type (follow_type);
1722 case tp_function_with_arguments:
1724 VEC (type_ptr) *args = pop_typelist ();
1727 = lookup_function_type_with_arguments (follow_type,
1728 VEC_length (type_ptr, args),
1729 VEC_address (type_ptr,
1731 VEC_free (type_ptr, args);
1737 struct type_stack *stack = pop_type_stack ();
1738 /* Sort of ugly, but not really much worse than the
1740 struct type_stack save = type_stack;
1742 type_stack = *stack;
1743 follow_type = follow_types (follow_type);
1744 gdb_assert (type_stack.depth == 0);
1750 gdb_assert_not_reached ("unrecognized tp_ value in follow_types");
1755 /* This function avoids direct calls to fprintf
1756 in the parser generated debug code. */
1758 parser_fprintf (FILE *x, const char *y, ...)
1764 vfprintf_unfiltered (gdb_stderr, y, args);
1767 fprintf_unfiltered (gdb_stderr, " Unknown FILE used.\n");
1768 vfprintf_unfiltered (gdb_stderr, y, args);
1773 /* Implementation of the exp_descriptor method operator_check. */
1776 operator_check_standard (struct expression *exp, int pos,
1777 int (*objfile_func) (struct objfile *objfile,
1781 const union exp_element *const elts = exp->elts;
1782 struct type *type = NULL;
1783 struct objfile *objfile = NULL;
1785 /* Extended operators should have been already handled by exp_descriptor
1786 iterate method of its specific language. */
1787 gdb_assert (elts[pos].opcode < OP_EXTENDED0);
1789 /* Track the callers of write_exp_elt_type for this table. */
1791 switch (elts[pos].opcode)
1804 type = elts[pos + 1].type;
1809 LONGEST arg, nargs = elts[pos + 1].longconst;
1811 for (arg = 0; arg < nargs; arg++)
1813 struct type *type = elts[pos + 2 + arg].type;
1814 struct objfile *objfile = TYPE_OBJFILE (type);
1816 if (objfile && (*objfile_func) (objfile, data))
1822 case UNOP_MEMVAL_TLS:
1823 objfile = elts[pos + 1].objfile;
1824 type = elts[pos + 2].type;
1829 const struct block *const block = elts[pos + 1].block;
1830 const struct symbol *const symbol = elts[pos + 2].symbol;
1832 /* Check objfile where the variable itself is placed.
1833 SYMBOL_OBJ_SECTION (symbol) may be NULL. */
1834 if ((*objfile_func) (symbol_objfile (symbol), data))
1837 /* Check objfile where is placed the code touching the variable. */
1838 objfile = lookup_objfile_from_block (block);
1840 type = SYMBOL_TYPE (symbol);
1845 /* Invoke callbacks for TYPE and OBJFILE if they were set as non-NULL. */
1847 if (type && TYPE_OBJFILE (type)
1848 && (*objfile_func) (TYPE_OBJFILE (type), data))
1850 if (objfile && (*objfile_func) (objfile, data))
1856 /* Call OBJFILE_FUNC for any objfile found being referenced by EXP.
1857 OBJFILE_FUNC is never called with NULL OBJFILE. OBJFILE_FUNC get
1858 passed an arbitrary caller supplied DATA pointer. If OBJFILE_FUNC
1859 returns non-zero value then (any other) non-zero value is immediately
1860 returned to the caller. Otherwise zero is returned after iterating
1861 through whole EXP. */
1864 exp_iterate (struct expression *exp,
1865 int (*objfile_func) (struct objfile *objfile, void *data),
1870 for (endpos = exp->nelts; endpos > 0; )
1872 int pos, args, oplen = 0;
1874 operator_length (exp, endpos, &oplen, &args);
1875 gdb_assert (oplen > 0);
1877 pos = endpos - oplen;
1878 if (exp->language_defn->la_exp_desc->operator_check (exp, pos,
1879 objfile_func, data))
1888 /* Helper for exp_uses_objfile. */
1891 exp_uses_objfile_iter (struct objfile *exp_objfile, void *objfile_voidp)
1893 struct objfile *objfile = (struct objfile *) objfile_voidp;
1895 if (exp_objfile->separate_debug_objfile_backlink)
1896 exp_objfile = exp_objfile->separate_debug_objfile_backlink;
1898 return exp_objfile == objfile;
1901 /* Return 1 if EXP uses OBJFILE (and will become dangling when OBJFILE
1902 is unloaded), otherwise return 0. OBJFILE must not be a separate debug info
1906 exp_uses_objfile (struct expression *exp, struct objfile *objfile)
1908 gdb_assert (objfile->separate_debug_objfile_backlink == NULL);
1910 return exp_iterate (exp, exp_uses_objfile_iter, objfile);
1913 /* See definition in parser-defs.h. */
1916 increase_expout_size (struct parser_state *ps, size_t lenelt)
1918 if ((ps->expout_ptr + lenelt) >= ps->expout_size)
1920 ps->expout_size = std::max (ps->expout_size * 2,
1921 ps->expout_ptr + lenelt + 10);
1922 ps->expout = (struct expression *)
1923 xrealloc (ps->expout, (sizeof (struct expression)
1924 + EXP_ELEM_TO_BYTES (ps->expout_size)));
1929 _initialize_parse (void)
1931 type_stack.size = 0;
1932 type_stack.depth = 0;
1933 type_stack.elements = NULL;
1935 add_setshow_zuinteger_cmd ("expression", class_maintenance,
1937 _("Set expression debugging."),
1938 _("Show expression debugging."),
1939 _("When non-zero, the internal representation "
1940 "of expressions will be printed."),
1942 show_expressiondebug,
1943 &setdebuglist, &showdebuglist);
1944 add_setshow_boolean_cmd ("parser", class_maintenance,
1946 _("Set parser debugging."),
1947 _("Show parser debugging."),
1948 _("When non-zero, expression parser "
1949 "tracing will be enabled."),
1952 &setdebuglist, &showdebuglist);