2015-02-26 09:02:31 -06:00
|
|
|
%option prefix="ADEF_"
|
|
|
|
%option reentrant
|
|
|
|
%option bison-bridge
|
|
|
|
%option bison-locations
|
|
|
|
%option yylineno
|
|
|
|
%option noyywrap
|
|
|
|
|
|
|
|
%{
|
|
|
|
/*
|
|
|
|
* This is a debug macro which is used to echo every character parsed by the
|
|
|
|
* lex.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <ctype.h>
|
2015-06-01 10:28:29 -05:00
|
|
|
#include "trick/mm_error.h"
|
|
|
|
#include "trick/ADefParseContext.hh"
|
2019-11-19 09:01:16 -06:00
|
|
|
#include "adef_parser.tab.hpp"
|
2015-02-26 09:02:31 -06:00
|
|
|
|
2018-08-16 16:02:11 -05:00
|
|
|
#pragma GCC diagnostic ignored "-Wunused-parameter"
|
|
|
|
#pragma GCC diagnostic ignored "-Wsign-compare"
|
|
|
|
#pragma GCC diagnostic ignored "-Wunused-function"
|
|
|
|
|
2015-02-26 09:02:31 -06:00
|
|
|
#define YY_EXTRA_TYPE Trick::ADefParseContext*
|
|
|
|
|
|
|
|
#define YY_USER_ACTION yylloc->first_line = yylineno;
|
|
|
|
|
|
|
|
#define YY_INPUT(buf, result, maxsize) \
|
|
|
|
{ \
|
|
|
|
char c; \
|
|
|
|
(*yyextra->is) >> std::noskipws >> c; \
|
|
|
|
if (yyextra->is->eof()) { \
|
|
|
|
result = YY_NULL; \
|
|
|
|
} else { \
|
|
|
|
buf[0] = c; \
|
|
|
|
result = 1; \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
|
|
|
/*===== END OF INITIAL C SOURCE CODE SECTION =====*/
|
|
|
|
|
|
|
|
/*=== LEXICAL SPECIFICATIONS ===*/
|
|
|
|
|
|
|
|
%}
|
|
|
|
W [ \t]
|
|
|
|
D [0-9]
|
|
|
|
OCT "0"[0-7]+
|
|
|
|
HEX "0"[Xx][0-9a-fA-F]+
|
|
|
|
NAM [_a-zA-Z][_a-zA-Z0-9:]*
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
yy_flex_debug = 0;
|
|
|
|
Trick::ADefParseContext* context = yyextra ;
|
|
|
|
|
|
|
|
"*" |
|
|
|
|
"[" |
|
|
|
|
"]" { return( (int)yytext[0] ); }
|
|
|
|
|
|
|
|
"char" {
|
|
|
|
yylval->ival = TRICK_CHARACTER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"std::string" {
|
|
|
|
yylval->ival = TRICK_STRING ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"wchar" {
|
|
|
|
yylval->ival = TRICK_WCHAR ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"signed char" {
|
|
|
|
yylval->ival = TRICK_CHARACTER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"int8_t" {
|
|
|
|
yylval->ival = TRICK_CHARACTER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"unsigned char" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_CHARACTER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"uint8_t" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_CHARACTER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"short" {
|
|
|
|
yylval->ival = TRICK_SHORT ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"signed short" {
|
|
|
|
yylval->ival = TRICK_SHORT ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"int16_t" {
|
|
|
|
yylval->ival = TRICK_SHORT ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"unsigned short" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_SHORT ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"uint16_t" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_SHORT ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"int" {
|
|
|
|
yylval->ival = TRICK_INTEGER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"signed int" {
|
|
|
|
yylval->ival = TRICK_INTEGER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"int32_t" {
|
|
|
|
yylval->ival = TRICK_INTEGER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"unsigned int" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_INTEGER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"uint32_t" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_INTEGER ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"int64_t" {
|
|
|
|
yylval->ival = TRICK_INT64 ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"uint64_t" {
|
|
|
|
yylval->ival = TRICK_UINT64 ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"long" {
|
|
|
|
yylval->ival = TRICK_LONG ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"signed long" {
|
|
|
|
yylval->ival = TRICK_LONG ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"unsigned long" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_LONG ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"long long" {
|
|
|
|
yylval->ival = TRICK_LONG_LONG ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"signed long long" {
|
|
|
|
yylval->ival = TRICK_LONG_LONG ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"unsigned long long" {
|
|
|
|
yylval->ival = TRICK_UNSIGNED_LONG_LONG ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"float" {
|
|
|
|
yylval->ival = TRICK_FLOAT ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"double" {
|
|
|
|
yylval->ival = TRICK_DOUBLE ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"bool" {
|
|
|
|
yylval->ival = TRICK_BOOLEAN ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
"wchar_t" {
|
|
|
|
yylval->ival = TRICK_WCHAR ;
|
|
|
|
return( TYPE ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
{NAM} {
|
|
|
|
/*
|
|
|
|
* This rule handles general parameter and label names.
|
|
|
|
* save the name in a YACC variable and return the token to YACC.
|
|
|
|
*/
|
|
|
|
yylval->sval = strdup( yytext ) ;
|
|
|
|
return( NAME ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
{HEX} {
|
|
|
|
int i ;
|
|
|
|
/*
|
|
|
|
* This rule handles integers in hexidecimal format.
|
|
|
|
* convert the string to an integer value, save the value in
|
|
|
|
* the YACC variable and return the YACC token.
|
|
|
|
* The first two characters of yytext are the "0x" characters
|
|
|
|
* which signify a hex number.
|
|
|
|
*/
|
|
|
|
sscanf( &(yytext[2]) , "%x" , &i ) ;
|
|
|
|
yylval->ival = i ;
|
|
|
|
|
|
|
|
return( I_CON ) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
{D}+ {
|
|
|
|
/*
|
|
|
|
* This rule handles integers in decimal format.
|
|
|
|
* convert the string to an integer value, save the value in
|
|
|
|
* the YACC variable and return the YACC token.
|
|
|
|
* Decimals can overflow for unsigned long longs so test to
|
|
|
|
* see if we are over that and covert to unsigned if it's
|
|
|
|
* greater that that huge number
|
|
|
|
*/
|
|
|
|
yylval->ival = atoi(yytext);
|
|
|
|
return( I_CON );
|
|
|
|
}
|
|
|
|
|
|
|
|
<<EOF>> {
|
|
|
|
yy_delete_buffer( YY_CURRENT_BUFFER, yyscanner ) ;
|
|
|
|
return( 0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
{W} {}
|
|
|
|
|
|
|
|
|
|
|
|
. {
|
|
|
|
/*
|
|
|
|
* This rule matches all other characters not matched by a previous
|
|
|
|
* rule. All lex synatx error messages are handled by the rule.
|
|
|
|
* Starting at the unrecognized character, all remaining characters
|
|
|
|
* to the end of the current line or the end of the file are read
|
|
|
|
* and stored in a buffer which is then used as part of the syntax
|
|
|
|
* error message. I->token is an input processor parameter designed
|
|
|
|
* specifically for use with error messages.
|
|
|
|
*/
|
|
|
|
context->error_str = yytext ;
|
|
|
|
|
|
|
|
return(MM_SYNTAX_ERROR) ;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
void Trick::ADefParseContext::init_scanner() {
|
|
|
|
|
|
|
|
// Allocate the scanner structure.
|
|
|
|
yylex_init( &scanner);
|
|
|
|
|
|
|
|
// Set the file where output messages are to go.
|
2017-03-30 16:14:28 -05:00
|
|
|
yyset_out( stdout, scanner);
|
2015-02-26 09:02:31 -06:00
|
|
|
|
|
|
|
yyset_extra( this, scanner);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void Trick::ADefParseContext::destroy_scanner() {
|
|
|
|
|
|
|
|
yylex_destroy(scanner);
|
|
|
|
|
|
|
|
}
|
|
|
|
|