gdb Power 9 add test for HW watchpoint support.
[binutils-gdb.git] / gdb / go-exp.y
1 /* YACC parser for Go expressions, for GDB.
2
3 Copyright (C) 2012-2022 Free Software Foundation, Inc.
4
5 This file is part of GDB.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
20 /* This file is derived from c-exp.y, p-exp.y. */
21
22 /* Parse a Go expression from text in a string,
23 and return the result as a struct expression pointer.
24 That structure contains arithmetic operations in reverse polish,
25 with constants represented by operations that are followed by special data.
26 See expression.h for the details of the format.
27 What is important here is that it can be built up sequentially
28 during the process of parsing; the lower levels of the tree always
29 come first in the result.
30
31 Note that malloc's and realloc's in this file are transformed to
32 xmalloc and xrealloc respectively by the same sed command in the
33 makefile that remaps any other malloc/realloc inserted by the parser
34 generator. Doing this with #defines and trying to control the interaction
35 with include files (<malloc.h> and <stdlib.h> for example) just became
36 too messy, particularly when such includes can be inserted at random
37 times by the parser generator. */
38
39 /* Known bugs or limitations:
40
41 - Unicode
42 - &^
43 - '_' (blank identifier)
44 - automatic deref of pointers
45 - method expressions
46 - interfaces, channels, etc.
47
48 And lots of other things.
49 I'm sure there's some cleanup to do.
50 */
51
52 %{
53
54 #include "defs.h"
55 #include <ctype.h>
56 #include "expression.h"
57 #include "value.h"
58 #include "parser-defs.h"
59 #include "language.h"
60 #include "c-lang.h"
61 #include "go-lang.h"
62 #include "bfd.h" /* Required by objfiles.h. */
63 #include "symfile.h" /* Required by objfiles.h. */
64 #include "objfiles.h" /* For have_full_symbols and have_partial_symbols */
65 #include "charset.h"
66 #include "block.h"
67 #include "expop.h"
68
69 #define parse_type(ps) builtin_type (ps->gdbarch ())
70
71 /* Remap normal yacc parser interface names (yyparse, yylex, yyerror,
72 etc). */
73 #define GDB_YY_REMAP_PREFIX go_
74 #include "yy-remap.h"
75
76 /* The state of the parser, used internally when we are parsing the
77 expression. */
78
79 static struct parser_state *pstate = NULL;
80
81 int yyparse (void);
82
83 static int yylex (void);
84
85 static void yyerror (const char *);
86
87 %}
88
89 /* Although the yacc "value" of an expression is not used,
90 since the result is stored in the structure being created,
91 other node types do have values. */
92
93 %union
94 {
95 LONGEST lval;
96 struct {
97 LONGEST val;
98 struct type *type;
99 } typed_val_int;
100 struct {
101 gdb_byte val[16];
102 struct type *type;
103 } typed_val_float;
104 struct stoken sval;
105 struct symtoken ssym;
106 struct type *tval;
107 struct typed_stoken tsval;
108 struct ttype tsym;
109 int voidval;
110 enum exp_opcode opcode;
111 struct internalvar *ivar;
112 struct stoken_vector svec;
113 }
114
115 %{
116 /* YYSTYPE gets defined by %union. */
117 static int parse_number (struct parser_state *,
118 const char *, int, int, YYSTYPE *);
119
120 using namespace expr;
121 %}
122
123 %type <voidval> exp exp1 type_exp start variable lcurly
124 %type <lval> rcurly
125 %type <tval> type
126
127 %token <typed_val_int> INT
128 %token <typed_val_float> FLOAT
129
130 /* Both NAME and TYPENAME tokens represent symbols in the input,
131 and both convey their data as strings.
132 But a TYPENAME is a string that happens to be defined as a type
133 or builtin type name (such as int or char)
134 and a NAME is any other symbol.
135 Contexts where this distinction is not important can use the
136 nonterminal "name", which matches either NAME or TYPENAME. */
137
138 %token <tsval> RAW_STRING
139 %token <tsval> STRING
140 %token <tsval> CHAR
141 %token <ssym> NAME
142 %token <tsym> TYPENAME /* Not TYPE_NAME cus already taken. */
143 %token <voidval> COMPLETE
144 /*%type <sval> name*/
145 %type <svec> string_exp
146 %type <ssym> name_not_typename
147
148 /* A NAME_OR_INT is a symbol which is not known in the symbol table,
149 but which would parse as a valid number in the current input radix.
150 E.g. "c" when input_radix==16. Depending on the parse, it will be
151 turned into a name or into a number. */
152 %token <ssym> NAME_OR_INT
153
154 %token <lval> TRUE_KEYWORD FALSE_KEYWORD
155 %token STRUCT_KEYWORD INTERFACE_KEYWORD TYPE_KEYWORD CHAN_KEYWORD
156 %token SIZEOF_KEYWORD
157 %token LEN_KEYWORD CAP_KEYWORD
158 %token NEW_KEYWORD
159 %token IOTA_KEYWORD NIL_KEYWORD
160 %token CONST_KEYWORD
161 %token DOTDOTDOT
162 %token ENTRY
163 %token ERROR
164
165 /* Special type cases. */
166 %token BYTE_KEYWORD /* An alias of uint8. */
167
168 %token <sval> DOLLAR_VARIABLE
169
170 %token <opcode> ASSIGN_MODIFY
171
172 %left ','
173 %left ABOVE_COMMA
174 %right '=' ASSIGN_MODIFY
175 %right '?'
176 %left OROR
177 %left ANDAND
178 %left '|'
179 %left '^'
180 %left '&'
181 %left ANDNOT
182 %left EQUAL NOTEQUAL
183 %left '<' '>' LEQ GEQ
184 %left LSH RSH
185 %left '@'
186 %left '+' '-'
187 %left '*' '/' '%'
188 %right UNARY INCREMENT DECREMENT
189 %right LEFT_ARROW '.' '[' '('
190
191 \f
192 %%
193
194 start : exp1
195 | type_exp
196 ;
197
198 type_exp: type
199 { pstate->push_new<type_operation> ($1); }
200 ;
201
202 /* Expressions, including the comma operator. */
203 exp1 : exp
204 | exp1 ',' exp
205 { pstate->wrap2<comma_operation> (); }
206 ;
207
208 /* Expressions, not including the comma operator. */
209 exp : '*' exp %prec UNARY
210 { pstate->wrap<unop_ind_operation> (); }
211 ;
212
213 exp : '&' exp %prec UNARY
214 { pstate->wrap<unop_addr_operation> (); }
215 ;
216
217 exp : '-' exp %prec UNARY
218 { pstate->wrap<unary_neg_operation> (); }
219 ;
220
221 exp : '+' exp %prec UNARY
222 { pstate->wrap<unary_plus_operation> (); }
223 ;
224
225 exp : '!' exp %prec UNARY
226 { pstate->wrap<unary_logical_not_operation> (); }
227 ;
228
229 exp : '^' exp %prec UNARY
230 { pstate->wrap<unary_complement_operation> (); }
231 ;
232
233 exp : exp INCREMENT %prec UNARY
234 { pstate->wrap<postinc_operation> (); }
235 ;
236
237 exp : exp DECREMENT %prec UNARY
238 { pstate->wrap<postdec_operation> (); }
239 ;
240
241 /* foo->bar is not in Go. May want as a gdb extension. Later. */
242
243 exp : exp '.' name_not_typename
244 {
245 pstate->push_new<structop_operation>
246 (pstate->pop (), copy_name ($3.stoken));
247 }
248 ;
249
250 exp : exp '.' name_not_typename COMPLETE
251 {
252 structop_base_operation *op
253 = new structop_operation (pstate->pop (),
254 copy_name ($3.stoken));
255 pstate->mark_struct_expression (op);
256 pstate->push (operation_up (op));
257 }
258 ;
259
260 exp : exp '.' COMPLETE
261 {
262 structop_base_operation *op
263 = new structop_operation (pstate->pop (), "");
264 pstate->mark_struct_expression (op);
265 pstate->push (operation_up (op));
266 }
267 ;
268
269 exp : exp '[' exp1 ']'
270 { pstate->wrap2<subscript_operation> (); }
271 ;
272
273 exp : exp '('
274 /* This is to save the value of arglist_len
275 being accumulated by an outer function call. */
276 { pstate->start_arglist (); }
277 arglist ')' %prec LEFT_ARROW
278 {
279 std::vector<operation_up> args
280 = pstate->pop_vector (pstate->end_arglist ());
281 pstate->push_new<funcall_operation>
282 (pstate->pop (), std::move (args));
283 }
284 ;
285
286 lcurly : '{'
287 { pstate->start_arglist (); }
288 ;
289
290 arglist :
291 ;
292
293 arglist : exp
294 { pstate->arglist_len = 1; }
295 ;
296
297 arglist : arglist ',' exp %prec ABOVE_COMMA
298 { pstate->arglist_len++; }
299 ;
300
301 rcurly : '}'
302 { $$ = pstate->end_arglist () - 1; }
303 ;
304
305 exp : lcurly type rcurly exp %prec UNARY
306 {
307 pstate->push_new<unop_memval_operation>
308 (pstate->pop (), $2);
309 }
310 ;
311
312 exp : type '(' exp ')' %prec UNARY
313 {
314 pstate->push_new<unop_cast_operation>
315 (pstate->pop (), $1);
316 }
317 ;
318
319 exp : '(' exp1 ')'
320 { }
321 ;
322
323 /* Binary operators in order of decreasing precedence. */
324
325 exp : exp '@' exp
326 { pstate->wrap2<repeat_operation> (); }
327 ;
328
329 exp : exp '*' exp
330 { pstate->wrap2<mul_operation> (); }
331 ;
332
333 exp : exp '/' exp
334 { pstate->wrap2<div_operation> (); }
335 ;
336
337 exp : exp '%' exp
338 { pstate->wrap2<rem_operation> (); }
339 ;
340
341 exp : exp '+' exp
342 { pstate->wrap2<add_operation> (); }
343 ;
344
345 exp : exp '-' exp
346 { pstate->wrap2<sub_operation> (); }
347 ;
348
349 exp : exp LSH exp
350 { pstate->wrap2<lsh_operation> (); }
351 ;
352
353 exp : exp RSH exp
354 { pstate->wrap2<rsh_operation> (); }
355 ;
356
357 exp : exp EQUAL exp
358 { pstate->wrap2<equal_operation> (); }
359 ;
360
361 exp : exp NOTEQUAL exp
362 { pstate->wrap2<notequal_operation> (); }
363 ;
364
365 exp : exp LEQ exp
366 { pstate->wrap2<leq_operation> (); }
367 ;
368
369 exp : exp GEQ exp
370 { pstate->wrap2<geq_operation> (); }
371 ;
372
373 exp : exp '<' exp
374 { pstate->wrap2<less_operation> (); }
375 ;
376
377 exp : exp '>' exp
378 { pstate->wrap2<gtr_operation> (); }
379 ;
380
381 exp : exp '&' exp
382 { pstate->wrap2<bitwise_and_operation> (); }
383 ;
384
385 exp : exp '^' exp
386 { pstate->wrap2<bitwise_xor_operation> (); }
387 ;
388
389 exp : exp '|' exp
390 { pstate->wrap2<bitwise_ior_operation> (); }
391 ;
392
393 exp : exp ANDAND exp
394 { pstate->wrap2<logical_and_operation> (); }
395 ;
396
397 exp : exp OROR exp
398 { pstate->wrap2<logical_or_operation> (); }
399 ;
400
401 exp : exp '?' exp ':' exp %prec '?'
402 {
403 operation_up last = pstate->pop ();
404 operation_up mid = pstate->pop ();
405 operation_up first = pstate->pop ();
406 pstate->push_new<ternop_cond_operation>
407 (std::move (first), std::move (mid),
408 std::move (last));
409 }
410 ;
411
412 exp : exp '=' exp
413 { pstate->wrap2<assign_operation> (); }
414 ;
415
416 exp : exp ASSIGN_MODIFY exp
417 {
418 operation_up rhs = pstate->pop ();
419 operation_up lhs = pstate->pop ();
420 pstate->push_new<assign_modify_operation>
421 ($2, std::move (lhs), std::move (rhs));
422 }
423 ;
424
425 exp : INT
426 {
427 pstate->push_new<long_const_operation>
428 ($1.type, $1.val);
429 }
430 ;
431
432 exp : CHAR
433 {
434 struct stoken_vector vec;
435 vec.len = 1;
436 vec.tokens = &$1;
437 pstate->push_c_string ($1.type, &vec);
438 }
439 ;
440
441 exp : NAME_OR_INT
442 { YYSTYPE val;
443 parse_number (pstate, $1.stoken.ptr,
444 $1.stoken.length, 0, &val);
445 pstate->push_new<long_const_operation>
446 (val.typed_val_int.type,
447 val.typed_val_int.val);
448 }
449 ;
450
451
452 exp : FLOAT
453 {
454 float_data data;
455 std::copy (std::begin ($1.val), std::end ($1.val),
456 std::begin (data));
457 pstate->push_new<float_const_operation> ($1.type, data);
458 }
459 ;
460
461 exp : variable
462 ;
463
464 exp : DOLLAR_VARIABLE
465 {
466 pstate->push_dollar ($1);
467 }
468 ;
469
470 exp : SIZEOF_KEYWORD '(' type ')' %prec UNARY
471 {
472 /* TODO(dje): Go objects in structs. */
473 /* TODO(dje): What's the right type here? */
474 struct type *size_type
475 = parse_type (pstate)->builtin_unsigned_int;
476 $3 = check_typedef ($3);
477 pstate->push_new<long_const_operation>
478 (size_type, (LONGEST) TYPE_LENGTH ($3));
479 }
480 ;
481
482 exp : SIZEOF_KEYWORD '(' exp ')' %prec UNARY
483 {
484 /* TODO(dje): Go objects in structs. */
485 pstate->wrap<unop_sizeof_operation> ();
486 }
487
488 string_exp:
489 STRING
490 {
491 /* We copy the string here, and not in the
492 lexer, to guarantee that we do not leak a
493 string. */
494 /* Note that we NUL-terminate here, but just
495 for convenience. */
496 struct typed_stoken *vec = XNEW (struct typed_stoken);
497 $$.len = 1;
498 $$.tokens = vec;
499
500 vec->type = $1.type;
501 vec->length = $1.length;
502 vec->ptr = (char *) malloc ($1.length + 1);
503 memcpy (vec->ptr, $1.ptr, $1.length + 1);
504 }
505
506 | string_exp '+' STRING
507 {
508 /* Note that we NUL-terminate here, but just
509 for convenience. */
510 char *p;
511 ++$$.len;
512 $$.tokens = XRESIZEVEC (struct typed_stoken,
513 $$.tokens, $$.len);
514
515 p = (char *) malloc ($3.length + 1);
516 memcpy (p, $3.ptr, $3.length + 1);
517
518 $$.tokens[$$.len - 1].type = $3.type;
519 $$.tokens[$$.len - 1].length = $3.length;
520 $$.tokens[$$.len - 1].ptr = p;
521 }
522 ;
523
524 exp : string_exp %prec ABOVE_COMMA
525 {
526 int i;
527
528 /* Always utf8. */
529 pstate->push_c_string (0, &$1);
530 for (i = 0; i < $1.len; ++i)
531 free ($1.tokens[i].ptr);
532 free ($1.tokens);
533 }
534 ;
535
536 exp : TRUE_KEYWORD
537 { pstate->push_new<bool_operation> ($1); }
538 ;
539
540 exp : FALSE_KEYWORD
541 { pstate->push_new<bool_operation> ($1); }
542 ;
543
544 variable: name_not_typename ENTRY
545 { struct symbol *sym = $1.sym.symbol;
546
547 if (sym == NULL
548 || !SYMBOL_IS_ARGUMENT (sym)
549 || !symbol_read_needs_frame (sym))
550 error (_("@entry can be used only for function "
551 "parameters, not for \"%s\""),
552 copy_name ($1.stoken).c_str ());
553
554 pstate->push_new<var_entry_value_operation> (sym);
555 }
556 ;
557
558 variable: name_not_typename
559 { struct block_symbol sym = $1.sym;
560
561 if (sym.symbol)
562 {
563 if (symbol_read_needs_frame (sym.symbol))
564 pstate->block_tracker->update (sym);
565
566 pstate->push_new<var_value_operation> (sym);
567 }
568 else if ($1.is_a_field_of_this)
569 {
570 /* TODO(dje): Can we get here?
571 E.g., via a mix of c++ and go? */
572 gdb_assert_not_reached ("go with `this' field");
573 }
574 else
575 {
576 struct bound_minimal_symbol msymbol;
577 std::string arg = copy_name ($1.stoken);
578
579 msymbol =
580 lookup_bound_minimal_symbol (arg.c_str ());
581 if (msymbol.minsym != NULL)
582 pstate->push_new<var_msym_value_operation>
583 (msymbol);
584 else if (!have_full_symbols ()
585 && !have_partial_symbols ())
586 error (_("No symbol table is loaded. "
587 "Use the \"file\" command."));
588 else
589 error (_("No symbol \"%s\" in current context."),
590 arg.c_str ());
591 }
592 }
593 ;
594
595 /* TODO
596 method_exp: PACKAGENAME '.' name '.' name
597 {
598 }
599 ;
600 */
601
602 type /* Implements (approximately): [*] type-specifier */
603 : '*' type
604 { $$ = lookup_pointer_type ($2); }
605 | TYPENAME
606 { $$ = $1.type; }
607 /*
608 | STRUCT_KEYWORD name
609 { $$ = lookup_struct (copy_name ($2),
610 expression_context_block); }
611 */
612 | BYTE_KEYWORD
613 { $$ = builtin_go_type (pstate->gdbarch ())
614 ->builtin_uint8; }
615 ;
616
617 /* TODO
618 name : NAME { $$ = $1.stoken; }
619 | TYPENAME { $$ = $1.stoken; }
620 | NAME_OR_INT { $$ = $1.stoken; }
621 ;
622 */
623
624 name_not_typename
625 : NAME
626 /* These would be useful if name_not_typename was useful, but it is just
627 a fake for "variable", so these cause reduce/reduce conflicts because
628 the parser can't tell whether NAME_OR_INT is a name_not_typename (=variable,
629 =exp) or just an exp. If name_not_typename was ever used in an lvalue
630 context where only a name could occur, this might be useful.
631 | NAME_OR_INT
632 */
633 ;
634
635 %%
636
637 /* Take care of parsing a number (anything that starts with a digit).
638 Set yylval and return the token type; update lexptr.
639 LEN is the number of characters in it. */
640
641 /* FIXME: Needs some error checking for the float case. */
642 /* FIXME(dje): IWBN to use c-exp.y's parse_number if we could.
643 That will require moving the guts into a function that we both call
644 as our YYSTYPE is different than c-exp.y's */
645
646 static int
647 parse_number (struct parser_state *par_state,
648 const char *p, int len, int parsed_float, YYSTYPE *putithere)
649 {
650 /* FIXME: Shouldn't these be unsigned? We don't deal with negative values
651 here, and we do kind of silly things like cast to unsigned. */
652 LONGEST n = 0;
653 LONGEST prevn = 0;
654 ULONGEST un;
655
656 int i = 0;
657 int c;
658 int base = input_radix;
659 int unsigned_p = 0;
660
661 /* Number of "L" suffixes encountered. */
662 int long_p = 0;
663
664 /* We have found a "L" or "U" suffix. */
665 int found_suffix = 0;
666
667 ULONGEST high_bit;
668 struct type *signed_type;
669 struct type *unsigned_type;
670
671 if (parsed_float)
672 {
673 const struct builtin_go_type *builtin_go_types
674 = builtin_go_type (par_state->gdbarch ());
675
676 /* Handle suffixes: 'f' for float32, 'l' for long double.
677 FIXME: This appears to be an extension -- do we want this? */
678 if (len >= 1 && tolower (p[len - 1]) == 'f')
679 {
680 putithere->typed_val_float.type
681 = builtin_go_types->builtin_float32;
682 len--;
683 }
684 else if (len >= 1 && tolower (p[len - 1]) == 'l')
685 {
686 putithere->typed_val_float.type
687 = parse_type (par_state)->builtin_long_double;
688 len--;
689 }
690 /* Default type for floating-point literals is float64. */
691 else
692 {
693 putithere->typed_val_float.type
694 = builtin_go_types->builtin_float64;
695 }
696
697 if (!parse_float (p, len,
698 putithere->typed_val_float.type,
699 putithere->typed_val_float.val))
700 return ERROR;
701 return FLOAT;
702 }
703
704 /* Handle base-switching prefixes 0x, 0t, 0d, 0. */
705 if (p[0] == '0')
706 switch (p[1])
707 {
708 case 'x':
709 case 'X':
710 if (len >= 3)
711 {
712 p += 2;
713 base = 16;
714 len -= 2;
715 }
716 break;
717
718 case 'b':
719 case 'B':
720 if (len >= 3)
721 {
722 p += 2;
723 base = 2;
724 len -= 2;
725 }
726 break;
727
728 case 't':
729 case 'T':
730 case 'd':
731 case 'D':
732 if (len >= 3)
733 {
734 p += 2;
735 base = 10;
736 len -= 2;
737 }
738 break;
739
740 default:
741 base = 8;
742 break;
743 }
744
745 while (len-- > 0)
746 {
747 c = *p++;
748 if (c >= 'A' && c <= 'Z')
749 c += 'a' - 'A';
750 if (c != 'l' && c != 'u')
751 n *= base;
752 if (c >= '0' && c <= '9')
753 {
754 if (found_suffix)
755 return ERROR;
756 n += i = c - '0';
757 }
758 else
759 {
760 if (base > 10 && c >= 'a' && c <= 'f')
761 {
762 if (found_suffix)
763 return ERROR;
764 n += i = c - 'a' + 10;
765 }
766 else if (c == 'l')
767 {
768 ++long_p;
769 found_suffix = 1;
770 }
771 else if (c == 'u')
772 {
773 unsigned_p = 1;
774 found_suffix = 1;
775 }
776 else
777 return ERROR; /* Char not a digit */
778 }
779 if (i >= base)
780 return ERROR; /* Invalid digit in this base. */
781
782 /* Portably test for overflow (only works for nonzero values, so make
783 a second check for zero). FIXME: Can't we just make n and prevn
784 unsigned and avoid this? */
785 if (c != 'l' && c != 'u' && (prevn >= n) && n != 0)
786 unsigned_p = 1; /* Try something unsigned. */
787
788 /* Portably test for unsigned overflow.
789 FIXME: This check is wrong; for example it doesn't find overflow
790 on 0x123456789 when LONGEST is 32 bits. */
791 if (c != 'l' && c != 'u' && n != 0)
792 {
793 if ((unsigned_p && (ULONGEST) prevn >= (ULONGEST) n))
794 error (_("Numeric constant too large."));
795 }
796 prevn = n;
797 }
798
799 /* An integer constant is an int, a long, or a long long. An L
800 suffix forces it to be long; an LL suffix forces it to be long
801 long. If not forced to a larger size, it gets the first type of
802 the above that it fits in. To figure out whether it fits, we
803 shift it right and see whether anything remains. Note that we
804 can't shift sizeof (LONGEST) * HOST_CHAR_BIT bits or more in one
805 operation, because many compilers will warn about such a shift
806 (which always produces a zero result). Sometimes gdbarch_int_bit
807 or gdbarch_long_bit will be that big, sometimes not. To deal with
808 the case where it is we just always shift the value more than
809 once, with fewer bits each time. */
810
811 un = (ULONGEST)n >> 2;
812 if (long_p == 0
813 && (un >> (gdbarch_int_bit (par_state->gdbarch ()) - 2)) == 0)
814 {
815 high_bit
816 = ((ULONGEST)1) << (gdbarch_int_bit (par_state->gdbarch ()) - 1);
817
818 /* A large decimal (not hex or octal) constant (between INT_MAX
819 and UINT_MAX) is a long or unsigned long, according to ANSI,
820 never an unsigned int, but this code treats it as unsigned
821 int. This probably should be fixed. GCC gives a warning on
822 such constants. */
823
824 unsigned_type = parse_type (par_state)->builtin_unsigned_int;
825 signed_type = parse_type (par_state)->builtin_int;
826 }
827 else if (long_p <= 1
828 && (un >> (gdbarch_long_bit (par_state->gdbarch ()) - 2)) == 0)
829 {
830 high_bit
831 = ((ULONGEST)1) << (gdbarch_long_bit (par_state->gdbarch ()) - 1);
832 unsigned_type = parse_type (par_state)->builtin_unsigned_long;
833 signed_type = parse_type (par_state)->builtin_long;
834 }
835 else
836 {
837 int shift;
838 if (sizeof (ULONGEST) * HOST_CHAR_BIT
839 < gdbarch_long_long_bit (par_state->gdbarch ()))
840 /* A long long does not fit in a LONGEST. */
841 shift = (sizeof (ULONGEST) * HOST_CHAR_BIT - 1);
842 else
843 shift = (gdbarch_long_long_bit (par_state->gdbarch ()) - 1);
844 high_bit = (ULONGEST) 1 << shift;
845 unsigned_type = parse_type (par_state)->builtin_unsigned_long_long;
846 signed_type = parse_type (par_state)->builtin_long_long;
847 }
848
849 putithere->typed_val_int.val = n;
850
851 /* If the high bit of the worked out type is set then this number
852 has to be unsigned. */
853
854 if (unsigned_p || (n & high_bit))
855 {
856 putithere->typed_val_int.type = unsigned_type;
857 }
858 else
859 {
860 putithere->typed_val_int.type = signed_type;
861 }
862
863 return INT;
864 }
865
866 /* Temporary obstack used for holding strings. */
867 static struct obstack tempbuf;
868 static int tempbuf_init;
869
870 /* Parse a string or character literal from TOKPTR. The string or
871 character may be wide or unicode. *OUTPTR is set to just after the
872 end of the literal in the input string. The resulting token is
873 stored in VALUE. This returns a token value, either STRING or
874 CHAR, depending on what was parsed. *HOST_CHARS is set to the
875 number of host characters in the literal. */
876
877 static int
878 parse_string_or_char (const char *tokptr, const char **outptr,
879 struct typed_stoken *value, int *host_chars)
880 {
881 int quote;
882
883 /* Build the gdb internal form of the input string in tempbuf. Note
884 that the buffer is null byte terminated *only* for the
885 convenience of debugging gdb itself and printing the buffer
886 contents when the buffer contains no embedded nulls. Gdb does
887 not depend upon the buffer being null byte terminated, it uses
888 the length string instead. This allows gdb to handle C strings
889 (as well as strings in other languages) with embedded null
890 bytes */
891
892 if (!tempbuf_init)
893 tempbuf_init = 1;
894 else
895 obstack_free (&tempbuf, NULL);
896 obstack_init (&tempbuf);
897
898 /* Skip the quote. */
899 quote = *tokptr;
900 ++tokptr;
901
902 *host_chars = 0;
903
904 while (*tokptr)
905 {
906 char c = *tokptr;
907 if (c == '\\')
908 {
909 ++tokptr;
910 *host_chars += c_parse_escape (&tokptr, &tempbuf);
911 }
912 else if (c == quote)
913 break;
914 else
915 {
916 obstack_1grow (&tempbuf, c);
917 ++tokptr;
918 /* FIXME: this does the wrong thing with multi-byte host
919 characters. We could use mbrlen here, but that would
920 make "set host-charset" a bit less useful. */
921 ++*host_chars;
922 }
923 }
924
925 if (*tokptr != quote)
926 {
927 if (quote == '"')
928 error (_("Unterminated string in expression."));
929 else
930 error (_("Unmatched single quote."));
931 }
932 ++tokptr;
933
934 value->type = (int) C_STRING | (quote == '\'' ? C_CHAR : 0); /*FIXME*/
935 value->ptr = (char *) obstack_base (&tempbuf);
936 value->length = obstack_object_size (&tempbuf);
937
938 *outptr = tokptr;
939
940 return quote == '\'' ? CHAR : STRING;
941 }
942
943 struct token
944 {
945 const char *oper;
946 int token;
947 enum exp_opcode opcode;
948 };
949
950 static const struct token tokentab3[] =
951 {
952 {">>=", ASSIGN_MODIFY, BINOP_RSH},
953 {"<<=", ASSIGN_MODIFY, BINOP_LSH},
954 /*{"&^=", ASSIGN_MODIFY, BINOP_BITWISE_ANDNOT}, TODO */
955 {"...", DOTDOTDOT, OP_NULL},
956 };
957
958 static const struct token tokentab2[] =
959 {
960 {"+=", ASSIGN_MODIFY, BINOP_ADD},
961 {"-=", ASSIGN_MODIFY, BINOP_SUB},
962 {"*=", ASSIGN_MODIFY, BINOP_MUL},
963 {"/=", ASSIGN_MODIFY, BINOP_DIV},
964 {"%=", ASSIGN_MODIFY, BINOP_REM},
965 {"|=", ASSIGN_MODIFY, BINOP_BITWISE_IOR},
966 {"&=", ASSIGN_MODIFY, BINOP_BITWISE_AND},
967 {"^=", ASSIGN_MODIFY, BINOP_BITWISE_XOR},
968 {"++", INCREMENT, OP_NULL},
969 {"--", DECREMENT, OP_NULL},
970 /*{"->", RIGHT_ARROW, OP_NULL}, Doesn't exist in Go. */
971 {"<-", LEFT_ARROW, OP_NULL},
972 {"&&", ANDAND, OP_NULL},
973 {"||", OROR, OP_NULL},
974 {"<<", LSH, OP_NULL},
975 {">>", RSH, OP_NULL},
976 {"==", EQUAL, OP_NULL},
977 {"!=", NOTEQUAL, OP_NULL},
978 {"<=", LEQ, OP_NULL},
979 {">=", GEQ, OP_NULL},
980 /*{"&^", ANDNOT, OP_NULL}, TODO */
981 };
982
983 /* Identifier-like tokens. */
984 static const struct token ident_tokens[] =
985 {
986 {"true", TRUE_KEYWORD, OP_NULL},
987 {"false", FALSE_KEYWORD, OP_NULL},
988 {"nil", NIL_KEYWORD, OP_NULL},
989 {"const", CONST_KEYWORD, OP_NULL},
990 {"struct", STRUCT_KEYWORD, OP_NULL},
991 {"type", TYPE_KEYWORD, OP_NULL},
992 {"interface", INTERFACE_KEYWORD, OP_NULL},
993 {"chan", CHAN_KEYWORD, OP_NULL},
994 {"byte", BYTE_KEYWORD, OP_NULL}, /* An alias of uint8. */
995 {"len", LEN_KEYWORD, OP_NULL},
996 {"cap", CAP_KEYWORD, OP_NULL},
997 {"new", NEW_KEYWORD, OP_NULL},
998 {"iota", IOTA_KEYWORD, OP_NULL},
999 };
1000
1001 /* This is set if a NAME token appeared at the very end of the input
1002 string, with no whitespace separating the name from the EOF. This
1003 is used only when parsing to do field name completion. */
1004 static int saw_name_at_eof;
1005
1006 /* This is set if the previously-returned token was a structure
1007 operator -- either '.' or ARROW. This is used only when parsing to
1008 do field name completion. */
1009 static int last_was_structop;
1010
1011 /* Depth of parentheses. */
1012 static int paren_depth;
1013
1014 /* Read one token, getting characters through lexptr. */
1015
1016 static int
1017 lex_one_token (struct parser_state *par_state)
1018 {
1019 int c;
1020 int namelen;
1021 const char *tokstart;
1022 int saw_structop = last_was_structop;
1023
1024 last_was_structop = 0;
1025
1026 retry:
1027
1028 par_state->prev_lexptr = par_state->lexptr;
1029
1030 tokstart = par_state->lexptr;
1031 /* See if it is a special token of length 3. */
1032 for (const auto &token : tokentab3)
1033 if (strncmp (tokstart, token.oper, 3) == 0)
1034 {
1035 par_state->lexptr += 3;
1036 yylval.opcode = token.opcode;
1037 return token.token;
1038 }
1039
1040 /* See if it is a special token of length 2. */
1041 for (const auto &token : tokentab2)
1042 if (strncmp (tokstart, token.oper, 2) == 0)
1043 {
1044 par_state->lexptr += 2;
1045 yylval.opcode = token.opcode;
1046 /* NOTE: -> doesn't exist in Go, so we don't need to watch for
1047 setting last_was_structop here. */
1048 return token.token;
1049 }
1050
1051 switch (c = *tokstart)
1052 {
1053 case 0:
1054 if (saw_name_at_eof)
1055 {
1056 saw_name_at_eof = 0;
1057 return COMPLETE;
1058 }
1059 else if (saw_structop)
1060 return COMPLETE;
1061 else
1062 return 0;
1063
1064 case ' ':
1065 case '\t':
1066 case '\n':
1067 par_state->lexptr++;
1068 goto retry;
1069
1070 case '[':
1071 case '(':
1072 paren_depth++;
1073 par_state->lexptr++;
1074 return c;
1075
1076 case ']':
1077 case ')':
1078 if (paren_depth == 0)
1079 return 0;
1080 paren_depth--;
1081 par_state->lexptr++;
1082 return c;
1083
1084 case ',':
1085 if (pstate->comma_terminates
1086 && paren_depth == 0)
1087 return 0;
1088 par_state->lexptr++;
1089 return c;
1090
1091 case '.':
1092 /* Might be a floating point number. */
1093 if (par_state->lexptr[1] < '0' || par_state->lexptr[1] > '9')
1094 {
1095 if (pstate->parse_completion)
1096 last_was_structop = 1;
1097 goto symbol; /* Nope, must be a symbol. */
1098 }
1099 /* FALL THRU. */
1100
1101 case '0':
1102 case '1':
1103 case '2':
1104 case '3':
1105 case '4':
1106 case '5':
1107 case '6':
1108 case '7':
1109 case '8':
1110 case '9':
1111 {
1112 /* It's a number. */
1113 int got_dot = 0, got_e = 0, toktype;
1114 const char *p = tokstart;
1115 int hex = input_radix > 10;
1116
1117 if (c == '0' && (p[1] == 'x' || p[1] == 'X'))
1118 {
1119 p += 2;
1120 hex = 1;
1121 }
1122
1123 for (;; ++p)
1124 {
1125 /* This test includes !hex because 'e' is a valid hex digit
1126 and thus does not indicate a floating point number when
1127 the radix is hex. */
1128 if (!hex && !got_e && (*p == 'e' || *p == 'E'))
1129 got_dot = got_e = 1;
1130 /* This test does not include !hex, because a '.' always indicates
1131 a decimal floating point number regardless of the radix. */
1132 else if (!got_dot && *p == '.')
1133 got_dot = 1;
1134 else if (got_e && (p[-1] == 'e' || p[-1] == 'E')
1135 && (*p == '-' || *p == '+'))
1136 /* This is the sign of the exponent, not the end of the
1137 number. */
1138 continue;
1139 /* We will take any letters or digits. parse_number will
1140 complain if past the radix, or if L or U are not final. */
1141 else if ((*p < '0' || *p > '9')
1142 && ((*p < 'a' || *p > 'z')
1143 && (*p < 'A' || *p > 'Z')))
1144 break;
1145 }
1146 toktype = parse_number (par_state, tokstart, p - tokstart,
1147 got_dot|got_e, &yylval);
1148 if (toktype == ERROR)
1149 {
1150 char *err_copy = (char *) alloca (p - tokstart + 1);
1151
1152 memcpy (err_copy, tokstart, p - tokstart);
1153 err_copy[p - tokstart] = 0;
1154 error (_("Invalid number \"%s\"."), err_copy);
1155 }
1156 par_state->lexptr = p;
1157 return toktype;
1158 }
1159
1160 case '@':
1161 {
1162 const char *p = &tokstart[1];
1163 size_t len = strlen ("entry");
1164
1165 while (isspace (*p))
1166 p++;
1167 if (strncmp (p, "entry", len) == 0 && !isalnum (p[len])
1168 && p[len] != '_')
1169 {
1170 par_state->lexptr = &p[len];
1171 return ENTRY;
1172 }
1173 }
1174 /* FALLTHRU */
1175 case '+':
1176 case '-':
1177 case '*':
1178 case '/':
1179 case '%':
1180 case '|':
1181 case '&':
1182 case '^':
1183 case '~':
1184 case '!':
1185 case '<':
1186 case '>':
1187 case '?':
1188 case ':':
1189 case '=':
1190 case '{':
1191 case '}':
1192 symbol:
1193 par_state->lexptr++;
1194 return c;
1195
1196 case '\'':
1197 case '"':
1198 case '`':
1199 {
1200 int host_len;
1201 int result = parse_string_or_char (tokstart, &par_state->lexptr,
1202 &yylval.tsval, &host_len);
1203 if (result == CHAR)
1204 {
1205 if (host_len == 0)
1206 error (_("Empty character constant."));
1207 else if (host_len > 2 && c == '\'')
1208 {
1209 ++tokstart;
1210 namelen = par_state->lexptr - tokstart - 1;
1211 goto tryname;
1212 }
1213 else if (host_len > 1)
1214 error (_("Invalid character constant."));
1215 }
1216 return result;
1217 }
1218 }
1219
1220 if (!(c == '_' || c == '$'
1221 || (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')))
1222 /* We must have come across a bad character (e.g. ';'). */
1223 error (_("Invalid character '%c' in expression."), c);
1224
1225 /* It's a name. See how long it is. */
1226 namelen = 0;
1227 for (c = tokstart[namelen];
1228 (c == '_' || c == '$' || (c >= '0' && c <= '9')
1229 || (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'));)
1230 {
1231 c = tokstart[++namelen];
1232 }
1233
1234 /* The token "if" terminates the expression and is NOT removed from
1235 the input stream. It doesn't count if it appears in the
1236 expansion of a macro. */
1237 if (namelen == 2
1238 && tokstart[0] == 'i'
1239 && tokstart[1] == 'f')
1240 {
1241 return 0;
1242 }
1243
1244 /* For the same reason (breakpoint conditions), "thread N"
1245 terminates the expression. "thread" could be an identifier, but
1246 an identifier is never followed by a number without intervening
1247 punctuation.
1248 Handle abbreviations of these, similarly to
1249 breakpoint.c:find_condition_and_thread.
1250 TODO: Watch for "goroutine" here? */
1251 if (namelen >= 1
1252 && strncmp (tokstart, "thread", namelen) == 0
1253 && (tokstart[namelen] == ' ' || tokstart[namelen] == '\t'))
1254 {
1255 const char *p = tokstart + namelen + 1;
1256
1257 while (*p == ' ' || *p == '\t')
1258 p++;
1259 if (*p >= '0' && *p <= '9')
1260 return 0;
1261 }
1262
1263 par_state->lexptr += namelen;
1264
1265 tryname:
1266
1267 yylval.sval.ptr = tokstart;
1268 yylval.sval.length = namelen;
1269
1270 /* Catch specific keywords. */
1271 std::string copy = copy_name (yylval.sval);
1272 for (const auto &token : ident_tokens)
1273 if (copy == token.oper)
1274 {
1275 /* It is ok to always set this, even though we don't always
1276 strictly need to. */
1277 yylval.opcode = token.opcode;
1278 return token.token;
1279 }
1280
1281 if (*tokstart == '$')
1282 return DOLLAR_VARIABLE;
1283
1284 if (pstate->parse_completion && *par_state->lexptr == '\0')
1285 saw_name_at_eof = 1;
1286 return NAME;
1287 }
1288
1289 /* An object of this type is pushed on a FIFO by the "outer" lexer. */
1290 struct token_and_value
1291 {
1292 int token;
1293 YYSTYPE value;
1294 };
1295
1296 /* A FIFO of tokens that have been read but not yet returned to the
1297 parser. */
1298 static std::vector<token_and_value> token_fifo;
1299
1300 /* Non-zero if the lexer should return tokens from the FIFO. */
1301 static int popping;
1302
1303 /* Temporary storage for yylex; this holds symbol names as they are
1304 built up. */
1305 static auto_obstack name_obstack;
1306
1307 /* Build "package.name" in name_obstack.
1308 For convenience of the caller, the name is NUL-terminated,
1309 but the NUL is not included in the recorded length. */
1310
1311 static struct stoken
1312 build_packaged_name (const char *package, int package_len,
1313 const char *name, int name_len)
1314 {
1315 struct stoken result;
1316
1317 name_obstack.clear ();
1318 obstack_grow (&name_obstack, package, package_len);
1319 obstack_grow_str (&name_obstack, ".");
1320 obstack_grow (&name_obstack, name, name_len);
1321 obstack_grow (&name_obstack, "", 1);
1322 result.ptr = (char *) obstack_base (&name_obstack);
1323 result.length = obstack_object_size (&name_obstack) - 1;
1324
1325 return result;
1326 }
1327
1328 /* Return non-zero if NAME is a package name.
1329 BLOCK is the scope in which to interpret NAME; this can be NULL
1330 to mean the global scope. */
1331
1332 static int
1333 package_name_p (const char *name, const struct block *block)
1334 {
1335 struct symbol *sym;
1336 struct field_of_this_result is_a_field_of_this;
1337
1338 sym = lookup_symbol (name, block, STRUCT_DOMAIN, &is_a_field_of_this).symbol;
1339
1340 if (sym
1341 && SYMBOL_CLASS (sym) == LOC_TYPEDEF
1342 && SYMBOL_TYPE (sym)->code () == TYPE_CODE_MODULE)
1343 return 1;
1344
1345 return 0;
1346 }
1347
1348 /* Classify a (potential) function in the "unsafe" package.
1349 We fold these into "keywords" to keep things simple, at least until
1350 something more complex is warranted. */
1351
1352 static int
1353 classify_unsafe_function (struct stoken function_name)
1354 {
1355 std::string copy = copy_name (function_name);
1356
1357 if (copy == "Sizeof")
1358 {
1359 yylval.sval = function_name;
1360 return SIZEOF_KEYWORD;
1361 }
1362
1363 error (_("Unknown function in `unsafe' package: %s"), copy.c_str ());
1364 }
1365
1366 /* Classify token(s) "name1.name2" where name1 is known to be a package.
1367 The contents of the token are in `yylval'.
1368 Updates yylval and returns the new token type.
1369
1370 The result is one of NAME, NAME_OR_INT, or TYPENAME. */
1371
1372 static int
1373 classify_packaged_name (const struct block *block)
1374 {
1375 struct block_symbol sym;
1376 struct field_of_this_result is_a_field_of_this;
1377
1378 std::string copy = copy_name (yylval.sval);
1379
1380 sym = lookup_symbol (copy.c_str (), block, VAR_DOMAIN, &is_a_field_of_this);
1381
1382 if (sym.symbol)
1383 {
1384 yylval.ssym.sym = sym;
1385 yylval.ssym.is_a_field_of_this = is_a_field_of_this.type != NULL;
1386 }
1387
1388 return NAME;
1389 }
1390
1391 /* Classify a NAME token.
1392 The contents of the token are in `yylval'.
1393 Updates yylval and returns the new token type.
1394 BLOCK is the block in which lookups start; this can be NULL
1395 to mean the global scope.
1396
1397 The result is one of NAME, NAME_OR_INT, or TYPENAME. */
1398
1399 static int
1400 classify_name (struct parser_state *par_state, const struct block *block)
1401 {
1402 struct type *type;
1403 struct block_symbol sym;
1404 struct field_of_this_result is_a_field_of_this;
1405
1406 std::string copy = copy_name (yylval.sval);
1407
1408 /* Try primitive types first so they win over bad/weird debug info. */
1409 type = language_lookup_primitive_type (par_state->language (),
1410 par_state->gdbarch (),
1411 copy.c_str ());
1412 if (type != NULL)
1413 {
1414 /* NOTE: We take advantage of the fact that yylval coming in was a
1415 NAME, and that struct ttype is a compatible extension of struct
1416 stoken, so yylval.tsym.stoken is already filled in. */
1417 yylval.tsym.type = type;
1418 return TYPENAME;
1419 }
1420
1421 /* TODO: What about other types? */
1422
1423 sym = lookup_symbol (copy.c_str (), block, VAR_DOMAIN, &is_a_field_of_this);
1424
1425 if (sym.symbol)
1426 {
1427 yylval.ssym.sym = sym;
1428 yylval.ssym.is_a_field_of_this = is_a_field_of_this.type != NULL;
1429 return NAME;
1430 }
1431
1432 /* If we didn't find a symbol, look again in the current package.
1433 This is to, e.g., make "p global_var" work without having to specify
1434 the package name. We intentionally only looks for objects in the
1435 current package. */
1436
1437 {
1438 char *current_package_name = go_block_package_name (block);
1439
1440 if (current_package_name != NULL)
1441 {
1442 struct stoken sval =
1443 build_packaged_name (current_package_name,
1444 strlen (current_package_name),
1445 copy.c_str (), copy.size ());
1446
1447 xfree (current_package_name);
1448 sym = lookup_symbol (sval.ptr, block, VAR_DOMAIN,
1449 &is_a_field_of_this);
1450 if (sym.symbol)
1451 {
1452 yylval.ssym.stoken = sval;
1453 yylval.ssym.sym = sym;
1454 yylval.ssym.is_a_field_of_this = is_a_field_of_this.type != NULL;
1455 return NAME;
1456 }
1457 }
1458 }
1459
1460 /* Input names that aren't symbols but ARE valid hex numbers, when
1461 the input radix permits them, can be names or numbers depending
1462 on the parse. Note we support radixes > 16 here. */
1463 if ((copy[0] >= 'a' && copy[0] < 'a' + input_radix - 10)
1464 || (copy[0] >= 'A' && copy[0] < 'A' + input_radix - 10))
1465 {
1466 YYSTYPE newlval; /* Its value is ignored. */
1467 int hextype = parse_number (par_state, copy.c_str (),
1468 yylval.sval.length, 0, &newlval);
1469 if (hextype == INT)
1470 {
1471 yylval.ssym.sym.symbol = NULL;
1472 yylval.ssym.sym.block = NULL;
1473 yylval.ssym.is_a_field_of_this = 0;
1474 return NAME_OR_INT;
1475 }
1476 }
1477
1478 yylval.ssym.sym.symbol = NULL;
1479 yylval.ssym.sym.block = NULL;
1480 yylval.ssym.is_a_field_of_this = 0;
1481 return NAME;
1482 }
1483
1484 /* This is taken from c-exp.y mostly to get something working.
1485 The basic structure has been kept because we may yet need some of it. */
1486
1487 static int
1488 yylex (void)
1489 {
1490 token_and_value current, next;
1491
1492 if (popping && !token_fifo.empty ())
1493 {
1494 token_and_value tv = token_fifo[0];
1495 token_fifo.erase (token_fifo.begin ());
1496 yylval = tv.value;
1497 /* There's no need to fall through to handle package.name
1498 as that can never happen here. In theory. */
1499 return tv.token;
1500 }
1501 popping = 0;
1502
1503 current.token = lex_one_token (pstate);
1504
1505 /* TODO: Need a way to force specifying name1 as a package.
1506 .name1.name2 ? */
1507
1508 if (current.token != NAME)
1509 return current.token;
1510
1511 /* See if we have "name1 . name2". */
1512
1513 current.value = yylval;
1514 next.token = lex_one_token (pstate);
1515 next.value = yylval;
1516
1517 if (next.token == '.')
1518 {
1519 token_and_value name2;
1520
1521 name2.token = lex_one_token (pstate);
1522 name2.value = yylval;
1523
1524 if (name2.token == NAME)
1525 {
1526 /* Ok, we have "name1 . name2". */
1527 std::string copy = copy_name (current.value.sval);
1528
1529 if (copy == "unsafe")
1530 {
1531 popping = 1;
1532 return classify_unsafe_function (name2.value.sval);
1533 }
1534
1535 if (package_name_p (copy.c_str (), pstate->expression_context_block))
1536 {
1537 popping = 1;
1538 yylval.sval = build_packaged_name (current.value.sval.ptr,
1539 current.value.sval.length,
1540 name2.value.sval.ptr,
1541 name2.value.sval.length);
1542 return classify_packaged_name (pstate->expression_context_block);
1543 }
1544 }
1545
1546 token_fifo.push_back (next);
1547 token_fifo.push_back (name2);
1548 }
1549 else
1550 token_fifo.push_back (next);
1551
1552 /* If we arrive here we don't have a package-qualified name. */
1553
1554 popping = 1;
1555 yylval = current.value;
1556 return classify_name (pstate, pstate->expression_context_block);
1557 }
1558
1559 /* See language.h. */
1560
1561 int
1562 go_language::parser (struct parser_state *par_state) const
1563 {
1564 /* Setting up the parser state. */
1565 scoped_restore pstate_restore = make_scoped_restore (&pstate);
1566 gdb_assert (par_state != NULL);
1567 pstate = par_state;
1568
1569 scoped_restore restore_yydebug = make_scoped_restore (&yydebug,
1570 parser_debug);
1571
1572 /* Initialize some state used by the lexer. */
1573 last_was_structop = 0;
1574 saw_name_at_eof = 0;
1575 paren_depth = 0;
1576
1577 token_fifo.clear ();
1578 popping = 0;
1579 name_obstack.clear ();
1580
1581 int result = yyparse ();
1582 if (!result)
1583 pstate->set_operation (pstate->pop ());
1584 return result;
1585 }
1586
1587 static void
1588 yyerror (const char *msg)
1589 {
1590 if (pstate->prev_lexptr)
1591 pstate->lexptr = pstate->prev_lexptr;
1592
1593 error (_("A %s in expression, near `%s'."), msg, pstate->lexptr);
1594 }