mirror of https://github.com/Icinga/icinga2.git
parent
d72bd4fec2
commit
8ef8316ca6
|
@ -57,11 +57,21 @@ do { \
|
||||||
%x HEREDOC
|
%x HEREDOC
|
||||||
|
|
||||||
%%
|
%%
|
||||||
\" { yyextra->m_LexBuffer.str(""); yyextra->m_LexBuffer.clear(); BEGIN(STRING); }
|
\" {
|
||||||
|
yyextra->m_LexBuffer.str("");
|
||||||
|
yyextra->m_LexBuffer.clear();
|
||||||
|
|
||||||
|
yyextra->m_LocationBegin = *yylloc;
|
||||||
|
|
||||||
|
BEGIN(STRING);
|
||||||
|
}
|
||||||
|
|
||||||
<STRING>\" {
|
<STRING>\" {
|
||||||
BEGIN(INITIAL);
|
BEGIN(INITIAL);
|
||||||
|
|
||||||
|
yylloc->FirstLine = yyextra->m_LocationBegin.FirstLine;
|
||||||
|
yylloc->FirstColumn = yyextra->m_LocationBegin.FirstColumn;
|
||||||
|
|
||||||
std::string str = yyextra->m_LexBuffer.str();
|
std::string str = yyextra->m_LexBuffer.str();
|
||||||
yylval->text = strdup(str.c_str());
|
yylval->text = strdup(str.c_str());
|
||||||
|
|
||||||
|
@ -69,7 +79,7 @@ do { \
|
||||||
}
|
}
|
||||||
|
|
||||||
<STRING>\n {
|
<STRING>\n {
|
||||||
BOOST_THROW_EXCEPTION(ScriptError("Unterminated string literal", *yylloc));
|
BOOST_THROW_EXCEPTION(ScriptError("Unterminated string literal", DebugInfoRange(yyextra->m_LocationBegin, *yylloc)));
|
||||||
}
|
}
|
||||||
|
|
||||||
<STRING>\\[0-7]{1,3} {
|
<STRING>\\[0-7]{1,3} {
|
||||||
|
@ -80,7 +90,7 @@ do { \
|
||||||
|
|
||||||
if (result > 0xff) {
|
if (result > 0xff) {
|
||||||
/* error, constant is out-of-bounds */
|
/* error, constant is out-of-bounds */
|
||||||
BOOST_THROW_EXCEPTION(ScriptError("Constant is out of bounds: " + String(yytext), *yylloc));
|
BOOST_THROW_EXCEPTION(ScriptError("Constant is out of bounds: " + String(yytext), DebugInfoRange(yyextra->m_LocationBegin, *yylloc)));
|
||||||
}
|
}
|
||||||
|
|
||||||
yyextra->m_LexBuffer << static_cast<char>(result);
|
yyextra->m_LexBuffer << static_cast<char>(result);
|
||||||
|
@ -90,7 +100,7 @@ do { \
|
||||||
/* generate error - bad escape sequence; something
|
/* generate error - bad escape sequence; something
|
||||||
* like '\48' or '\0777777'
|
* like '\48' or '\0777777'
|
||||||
*/
|
*/
|
||||||
BOOST_THROW_EXCEPTION(ScriptError("Bad escape sequence found: " + String(yytext), *yylloc));
|
BOOST_THROW_EXCEPTION(ScriptError("Bad escape sequence found: " + String(yytext), DebugInfoRange(yyextra->m_LocationBegin, *yylloc)));
|
||||||
}
|
}
|
||||||
|
|
||||||
<STRING>\\n { yyextra->m_LexBuffer << "\n"; }
|
<STRING>\\n { yyextra->m_LexBuffer << "\n"; }
|
||||||
|
@ -107,13 +117,25 @@ do { \
|
||||||
yyextra->m_LexBuffer << *yptr++;
|
yyextra->m_LexBuffer << *yptr++;
|
||||||
}
|
}
|
||||||
|
|
||||||
<STRING><<EOF>> { BOOST_THROW_EXCEPTION(ScriptError("End-of-file while in string literal", *yylloc)); }
|
<STRING><<EOF>> {
|
||||||
|
BOOST_THROW_EXCEPTION(ScriptError("End-of-file while in string literal", DebugInfoRange(yyextra->m_LocationBegin, *yylloc)));
|
||||||
|
}
|
||||||
|
|
||||||
\{\{\{ { yyextra->m_LexBuffer.str(""); yyextra->m_LexBuffer.clear(); BEGIN(HEREDOC); }
|
\{\{\{ {
|
||||||
|
yyextra->m_LexBuffer.str("");
|
||||||
|
yyextra->m_LexBuffer.clear();
|
||||||
|
|
||||||
|
yyextra->m_LocationBegin = *yylloc;
|
||||||
|
|
||||||
|
BEGIN(HEREDOC);
|
||||||
|
}
|
||||||
|
|
||||||
<HEREDOC>\}\}\} {
|
<HEREDOC>\}\}\} {
|
||||||
BEGIN(INITIAL);
|
BEGIN(INITIAL);
|
||||||
|
|
||||||
|
yylloc->FirstLine = yyextra->m_LocationBegin.FirstLine;
|
||||||
|
yylloc->FirstColumn = yyextra->m_LocationBegin.FirstColumn;
|
||||||
|
|
||||||
std::string str = yyextra->m_LexBuffer.str();
|
std::string str = yyextra->m_LexBuffer.str();
|
||||||
yylval->text = strdup(str.c_str());
|
yylval->text = strdup(str.c_str());
|
||||||
|
|
||||||
|
|
|
@ -215,7 +215,7 @@ static void MakeRBinaryOp(Expression** result, Expression *left, Expression *rig
|
||||||
%left T_SHIFT_LEFT T_SHIFT_RIGHT
|
%left T_SHIFT_LEFT T_SHIFT_RIGHT
|
||||||
%left T_PLUS T_MINUS
|
%left T_PLUS T_MINUS
|
||||||
%left T_MULTIPLY T_DIVIDE_OP
|
%left T_MULTIPLY T_DIVIDE_OP
|
||||||
%left UNARY_MINUS
|
%left UNARY_MINUS UNARY_PLUS
|
||||||
%right '!' '~'
|
%right '!' '~'
|
||||||
%left '.' '(' '['
|
%left '.' '(' '['
|
||||||
%left T_VAR T_THIS
|
%left T_VAR T_THIS
|
||||||
|
@ -756,6 +756,10 @@ rterm: T_STRING
|
||||||
{
|
{
|
||||||
$$ = new NegateExpression($2, DebugInfoRange(@1, @2));
|
$$ = new NegateExpression($2, DebugInfoRange(@1, @2));
|
||||||
}
|
}
|
||||||
|
| T_PLUS rterm %prec UNARY_PLUS
|
||||||
|
{
|
||||||
|
$$ = $2;
|
||||||
|
}
|
||||||
| T_MINUS rterm %prec UNARY_MINUS
|
| T_MINUS rterm %prec UNARY_MINUS
|
||||||
{
|
{
|
||||||
$$ = new SubtractExpression(MakeLiteral(0), $2, DebugInfoRange(@1, @2));
|
$$ = new SubtractExpression(MakeLiteral(0), $2, DebugInfoRange(@1, @2));
|
||||||
|
|
|
@ -115,6 +115,7 @@ public:
|
||||||
|
|
||||||
int m_IgnoreNewlines;
|
int m_IgnoreNewlines;
|
||||||
std::ostringstream m_LexBuffer;
|
std::ostringstream m_LexBuffer;
|
||||||
|
CompilerDebugInfo m_LocationBegin;
|
||||||
|
|
||||||
std::stack<TypeRuleList::Ptr> m_RuleLists;
|
std::stack<TypeRuleList::Ptr> m_RuleLists;
|
||||||
ConfigType::Ptr m_Type;
|
ConfigType::Ptr m_Type;
|
||||||
|
@ -127,8 +128,6 @@ public:
|
||||||
std::stack<String> m_FKVar;
|
std::stack<String> m_FKVar;
|
||||||
std::stack<String> m_FVVar;
|
std::stack<String> m_FVVar;
|
||||||
std::stack<Expression *> m_FTerm;
|
std::stack<Expression *> m_FTerm;
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class I2_CONFIG_API ConfigFragmentRegistry : public Registry<ConfigFragmentRegistry, String>
|
class I2_CONFIG_API ConfigFragmentRegistry : public Registry<ConfigFragmentRegistry, String>
|
||||||
|
|
Loading…
Reference in New Issue