2004-08-14 17:37:15 +08:00
|
|
|
/*===- 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
|
2004-08-19 12:49:47 +08:00
|
|
|
%option noreject
|
|
|
|
%pointer
|
2004-08-14 17:37:15 +08:00
|
|
|
|
|
|
|
%{
|
|
|
|
|
|
|
|
#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; \
|
|
|
|
}
|
|
|
|
|
2004-08-19 12:49:47 +08:00
|
|
|
#define YY_FATAL_ERROR(msg) \
|
|
|
|
{ \
|
|
|
|
assert(ConfigLexerInput != 0 && "Oops"); \
|
|
|
|
ConfigLexerInput->error(msg); \
|
|
|
|
}
|
|
|
|
|
2004-08-15 16:19:46 +08:00
|
|
|
#define YY_DECL ConfigLexerTokens llvm::Configlex()
|
|
|
|
|
|
|
|
#define yyterminate() { return EOFTOK; }
|
|
|
|
|
2004-08-14 17:37:15 +08:00
|
|
|
using namespace llvm;
|
|
|
|
|
2004-08-19 12:49:47 +08:00
|
|
|
inline llvm::ConfigLexerTokens
|
|
|
|
handleContext(const char* tokenText, llvm::ConfigLexerTokens token) {
|
|
|
|
if (ConfigLexerState.in_value) {
|
|
|
|
ConfigLexerState.StringVal = tokenText;
|
|
|
|
return OPTION;
|
2004-08-14 17:37:15 +08:00
|
|
|
}
|
2004-08-19 12:49:47 +08:00
|
|
|
return token;
|
2004-08-14 17:37:15 +08:00
|
|
|
}
|
|
|
|
|
2004-08-19 12:49:47 +08:00
|
|
|
inline llvm::ConfigLexerTokens
|
|
|
|
handleSubstitution(llvm::ConfigLexerTokens token) {
|
|
|
|
if (ConfigLexerState.in_value)
|
|
|
|
return token;
|
|
|
|
YY_FATAL_ERROR("Substitition tokens not allowed in names" );
|
|
|
|
return ERRORTOK;
|
|
|
|
};
|
|
|
|
|
|
|
|
inline llvm::ConfigLexerTokens handleBoolean(llvm::ConfigLexerTokens token) {
|
|
|
|
if (ConfigLexerState.in_value)
|
|
|
|
return token;
|
|
|
|
YY_FATAL_ERROR("Boolean values not allowed in names");
|
|
|
|
return ERRORTOK;
|
|
|
|
}
|
2004-08-14 17:37:15 +08:00
|
|
|
|
|
|
|
%}
|
|
|
|
|
|
|
|
ASSEMBLER assembler|Assembler|ASSEMBLER
|
2004-08-19 12:49:47 +08:00
|
|
|
BadSubst \@[^iots][a-zA-Z]\@
|
2004-08-14 17:37:15 +08:00
|
|
|
COMMAND command|Command|COMMAND
|
2004-08-19 12:49:47 +08:00
|
|
|
Comment \#[^\n]*\n
|
|
|
|
NewLine \n
|
|
|
|
Eq \=
|
|
|
|
EscNewLine \\\n
|
2004-08-14 17:37:15 +08:00
|
|
|
GROKS_DASH_O groks_dash_O|Groks_Dash_O|GROKS_DASH_O
|
2004-08-19 12:49:47 +08:00
|
|
|
LANG lang|Lang|LANG
|
|
|
|
LINKER linker|Linker|LINKER
|
|
|
|
NAME name|Name|NAME
|
2004-08-15 16:19:46 +08:00
|
|
|
OPT1 opt1|Opt1|OPT1
|
|
|
|
OPT2 opt2|Opt2|OPT2
|
|
|
|
OPT3 opt3|Opt3|OPT3
|
|
|
|
OPT4 opt4|Opt4|OPT4
|
|
|
|
OPT5 opt5|Opt5|OPT5
|
2004-08-19 12:49:47 +08:00
|
|
|
OPTIMIZER optimizer|Optimizer|OPTIMIZER
|
|
|
|
OPTIMIZES optimizes|Optimizes|OPTIMIZES
|
|
|
|
Option [-A-Za-z0-9_:%+/\\|,][-A-Za-z0-9_:%+/\\|,@]*
|
|
|
|
OUTPUT_IS_ASM output_is_asm|Output_Is_Asm|OUTPUT_IS_ASM
|
|
|
|
PREPROCESSES preprocesses|PreProcesses|PREPROCESSES
|
|
|
|
PREPROCESSOR preprocessor|PreProcessor|PREPROCESSOR
|
|
|
|
REQUIRED required|Required|REQUIRED
|
2004-08-14 17:37:15 +08:00
|
|
|
Sep \.
|
|
|
|
String \"[^\"]*\"
|
2004-08-19 12:49:47 +08:00
|
|
|
TRANSLATES translates|Translates|TRANSLATES
|
|
|
|
TRANSLATOR translator|Translator|TRANSLATOR
|
|
|
|
White [ \t]*
|
|
|
|
|
2004-08-14 17:37:15 +08:00
|
|
|
True true|True|TRUE
|
|
|
|
False false|False|FALSE
|
|
|
|
On on|On|ON
|
|
|
|
Off off|Off|OFF
|
|
|
|
Yes yes|Yes|YES
|
|
|
|
No no|No|NO
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
{White} { /* Ignore whitespace */ }
|
|
|
|
|
2004-08-19 12:49:47 +08:00
|
|
|
{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;
|
|
|
|
}
|
|
|
|
|
|
|
|
{LANG} { return handleContext("lang",LANG); }
|
|
|
|
{PREPROCESSOR} { return handleContext("preprocessor",PREPROCESSOR); }
|
|
|
|
{TRANSLATOR} { return handleContext("translator",TRANSLATOR); }
|
|
|
|
{OPTIMIZER} { return handleContext("optimizer",OPTIMIZER); }
|
|
|
|
{ASSEMBLER} { return handleContext("assembler",ASSEMBLER); }
|
|
|
|
{LINKER} { return handleContext("linker",LINKER); }
|
|
|
|
{NAME} { return handleContext("name",NAME); }
|
|
|
|
{REQUIRED} { return handleContext("required",REQUIRED); }
|
|
|
|
{COMMAND} { return handleContext("command",COMMAND); }
|
|
|
|
{PREPROCESSES} { return handleContext("preprocesses",PREPROCESSES); }
|
|
|
|
{TRANSLATES} { return handleContext("translates",TRANSLATES); }
|
|
|
|
{OPTIMIZES} { return handleContext("optimizes",OPTIMIZES); }
|
|
|
|
{GROKS_DASH_O} { return handleContext("groks_dash_O",GROKS_DASH_O); }
|
|
|
|
{OUTPUT_IS_ASM} { return handleContext("output_ias_asm",OUTPUT_IS_ASM); }
|
|
|
|
{OPT1} { return handleContext("opt1",OPT1); }
|
|
|
|
{OPT2} { return handleContext("opt2",OPT2); }
|
|
|
|
{OPT3} { return handleContext("opt3",OPT3); }
|
|
|
|
{OPT4} { return handleContext("opt4",OPT4); }
|
|
|
|
{OPT5} { return handleContext("opt5",OPT5); }
|
|
|
|
|
|
|
|
@in@ { return handleSubstitution(IN_SUBST); }
|
|
|
|
@out@ { return handleSubstitution(OUT_SUBST); }
|
|
|
|
@time@ { return handleSubstitution(TIME_SUBST); }
|
|
|
|
@stats@ { return handleSubstitution(STATS_SUBST); }
|
|
|
|
@opt@ { return handleSubstitution(OPT_SUBST); }
|
|
|
|
@target@ { return handleSubstitution(TARGET_SUBST); }
|
|
|
|
{BadSubst} { YY_FATAL_ERROR("Invalid substitution token"); }
|
|
|
|
{True} { return handleBoolean(TRUETOK); }
|
|
|
|
{On} { return handleBoolean(TRUETOK); }
|
|
|
|
{Yes} { return handleBoolean(TRUETOK); }
|
|
|
|
{False} { return handleBoolean(FALSETOK); }
|
|
|
|
{Off} { return handleBoolean(FALSETOK); }
|
|
|
|
{No} { return handleBoolean(FALSETOK); }
|
|
|
|
|
|
|
|
{Option} { ConfigLexerState.StringVal = yytext; return OPTION; }
|
|
|
|
{String} { ConfigLexerState.StringVal = yytext+1; // Nuke start quote
|
|
|
|
ConfigLexerState.StringVal.erase(
|
|
|
|
--ConfigLexerState.StringVal.end());
|
2004-08-14 17:37:15 +08:00
|
|
|
return STRING;
|
|
|
|
}
|
2004-08-19 12:49:47 +08:00
|
|
|
{Sep} { if (ConfigLexerState.in_value) { ConfigLexerState.StringVal = yytext;
|
2004-08-15 16:19:46 +08:00
|
|
|
return OPTION; } }
|
|
|
|
|
2004-08-14 17:37:15 +08:00
|
|
|
|
|
|
|
%%
|