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