Fetch the NT_ARM_TLS register set for native FreeBSD/arm processes.
[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 || !sym->is_argument ()
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 ULONGEST n = 0;
651 ULONGEST prevn = 0;
652 ULONGEST un;
653
654 int i = 0;
655 int c;
656 int base = input_radix;
657 int unsigned_p = 0;
658
659 /* Number of "L" suffixes encountered. */
660 int long_p = 0;
661
662 /* We have found a "L" or "U" suffix. */
663 int found_suffix = 0;
664
665 ULONGEST high_bit;
666 struct type *signed_type;
667 struct type *unsigned_type;
668
669 if (parsed_float)
670 {
671 const struct builtin_go_type *builtin_go_types
672 = builtin_go_type (par_state->gdbarch ());
673
674 /* Handle suffixes: 'f' for float32, 'l' for long double.
675 FIXME: This appears to be an extension -- do we want this? */
676 if (len >= 1 && tolower (p[len - 1]) == 'f')
677 {
678 putithere->typed_val_float.type
679 = builtin_go_types->builtin_float32;
680 len--;
681 }
682 else if (len >= 1 && tolower (p[len - 1]) == 'l')
683 {
684 putithere->typed_val_float.type
685 = parse_type (par_state)->builtin_long_double;
686 len--;
687 }
688 /* Default type for floating-point literals is float64. */
689 else
690 {
691 putithere->typed_val_float.type
692 = builtin_go_types->builtin_float64;
693 }
694
695 if (!parse_float (p, len,
696 putithere->typed_val_float.type,
697 putithere->typed_val_float.val))
698 return ERROR;
699 return FLOAT;
700 }
701
702 /* Handle base-switching prefixes 0x, 0t, 0d, 0. */
703 if (p[0] == '0' && len > 1)
704 switch (p[1])
705 {
706 case 'x':
707 case 'X':
708 if (len >= 3)
709 {
710 p += 2;
711 base = 16;
712 len -= 2;
713 }
714 break;
715
716 case 'b':
717 case 'B':
718 if (len >= 3)
719 {
720 p += 2;
721 base = 2;
722 len -= 2;
723 }
724 break;
725
726 case 't':
727 case 'T':
728 case 'd':
729 case 'D':
730 if (len >= 3)
731 {
732 p += 2;
733 base = 10;
734 len -= 2;
735 }
736 break;
737
738 default:
739 base = 8;
740 break;
741 }
742
743 while (len-- > 0)
744 {
745 c = *p++;
746 if (c >= 'A' && c <= 'Z')
747 c += 'a' - 'A';
748 if (c != 'l' && c != 'u')
749 n *= base;
750 if (c >= '0' && c <= '9')
751 {
752 if (found_suffix)
753 return ERROR;
754 n += i = c - '0';
755 }
756 else
757 {
758 if (base > 10 && c >= 'a' && c <= 'f')
759 {
760 if (found_suffix)
761 return ERROR;
762 n += i = c - 'a' + 10;
763 }
764 else if (c == 'l')
765 {
766 ++long_p;
767 found_suffix = 1;
768 }
769 else if (c == 'u')
770 {
771 unsigned_p = 1;
772 found_suffix = 1;
773 }
774 else
775 return ERROR; /* Char not a digit */
776 }
777 if (i >= base)
778 return ERROR; /* Invalid digit in this base. */
779
780 /* Portably test for overflow (only works for nonzero values, so make
781 a second check for zero). FIXME: Can't we just make n and prevn
782 unsigned and avoid this? */
783 if (c != 'l' && c != 'u' && (prevn >= n) && n != 0)
784 unsigned_p = 1; /* Try something unsigned. */
785
786 /* Portably test for unsigned overflow.
787 FIXME: This check is wrong; for example it doesn't find overflow
788 on 0x123456789 when LONGEST is 32 bits. */
789 if (c != 'l' && c != 'u' && n != 0)
790 {
791 if ((unsigned_p && prevn >= n))
792 error (_("Numeric constant too large."));
793 }
794 prevn = n;
795 }
796
797 /* An integer constant is an int, a long, or a long long. An L
798 suffix forces it to be long; an LL suffix forces it to be long
799 long. If not forced to a larger size, it gets the first type of
800 the above that it fits in. To figure out whether it fits, we
801 shift it right and see whether anything remains. Note that we
802 can't shift sizeof (LONGEST) * HOST_CHAR_BIT bits or more in one
803 operation, because many compilers will warn about such a shift
804 (which always produces a zero result). Sometimes gdbarch_int_bit
805 or gdbarch_long_bit will be that big, sometimes not. To deal with
806 the case where it is we just always shift the value more than
807 once, with fewer bits each time. */
808
809 un = n >> 2;
810 if (long_p == 0
811 && (un >> (gdbarch_int_bit (par_state->gdbarch ()) - 2)) == 0)
812 {
813 high_bit
814 = ((ULONGEST)1) << (gdbarch_int_bit (par_state->gdbarch ()) - 1);
815
816 /* A large decimal (not hex or octal) constant (between INT_MAX
817 and UINT_MAX) is a long or unsigned long, according to ANSI,
818 never an unsigned int, but this code treats it as unsigned
819 int. This probably should be fixed. GCC gives a warning on
820 such constants. */
821
822 unsigned_type = parse_type (par_state)->builtin_unsigned_int;
823 signed_type = parse_type (par_state)->builtin_int;
824 }
825 else if (long_p <= 1
826 && (un >> (gdbarch_long_bit (par_state->gdbarch ()) - 2)) == 0)
827 {
828 high_bit
829 = ((ULONGEST)1) << (gdbarch_long_bit (par_state->gdbarch ()) - 1);
830 unsigned_type = parse_type (par_state)->builtin_unsigned_long;
831 signed_type = parse_type (par_state)->builtin_long;
832 }
833 else
834 {
835 int shift;
836 if (sizeof (ULONGEST) * HOST_CHAR_BIT
837 < gdbarch_long_long_bit (par_state->gdbarch ()))
838 /* A long long does not fit in a LONGEST. */
839 shift = (sizeof (ULONGEST) * HOST_CHAR_BIT - 1);
840 else
841 shift = (gdbarch_long_long_bit (par_state->gdbarch ()) - 1);
842 high_bit = (ULONGEST) 1 << shift;
843 unsigned_type = parse_type (par_state)->builtin_unsigned_long_long;
844 signed_type = parse_type (par_state)->builtin_long_long;
845 }
846
847 putithere->typed_val_int.val = n;
848
849 /* If the high bit of the worked out type is set then this number
850 has to be unsigned. */
851
852 if (unsigned_p || (n & high_bit))
853 {
854 putithere->typed_val_int.type = unsigned_type;
855 }
856 else
857 {
858 putithere->typed_val_int.type = signed_type;
859 }
860
861 return INT;
862 }
863
864 /* Temporary obstack used for holding strings. */
865 static struct obstack tempbuf;
866 static int tempbuf_init;
867
868 /* Parse a string or character literal from TOKPTR. The string or
869 character may be wide or unicode. *OUTPTR is set to just after the
870 end of the literal in the input string. The resulting token is
871 stored in VALUE. This returns a token value, either STRING or
872 CHAR, depending on what was parsed. *HOST_CHARS is set to the
873 number of host characters in the literal. */
874
875 static int
876 parse_string_or_char (const char *tokptr, const char **outptr,
877 struct typed_stoken *value, int *host_chars)
878 {
879 int quote;
880
881 /* Build the gdb internal form of the input string in tempbuf. Note
882 that the buffer is null byte terminated *only* for the
883 convenience of debugging gdb itself and printing the buffer
884 contents when the buffer contains no embedded nulls. Gdb does
885 not depend upon the buffer being null byte terminated, it uses
886 the length string instead. This allows gdb to handle C strings
887 (as well as strings in other languages) with embedded null
888 bytes */
889
890 if (!tempbuf_init)
891 tempbuf_init = 1;
892 else
893 obstack_free (&tempbuf, NULL);
894 obstack_init (&tempbuf);
895
896 /* Skip the quote. */
897 quote = *tokptr;
898 ++tokptr;
899
900 *host_chars = 0;
901
902 while (*tokptr)
903 {
904 char c = *tokptr;
905 if (c == '\\')
906 {
907 ++tokptr;
908 *host_chars += c_parse_escape (&tokptr, &tempbuf);
909 }
910 else if (c == quote)
911 break;
912 else
913 {
914 obstack_1grow (&tempbuf, c);
915 ++tokptr;
916 /* FIXME: this does the wrong thing with multi-byte host
917 characters. We could use mbrlen here, but that would
918 make "set host-charset" a bit less useful. */
919 ++*host_chars;
920 }
921 }
922
923 if (*tokptr != quote)
924 {
925 if (quote == '"')
926 error (_("Unterminated string in expression."));
927 else
928 error (_("Unmatched single quote."));
929 }
930 ++tokptr;
931
932 value->type = (int) C_STRING | (quote == '\'' ? C_CHAR : 0); /*FIXME*/
933 value->ptr = (char *) obstack_base (&tempbuf);
934 value->length = obstack_object_size (&tempbuf);
935
936 *outptr = tokptr;
937
938 return quote == '\'' ? CHAR : STRING;
939 }
940
941 struct token
942 {
943 const char *oper;
944 int token;
945 enum exp_opcode opcode;
946 };
947
948 static const struct token tokentab3[] =
949 {
950 {">>=", ASSIGN_MODIFY, BINOP_RSH},
951 {"<<=", ASSIGN_MODIFY, BINOP_LSH},
952 /*{"&^=", ASSIGN_MODIFY, BINOP_BITWISE_ANDNOT}, TODO */
953 {"...", DOTDOTDOT, OP_NULL},
954 };
955
956 static const struct token tokentab2[] =
957 {
958 {"+=", ASSIGN_MODIFY, BINOP_ADD},
959 {"-=", ASSIGN_MODIFY, BINOP_SUB},
960 {"*=", ASSIGN_MODIFY, BINOP_MUL},
961 {"/=", ASSIGN_MODIFY, BINOP_DIV},
962 {"%=", ASSIGN_MODIFY, BINOP_REM},
963 {"|=", ASSIGN_MODIFY, BINOP_BITWISE_IOR},
964 {"&=", ASSIGN_MODIFY, BINOP_BITWISE_AND},
965 {"^=", ASSIGN_MODIFY, BINOP_BITWISE_XOR},
966 {"++", INCREMENT, OP_NULL},
967 {"--", DECREMENT, OP_NULL},
968 /*{"->", RIGHT_ARROW, OP_NULL}, Doesn't exist in Go. */
969 {"<-", LEFT_ARROW, OP_NULL},
970 {"&&", ANDAND, OP_NULL},
971 {"||", OROR, OP_NULL},
972 {"<<", LSH, OP_NULL},
973 {">>", RSH, OP_NULL},
974 {"==", EQUAL, OP_NULL},
975 {"!=", NOTEQUAL, OP_NULL},
976 {"<=", LEQ, OP_NULL},
977 {">=", GEQ, OP_NULL},
978 /*{"&^", ANDNOT, OP_NULL}, TODO */
979 };
980
981 /* Identifier-like tokens. */
982 static const struct token ident_tokens[] =
983 {
984 {"true", TRUE_KEYWORD, OP_NULL},
985 {"false", FALSE_KEYWORD, OP_NULL},
986 {"nil", NIL_KEYWORD, OP_NULL},
987 {"const", CONST_KEYWORD, OP_NULL},
988 {"struct", STRUCT_KEYWORD, OP_NULL},
989 {"type", TYPE_KEYWORD, OP_NULL},
990 {"interface", INTERFACE_KEYWORD, OP_NULL},
991 {"chan", CHAN_KEYWORD, OP_NULL},
992 {"byte", BYTE_KEYWORD, OP_NULL}, /* An alias of uint8. */
993 {"len", LEN_KEYWORD, OP_NULL},
994 {"cap", CAP_KEYWORD, OP_NULL},
995 {"new", NEW_KEYWORD, OP_NULL},
996 {"iota", IOTA_KEYWORD, OP_NULL},
997 };
998
999 /* This is set if a NAME token appeared at the very end of the input
1000 string, with no whitespace separating the name from the EOF. This
1001 is used only when parsing to do field name completion. */
1002 static int saw_name_at_eof;
1003
1004 /* This is set if the previously-returned token was a structure
1005 operator -- either '.' or ARROW. This is used only when parsing to
1006 do field name completion. */
1007 static int last_was_structop;
1008
1009 /* Depth of parentheses. */
1010 static int paren_depth;
1011
1012 /* Read one token, getting characters through lexptr. */
1013
1014 static int
1015 lex_one_token (struct parser_state *par_state)
1016 {
1017 int c;
1018 int namelen;
1019 const char *tokstart;
1020 int saw_structop = last_was_structop;
1021
1022 last_was_structop = 0;
1023
1024 retry:
1025
1026 par_state->prev_lexptr = par_state->lexptr;
1027
1028 tokstart = par_state->lexptr;
1029 /* See if it is a special token of length 3. */
1030 for (const auto &token : tokentab3)
1031 if (strncmp (tokstart, token.oper, 3) == 0)
1032 {
1033 par_state->lexptr += 3;
1034 yylval.opcode = token.opcode;
1035 return token.token;
1036 }
1037
1038 /* See if it is a special token of length 2. */
1039 for (const auto &token : tokentab2)
1040 if (strncmp (tokstart, token.oper, 2) == 0)
1041 {
1042 par_state->lexptr += 2;
1043 yylval.opcode = token.opcode;
1044 /* NOTE: -> doesn't exist in Go, so we don't need to watch for
1045 setting last_was_structop here. */
1046 return token.token;
1047 }
1048
1049 switch (c = *tokstart)
1050 {
1051 case 0:
1052 if (saw_name_at_eof)
1053 {
1054 saw_name_at_eof = 0;
1055 return COMPLETE;
1056 }
1057 else if (saw_structop)
1058 return COMPLETE;
1059 else
1060 return 0;
1061
1062 case ' ':
1063 case '\t':
1064 case '\n':
1065 par_state->lexptr++;
1066 goto retry;
1067
1068 case '[':
1069 case '(':
1070 paren_depth++;
1071 par_state->lexptr++;
1072 return c;
1073
1074 case ']':
1075 case ')':
1076 if (paren_depth == 0)
1077 return 0;
1078 paren_depth--;
1079 par_state->lexptr++;
1080 return c;
1081
1082 case ',':
1083 if (pstate->comma_terminates
1084 && paren_depth == 0)
1085 return 0;
1086 par_state->lexptr++;
1087 return c;
1088
1089 case '.':
1090 /* Might be a floating point number. */
1091 if (par_state->lexptr[1] < '0' || par_state->lexptr[1] > '9')
1092 {
1093 if (pstate->parse_completion)
1094 last_was_structop = 1;
1095 goto symbol; /* Nope, must be a symbol. */
1096 }
1097 /* FALL THRU. */
1098
1099 case '0':
1100 case '1':
1101 case '2':
1102 case '3':
1103 case '4':
1104 case '5':
1105 case '6':
1106 case '7':
1107 case '8':
1108 case '9':
1109 {
1110 /* It's a number. */
1111 int got_dot = 0, got_e = 0, toktype;
1112 const char *p = tokstart;
1113 int hex = input_radix > 10;
1114
1115 if (c == '0' && (p[1] == 'x' || p[1] == 'X'))
1116 {
1117 p += 2;
1118 hex = 1;
1119 }
1120
1121 for (;; ++p)
1122 {
1123 /* This test includes !hex because 'e' is a valid hex digit
1124 and thus does not indicate a floating point number when
1125 the radix is hex. */
1126 if (!hex && !got_e && (*p == 'e' || *p == 'E'))
1127 got_dot = got_e = 1;
1128 /* This test does not include !hex, because a '.' always indicates
1129 a decimal floating point number regardless of the radix. */
1130 else if (!got_dot && *p == '.')
1131 got_dot = 1;
1132 else if (got_e && (p[-1] == 'e' || p[-1] == 'E')
1133 && (*p == '-' || *p == '+'))
1134 /* This is the sign of the exponent, not the end of the
1135 number. */
1136 continue;
1137 /* We will take any letters or digits. parse_number will
1138 complain if past the radix, or if L or U are not final. */
1139 else if ((*p < '0' || *p > '9')
1140 && ((*p < 'a' || *p > 'z')
1141 && (*p < 'A' || *p > 'Z')))
1142 break;
1143 }
1144 toktype = parse_number (par_state, tokstart, p - tokstart,
1145 got_dot|got_e, &yylval);
1146 if (toktype == ERROR)
1147 {
1148 char *err_copy = (char *) alloca (p - tokstart + 1);
1149
1150 memcpy (err_copy, tokstart, p - tokstart);
1151 err_copy[p - tokstart] = 0;
1152 error (_("Invalid number \"%s\"."), err_copy);
1153 }
1154 par_state->lexptr = p;
1155 return toktype;
1156 }
1157
1158 case '@':
1159 {
1160 const char *p = &tokstart[1];
1161 size_t len = strlen ("entry");
1162
1163 while (isspace (*p))
1164 p++;
1165 if (strncmp (p, "entry", len) == 0 && !isalnum (p[len])
1166 && p[len] != '_')
1167 {
1168 par_state->lexptr = &p[len];
1169 return ENTRY;
1170 }
1171 }
1172 /* FALLTHRU */
1173 case '+':
1174 case '-':
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 symbol:
1191 par_state->lexptr++;
1192 return c;
1193
1194 case '\'':
1195 case '"':
1196 case '`':
1197 {
1198 int host_len;
1199 int result = parse_string_or_char (tokstart, &par_state->lexptr,
1200 &yylval.tsval, &host_len);
1201 if (result == CHAR)
1202 {
1203 if (host_len == 0)
1204 error (_("Empty character constant."));
1205 else if (host_len > 2 && c == '\'')
1206 {
1207 ++tokstart;
1208 namelen = par_state->lexptr - tokstart - 1;
1209 goto tryname;
1210 }
1211 else if (host_len > 1)
1212 error (_("Invalid character constant."));
1213 }
1214 return result;
1215 }
1216 }
1217
1218 if (!(c == '_' || c == '$'
1219 || (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')))
1220 /* We must have come across a bad character (e.g. ';'). */
1221 error (_("Invalid character '%c' in expression."), c);
1222
1223 /* It's a name. See how long it is. */
1224 namelen = 0;
1225 for (c = tokstart[namelen];
1226 (c == '_' || c == '$' || (c >= '0' && c <= '9')
1227 || (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'));)
1228 {
1229 c = tokstart[++namelen];
1230 }
1231
1232 /* The token "if" terminates the expression and is NOT removed from
1233 the input stream. It doesn't count if it appears in the
1234 expansion of a macro. */
1235 if (namelen == 2
1236 && tokstart[0] == 'i'
1237 && tokstart[1] == 'f')
1238 {
1239 return 0;
1240 }
1241
1242 /* For the same reason (breakpoint conditions), "thread N"
1243 terminates the expression. "thread" could be an identifier, but
1244 an identifier is never followed by a number without intervening
1245 punctuation.
1246 Handle abbreviations of these, similarly to
1247 breakpoint.c:find_condition_and_thread.
1248 TODO: Watch for "goroutine" here? */
1249 if (namelen >= 1
1250 && strncmp (tokstart, "thread", namelen) == 0
1251 && (tokstart[namelen] == ' ' || tokstart[namelen] == '\t'))
1252 {
1253 const char *p = tokstart + namelen + 1;
1254
1255 while (*p == ' ' || *p == '\t')
1256 p++;
1257 if (*p >= '0' && *p <= '9')
1258 return 0;
1259 }
1260
1261 par_state->lexptr += namelen;
1262
1263 tryname:
1264
1265 yylval.sval.ptr = tokstart;
1266 yylval.sval.length = namelen;
1267
1268 /* Catch specific keywords. */
1269 std::string copy = copy_name (yylval.sval);
1270 for (const auto &token : ident_tokens)
1271 if (copy == token.oper)
1272 {
1273 /* It is ok to always set this, even though we don't always
1274 strictly need to. */
1275 yylval.opcode = token.opcode;
1276 return token.token;
1277 }
1278
1279 if (*tokstart == '$')
1280 return DOLLAR_VARIABLE;
1281
1282 if (pstate->parse_completion && *par_state->lexptr == '\0')
1283 saw_name_at_eof = 1;
1284 return NAME;
1285 }
1286
1287 /* An object of this type is pushed on a FIFO by the "outer" lexer. */
1288 struct token_and_value
1289 {
1290 int token;
1291 YYSTYPE value;
1292 };
1293
1294 /* A FIFO of tokens that have been read but not yet returned to the
1295 parser. */
1296 static std::vector<token_and_value> token_fifo;
1297
1298 /* Non-zero if the lexer should return tokens from the FIFO. */
1299 static int popping;
1300
1301 /* Temporary storage for yylex; this holds symbol names as they are
1302 built up. */
1303 static auto_obstack name_obstack;
1304
1305 /* Build "package.name" in name_obstack.
1306 For convenience of the caller, the name is NUL-terminated,
1307 but the NUL is not included in the recorded length. */
1308
1309 static struct stoken
1310 build_packaged_name (const char *package, int package_len,
1311 const char *name, int name_len)
1312 {
1313 struct stoken result;
1314
1315 name_obstack.clear ();
1316 obstack_grow (&name_obstack, package, package_len);
1317 obstack_grow_str (&name_obstack, ".");
1318 obstack_grow (&name_obstack, name, name_len);
1319 obstack_grow (&name_obstack, "", 1);
1320 result.ptr = (char *) obstack_base (&name_obstack);
1321 result.length = obstack_object_size (&name_obstack) - 1;
1322
1323 return result;
1324 }
1325
1326 /* Return non-zero if NAME is a package name.
1327 BLOCK is the scope in which to interpret NAME; this can be NULL
1328 to mean the global scope. */
1329
1330 static int
1331 package_name_p (const char *name, const struct block *block)
1332 {
1333 struct symbol *sym;
1334 struct field_of_this_result is_a_field_of_this;
1335
1336 sym = lookup_symbol (name, block, STRUCT_DOMAIN, &is_a_field_of_this).symbol;
1337
1338 if (sym
1339 && sym->aclass () == LOC_TYPEDEF
1340 && sym->type ()->code () == TYPE_CODE_MODULE)
1341 return 1;
1342
1343 return 0;
1344 }
1345
1346 /* Classify a (potential) function in the "unsafe" package.
1347 We fold these into "keywords" to keep things simple, at least until
1348 something more complex is warranted. */
1349
1350 static int
1351 classify_unsafe_function (struct stoken function_name)
1352 {
1353 std::string copy = copy_name (function_name);
1354
1355 if (copy == "Sizeof")
1356 {
1357 yylval.sval = function_name;
1358 return SIZEOF_KEYWORD;
1359 }
1360
1361 error (_("Unknown function in `unsafe' package: %s"), copy.c_str ());
1362 }
1363
1364 /* Classify token(s) "name1.name2" where name1 is known to be a package.
1365 The contents of the token are in `yylval'.
1366 Updates yylval and returns the new token type.
1367
1368 The result is one of NAME, NAME_OR_INT, or TYPENAME. */
1369
1370 static int
1371 classify_packaged_name (const struct block *block)
1372 {
1373 struct block_symbol sym;
1374 struct field_of_this_result is_a_field_of_this;
1375
1376 std::string copy = copy_name (yylval.sval);
1377
1378 sym = lookup_symbol (copy.c_str (), block, VAR_DOMAIN, &is_a_field_of_this);
1379
1380 if (sym.symbol)
1381 {
1382 yylval.ssym.sym = sym;
1383 yylval.ssym.is_a_field_of_this = is_a_field_of_this.type != NULL;
1384 }
1385
1386 return NAME;
1387 }
1388
1389 /* Classify a NAME token.
1390 The contents of the token are in `yylval'.
1391 Updates yylval and returns the new token type.
1392 BLOCK is the block in which lookups start; this can be NULL
1393 to mean the global scope.
1394
1395 The result is one of NAME, NAME_OR_INT, or TYPENAME. */
1396
1397 static int
1398 classify_name (struct parser_state *par_state, const struct block *block)
1399 {
1400 struct type *type;
1401 struct block_symbol sym;
1402 struct field_of_this_result is_a_field_of_this;
1403
1404 std::string copy = copy_name (yylval.sval);
1405
1406 /* Try primitive types first so they win over bad/weird debug info. */
1407 type = language_lookup_primitive_type (par_state->language (),
1408 par_state->gdbarch (),
1409 copy.c_str ());
1410 if (type != NULL)
1411 {
1412 /* NOTE: We take advantage of the fact that yylval coming in was a
1413 NAME, and that struct ttype is a compatible extension of struct
1414 stoken, so yylval.tsym.stoken is already filled in. */
1415 yylval.tsym.type = type;
1416 return TYPENAME;
1417 }
1418
1419 /* TODO: What about other types? */
1420
1421 sym = lookup_symbol (copy.c_str (), block, VAR_DOMAIN, &is_a_field_of_this);
1422
1423 if (sym.symbol)
1424 {
1425 yylval.ssym.sym = sym;
1426 yylval.ssym.is_a_field_of_this = is_a_field_of_this.type != NULL;
1427 return NAME;
1428 }
1429
1430 /* If we didn't find a symbol, look again in the current package.
1431 This is to, e.g., make "p global_var" work without having to specify
1432 the package name. We intentionally only looks for objects in the
1433 current package. */
1434
1435 {
1436 char *current_package_name = go_block_package_name (block);
1437
1438 if (current_package_name != NULL)
1439 {
1440 struct stoken sval =
1441 build_packaged_name (current_package_name,
1442 strlen (current_package_name),
1443 copy.c_str (), copy.size ());
1444
1445 xfree (current_package_name);
1446 sym = lookup_symbol (sval.ptr, block, VAR_DOMAIN,
1447 &is_a_field_of_this);
1448 if (sym.symbol)
1449 {
1450 yylval.ssym.stoken = sval;
1451 yylval.ssym.sym = sym;
1452 yylval.ssym.is_a_field_of_this = is_a_field_of_this.type != NULL;
1453 return NAME;
1454 }
1455 }
1456 }
1457
1458 /* Input names that aren't symbols but ARE valid hex numbers, when
1459 the input radix permits them, can be names or numbers depending
1460 on the parse. Note we support radixes > 16 here. */
1461 if ((copy[0] >= 'a' && copy[0] < 'a' + input_radix - 10)
1462 || (copy[0] >= 'A' && copy[0] < 'A' + input_radix - 10))
1463 {
1464 YYSTYPE newlval; /* Its value is ignored. */
1465 int hextype = parse_number (par_state, copy.c_str (),
1466 yylval.sval.length, 0, &newlval);
1467 if (hextype == INT)
1468 {
1469 yylval.ssym.sym.symbol = NULL;
1470 yylval.ssym.sym.block = NULL;
1471 yylval.ssym.is_a_field_of_this = 0;
1472 return NAME_OR_INT;
1473 }
1474 }
1475
1476 yylval.ssym.sym.symbol = NULL;
1477 yylval.ssym.sym.block = NULL;
1478 yylval.ssym.is_a_field_of_this = 0;
1479 return NAME;
1480 }
1481
1482 /* This is taken from c-exp.y mostly to get something working.
1483 The basic structure has been kept because we may yet need some of it. */
1484
1485 static int
1486 yylex (void)
1487 {
1488 token_and_value current, next;
1489
1490 if (popping && !token_fifo.empty ())
1491 {
1492 token_and_value tv = token_fifo[0];
1493 token_fifo.erase (token_fifo.begin ());
1494 yylval = tv.value;
1495 /* There's no need to fall through to handle package.name
1496 as that can never happen here. In theory. */
1497 return tv.token;
1498 }
1499 popping = 0;
1500
1501 current.token = lex_one_token (pstate);
1502
1503 /* TODO: Need a way to force specifying name1 as a package.
1504 .name1.name2 ? */
1505
1506 if (current.token != NAME)
1507 return current.token;
1508
1509 /* See if we have "name1 . name2". */
1510
1511 current.value = yylval;
1512 next.token = lex_one_token (pstate);
1513 next.value = yylval;
1514
1515 if (next.token == '.')
1516 {
1517 token_and_value name2;
1518
1519 name2.token = lex_one_token (pstate);
1520 name2.value = yylval;
1521
1522 if (name2.token == NAME)
1523 {
1524 /* Ok, we have "name1 . name2". */
1525 std::string copy = copy_name (current.value.sval);
1526
1527 if (copy == "unsafe")
1528 {
1529 popping = 1;
1530 return classify_unsafe_function (name2.value.sval);
1531 }
1532
1533 if (package_name_p (copy.c_str (), pstate->expression_context_block))
1534 {
1535 popping = 1;
1536 yylval.sval = build_packaged_name (current.value.sval.ptr,
1537 current.value.sval.length,
1538 name2.value.sval.ptr,
1539 name2.value.sval.length);
1540 return classify_packaged_name (pstate->expression_context_block);
1541 }
1542 }
1543
1544 token_fifo.push_back (next);
1545 token_fifo.push_back (name2);
1546 }
1547 else
1548 token_fifo.push_back (next);
1549
1550 /* If we arrive here we don't have a package-qualified name. */
1551
1552 popping = 1;
1553 yylval = current.value;
1554 return classify_name (pstate, pstate->expression_context_block);
1555 }
1556
1557 /* See language.h. */
1558
1559 int
1560 go_language::parser (struct parser_state *par_state) const
1561 {
1562 /* Setting up the parser state. */
1563 scoped_restore pstate_restore = make_scoped_restore (&pstate);
1564 gdb_assert (par_state != NULL);
1565 pstate = par_state;
1566
1567 scoped_restore restore_yydebug = make_scoped_restore (&yydebug,
1568 parser_debug);
1569
1570 /* Initialize some state used by the lexer. */
1571 last_was_structop = 0;
1572 saw_name_at_eof = 0;
1573 paren_depth = 0;
1574
1575 token_fifo.clear ();
1576 popping = 0;
1577 name_obstack.clear ();
1578
1579 int result = yyparse ();
1580 if (!result)
1581 pstate->set_operation (pstate->pop ());
1582 return result;
1583 }
1584
1585 static void
1586 yyerror (const char *msg)
1587 {
1588 if (pstate->prev_lexptr)
1589 pstate->lexptr = pstate->prev_lexptr;
1590
1591 error (_("A %s in expression, near `%s'."), msg, pstate->lexptr);
1592 }