mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-08 03:30:22 +00:00
d4ff15af96
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16326 91177308-0d34-0410-b5e6-96231b3b80d8
195 lines
6.2 KiB
C++
195 lines
6.2 KiB
C++
/*===- ConfigLexer.l - Scanner for CompilerDriver Config Files -*- C++ -*--===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file was developed by Reid Spencer and is distributed under the
|
|
// University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file implements the flex scanner for configuration files for the
|
|
// llvmc CompilerDriver.
|
|
//
|
|
//===----------------------------------------------------------------------===*/
|
|
|
|
|
|
%option prefix="Config"
|
|
%option nostdinit
|
|
%option never-interactive
|
|
%option batch
|
|
%option noyywrap
|
|
%option nodefault
|
|
%option 8bit
|
|
%option outfile="ConfigLexer.cpp"
|
|
%option ecs
|
|
%option noyymore
|
|
%option noreject
|
|
%pointer
|
|
|
|
%{
|
|
|
|
#include "ConfigLexer.h"
|
|
|
|
#define YY_INPUT(buf,result,max_size) \
|
|
{ \
|
|
assert(ConfigLexerInput != 0 && "Oops"); \
|
|
result = ConfigLexerInput->read(buf,max_size); \
|
|
if (result == 0 ) result = YY_NULL; \
|
|
}
|
|
|
|
#define YY_FATAL_ERROR(msg) \
|
|
{ \
|
|
assert(ConfigLexerInput != 0 && "Oops"); \
|
|
ConfigLexerInput->error(msg); \
|
|
}
|
|
|
|
#define YY_DECL ConfigLexerTokens llvm::Configlex()
|
|
|
|
#define yyterminate() { return EOFTOK; }
|
|
|
|
using namespace llvm;
|
|
|
|
inline llvm::ConfigLexerTokens
|
|
handleNameContext(llvm::ConfigLexerTokens token) {
|
|
ConfigLexerState.StringVal = yytext;
|
|
if (ConfigLexerState.in_value)
|
|
return OPTION;
|
|
return token;
|
|
}
|
|
|
|
inline llvm::ConfigLexerTokens
|
|
handleSubstitution(llvm::ConfigLexerTokens token) {
|
|
if (ConfigLexerState.in_value) {
|
|
ConfigLexerState.StringVal = yytext;
|
|
return token;
|
|
}
|
|
YY_FATAL_ERROR("Substitition tokens not allowed in names" );
|
|
return ERRORTOK;
|
|
};
|
|
|
|
inline llvm::ConfigLexerTokens handleValueContext(llvm::ConfigLexerTokens token) {
|
|
ConfigLexerState.StringVal = yytext;
|
|
if (ConfigLexerState.in_value)
|
|
return token;
|
|
return OPTION;
|
|
}
|
|
|
|
%}
|
|
|
|
ASSEMBLER assembler|Assembler|ASSEMBLER
|
|
COMMAND command|Command|COMMAND
|
|
LANG lang|Lang|LANG
|
|
LINKER linker|Linker|LINKER
|
|
NAME name|Name|NAME
|
|
OPT1 opt1|Opt1|OPT1
|
|
OPT2 opt2|Opt2|OPT2
|
|
OPT3 opt3|Opt3|OPT3
|
|
OPT4 opt4|Opt4|OPT4
|
|
OPT5 opt5|Opt5|OPT5
|
|
OPTIMIZER optimizer|Optimizer|OPTIMIZER
|
|
OUTPUT output|Output|OUTPUT
|
|
PREPROCESSES preprocesses|PreProcesses|PREPROCESSES
|
|
PREPROCESSOR preprocessor|PreProcessor|PREPROCESSOR
|
|
REQUIRED required|Required|REQUIRED
|
|
TRANSLATES translates|Translates|TRANSLATES
|
|
TRANSLATOR translator|Translator|TRANSLATOR
|
|
VERSION version|Version|VERSION
|
|
|
|
True true|True|TRUE|on|On|ON|yes|Yes|YES
|
|
False false|False|FALSE|off|Off|OFF|no|No|NO
|
|
Bytecode bc|BC|bytecode|Bytecode|BYTECODE
|
|
Assembly asm|ASM|assembly|Assembly|ASSEMBLY
|
|
|
|
BadSubst \%[^iots][a-zA-Z]\%
|
|
Comment \#[^\r\n]*\r?\n
|
|
NewLine \r?\n
|
|
Eq \=
|
|
EscNewLine \\\r?\n
|
|
Option [-A-Za-z0-9_:%+/\\|,][-A-Za-z0-9_:+/\\|,@]*
|
|
Sep \.
|
|
String \"[^\"]*\"
|
|
White [ \t]*
|
|
|
|
|
|
%%
|
|
|
|
{White} { /* Ignore whitespace */ }
|
|
|
|
{Comment} { /* Ignore comments */
|
|
ConfigLexerState.in_value = false;
|
|
ConfigLexerState.lineNum++;
|
|
return EOLTOK;
|
|
}
|
|
|
|
{EscNewLine} { ConfigLexerState.lineNum++;
|
|
/* Don't return EOLTOK! */
|
|
}
|
|
|
|
{NewLine} { ConfigLexerState.in_value = false;
|
|
ConfigLexerState.lineNum++;
|
|
return EOLTOK;
|
|
}
|
|
|
|
{Eq} { ConfigLexerState.in_value = true;
|
|
return EQUALS;
|
|
}
|
|
|
|
{VERSION} { return handleNameContext(VERSION); }
|
|
|
|
{LANG} { return handleNameContext(LANG); }
|
|
{NAME} { return handleNameContext(NAME); }
|
|
{OPT1} { return handleNameContext(OPT1); }
|
|
{OPT2} { return handleNameContext(OPT2); }
|
|
{OPT3} { return handleNameContext(OPT3); }
|
|
{OPT4} { return handleNameContext(OPT4); }
|
|
{OPT5} { return handleNameContext(OPT5); }
|
|
|
|
{PREPROCESSOR} { return handleNameContext(PREPROCESSOR); }
|
|
{COMMAND} { return handleNameContext(COMMAND); }
|
|
{REQUIRED} { return handleNameContext(REQUIRED); }
|
|
|
|
{TRANSLATOR} { return handleNameContext(TRANSLATOR); }
|
|
{PREPROCESSES} { return handleNameContext(PREPROCESSES); }
|
|
{OUTPUT} { return handleNameContext(OUTPUT); }
|
|
|
|
{OPTIMIZER} { return handleNameContext(OPTIMIZER); }
|
|
{TRANSLATES} { return handleNameContext(TRANSLATES); }
|
|
|
|
{ASSEMBLER} { return handleNameContext(ASSEMBLER); }
|
|
|
|
{LINKER} { return handleNameContext(LINKER); }
|
|
|
|
%args% { return handleSubstitution(ARGS_SUBST); }
|
|
%defs% { return handleSubstitution(DEFS_SUBST); }
|
|
%force% { return handleSubstitution(FORCE_SUBST); }
|
|
%in% { return handleSubstitution(IN_SUBST); }
|
|
%incls% { return handleSubstitution(INCLS_SUBST); }
|
|
%libs% { return handleSubstitution(LIBS_SUBST); }
|
|
%opt% { return handleSubstitution(OPT_SUBST); }
|
|
%out% { return handleSubstitution(OUT_SUBST); }
|
|
%stats% { return handleSubstitution(STATS_SUBST); }
|
|
%target% { return handleSubstitution(TARGET_SUBST); }
|
|
%time% { return handleSubstitution(TIME_SUBST); }
|
|
%verbose% { return handleSubstitution(VERBOSE_SUBST); }
|
|
%fOpts% { return handleSubstitution(FOPTS_SUBST); }
|
|
%MOpts% { return handleSubstitution(MOPTS_SUBST); }
|
|
%WOpts% { return handleSubstitution(WOPTS_SUBST); }
|
|
{BadSubst} { YY_FATAL_ERROR("Invalid substitution token"); }
|
|
|
|
{Assembly} { return handleValueContext(ASSEMBLY); }
|
|
{Bytecode} { return handleValueContext(BYTECODE); }
|
|
{True} { return handleValueContext(TRUETOK); }
|
|
{False} { return handleValueContext(FALSETOK); }
|
|
|
|
{Option} { ConfigLexerState.StringVal = yytext; return OPTION; }
|
|
{String} { ConfigLexerState.StringVal = yytext+1; // Nuke start quote
|
|
ConfigLexerState.StringVal.erase(
|
|
--ConfigLexerState.StringVal.end());
|
|
return STRING;
|
|
}
|
|
{Sep} { if (ConfigLexerState.in_value) { ConfigLexerState.StringVal = yytext;
|
|
return OPTION; } }
|
|
|
|
|
|
%%
|