diff options
author | Haru <haru@dotalux.com> | 2013-10-10 23:56:05 +0200 |
---|---|---|
committer | Haru <haru@dotalux.com> | 2013-11-03 20:45:36 +0100 |
commit | 3b0cd11f980a48b903262c857fde1cd9c784c2e0 (patch) | |
tree | 2882d9e0958b57544e3135f928e4df2328958d0a | |
parent | 6728c0fa88b84fccb6f179ae13cf8a15c1ea23a4 (diff) | |
download | hercules-3b0cd11f980a48b903262c857fde1cd9c784c2e0.tar.gz hercules-3b0cd11f980a48b903262c857fde1cd9c784c2e0.tar.bz2 hercules-3b0cd11f980a48b903262c857fde1cd9c784c2e0.tar.xz hercules-3b0cd11f980a48b903262c857fde1cd9c784c2e0.zip |
Added support for <? ?> blocks (parsed as multiline strings) in libconfig
- If this doesn't make any sense right now, fear not. It'll make sense
in an upcoming update.
- Special thanks to Yommy, Ind.
Signed-off-by: Haru <haru@dotalux.com>
-rw-r--r-- | 3rdparty/libconfig/extra/gen/scanner.l | 10 | ||||
-rw-r--r-- | 3rdparty/libconfig/scanner.c | 376 | ||||
-rw-r--r-- | 3rdparty/libconfig/scanner.h | 5 |
3 files changed, 215 insertions, 176 deletions
diff --git a/3rdparty/libconfig/extra/gen/scanner.l b/3rdparty/libconfig/extra/gen/scanner.l index bdc57a8d4..a7befd11d 100644 --- a/3rdparty/libconfig/extra/gen/scanner.l +++ b/3rdparty/libconfig/extra/gen/scanner.l @@ -100,7 +100,7 @@ float ([-+]?([0-9]*)?\.[0-9]*([eE][-+]?[0-9]+)?)|([-+]?([0-9]+)(\.[0 comment (#|\/\/).*$ include_open ^[ \t]*@include[ \t]+\" -%x COMMENT STRING INCLUDE +%x COMMENT STRING INCLUDE SCRIPTBLOCK %% @@ -129,6 +129,14 @@ include_open ^[ \t]*@include[ \t]+\" return(TOK_STRING); } +\<\? { BEGIN SCRIPTBLOCK; } +<SCRIPTBLOCK>([^\?]|\?[^\>])+ { scanctx_append_string(yyextra, yytext); } +<SCRIPTBLOCK>\?\> { + yylval->sval = scanctx_take_string(yyextra); + BEGIN INITIAL; + return(TOK_STRING); + } + {include_open} { BEGIN INCLUDE; } <INCLUDE>[^\"\\]+ { scanctx_append_string(yyextra, yytext); } <INCLUDE>\\\\ { scanctx_append_string(yyextra, "\\"); } diff --git a/3rdparty/libconfig/scanner.c b/3rdparty/libconfig/scanner.c index 55e029f9f..171cef89d 100644 --- a/3rdparty/libconfig/scanner.c +++ b/3rdparty/libconfig/scanner.c @@ -365,8 +365,8 @@ static void yy_fatal_error (yyconst char msg[] ,yyscan_t yyscanner ); *yy_cp = '\0'; \ yyg->yy_c_buf_p = yy_cp; -#define YY_NUM_RULES 42 -#define YY_END_OF_BUFFER 43 +#define YY_NUM_RULES 45 +#define YY_END_OF_BUFFER 46 /* This struct is not used in this scanner, but its presence is necessary. */ struct yy_trans_info @@ -374,20 +374,21 @@ struct yy_trans_info flex_int32_t yy_verify; flex_int32_t yy_nxt; }; -static yyconst flex_int16_t yy_accept[103] = +static yyconst flex_int16_t yy_accept[112] = { 0, - 0, 0, 0, 0, 0, 0, 0, 0, 43, 41, - 22, 21, 21, 5, 41, 37, 38, 29, 41, 24, - 30, 41, 31, 31, 23, 39, 29, 29, 35, 36, - 25, 26, 22, 41, 3, 4, 3, 6, 15, 14, - 17, 20, 42, 22, 0, 40, 29, 30, 31, 30, - 0, 1, 0, 30, 0, 32, 0, 29, 29, 22, - 0, 0, 2, 6, 12, 0, 11, 10, 7, 8, - 9, 17, 19, 18, 0, 30, 30, 0, 0, 30, - 32, 33, 29, 29, 0, 0, 0, 30, 34, 29, - 27, 0, 13, 34, 28, 0, 0, 0, 0, 0, - - 16, 0 + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 46, 44, 25, 24, 24, 5, 44, 40, 41, 32, + 44, 27, 33, 44, 34, 34, 26, 42, 44, 32, + 32, 38, 39, 28, 29, 25, 44, 3, 4, 3, + 6, 15, 14, 20, 23, 45, 17, 45, 25, 0, + 43, 32, 33, 34, 33, 0, 1, 0, 33, 0, + 35, 0, 16, 32, 32, 25, 0, 0, 2, 6, + 12, 0, 11, 10, 7, 8, 9, 20, 22, 21, + 17, 0, 18, 0, 33, 33, 0, 0, 33, 35, + 36, 32, 32, 0, 0, 0, 33, 37, 32, 30, + + 0, 13, 37, 31, 0, 0, 0, 0, 0, 19, + 0 } ; static yyconst flex_int32_t yy_ec[256] = @@ -397,15 +398,15 @@ static yyconst flex_int32_t yy_ec[256] = 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 1, 6, 7, 1, 1, 1, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 18, - 18, 18, 18, 18, 18, 18, 18, 19, 20, 1, - 21, 1, 1, 22, 23, 24, 24, 24, 25, 26, - 27, 27, 27, 27, 27, 28, 27, 27, 27, 27, - 27, 29, 30, 31, 32, 27, 27, 33, 27, 27, - 34, 35, 36, 1, 8, 1, 23, 24, 37, 38, - - 39, 40, 27, 27, 41, 27, 27, 42, 27, 43, - 27, 27, 27, 44, 30, 45, 46, 27, 27, 33, - 27, 27, 47, 1, 48, 1, 1, 1, 1, 1, + 18, 18, 18, 18, 18, 18, 18, 19, 20, 21, + 22, 23, 24, 25, 26, 27, 27, 27, 28, 29, + 30, 30, 30, 30, 30, 31, 30, 30, 30, 30, + 30, 32, 33, 34, 35, 30, 30, 36, 30, 30, + 37, 38, 39, 1, 8, 1, 26, 27, 40, 41, + + 42, 43, 30, 30, 44, 30, 30, 45, 30, 46, + 30, 30, 30, 47, 33, 48, 49, 30, 30, 36, + 30, 30, 50, 1, 51, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, @@ -422,119 +423,126 @@ static yyconst flex_int32_t yy_ec[256] = 1, 1, 1, 1, 1 } ; -static yyconst flex_int32_t yy_meta[49] = +static yyconst flex_int32_t yy_meta[52] = { 0, 1, 1, 1, 1, 1, 2, 1, 3, 1, 1, 3, 1, 1, 3, 1, 1, 4, 4, 1, 1, - 1, 1, 4, 4, 4, 4, 3, 3, 3, 3, - 3, 3, 3, 1, 2, 1, 4, 4, 4, 4, - 3, 3, 3, 3, 3, 3, 1, 1 + 1, 1, 1, 1, 1, 4, 4, 4, 4, 3, + 3, 3, 3, 3, 3, 3, 1, 2, 1, 4, + 4, 4, 4, 3, 3, 3, 3, 3, 3, 1, + 1 } ; -static yyconst flex_int16_t yy_base[113] = +static yyconst flex_int16_t yy_base[124] = { 0, - 0, 47, 47, 48, 46, 47, 48, 49, 203, 204, - 200, 204, 204, 204, 198, 204, 204, 0, 45, 204, - 39, 50, 62, 71, 204, 204, 177, 41, 204, 204, - 204, 204, 69, 158, 204, 204, 182, 0, 204, 69, - 0, 204, 59, 195, 193, 204, 0, 80, 100, 104, - 118, 204, 192, 106, 130, 166, 0, 64, 61, 98, - 152, 149, 204, 0, 204, 0, 204, 204, 204, 204, - 204, 0, 204, 204, 50, 55, 116, 139, 109, 120, - 204, 161, 155, 115, 127, 0, 132, 141, 135, 121, - 0, 120, 204, 204, 0, 106, 78, 72, 106, 159, - - 204, 204, 165, 169, 173, 177, 179, 183, 187, 99, - 72, 70 + 0, 50, 50, 51, 49, 50, 51, 52, 197, 196, + 219, 222, 216, 222, 222, 222, 214, 222, 222, 0, + 48, 222, 42, 53, 63, 78, 222, 222, 192, 189, + 35, 222, 222, 222, 222, 72, 170, 222, 222, 197, + 0, 222, 65, 0, 222, 62, 182, 179, 175, 173, + 222, 0, 97, 101, 105, 123, 222, 172, 110, 132, + 143, 0, 222, 41, 72, 77, 128, 125, 222, 0, + 222, 0, 222, 222, 222, 222, 222, 0, 222, 222, + 146, 133, 222, 59, 113, 136, 143, 141, 145, 222, + 120, 112, 82, 102, 0, 148, 150, 105, 106, 0, + + 81, 222, 222, 0, 68, 63, 56, 90, 167, 222, + 222, 178, 182, 186, 190, 194, 196, 200, 204, 208, + 81, 79, 69 } ; -static yyconst flex_int16_t yy_def[113] = +static yyconst flex_int16_t yy_def[124] = { 0, - 102, 1, 103, 103, 104, 104, 105, 105, 102, 102, - 102, 102, 102, 102, 106, 102, 102, 107, 102, 102, - 102, 102, 102, 102, 102, 102, 107, 107, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 108, 102, 102, - 109, 102, 102, 102, 106, 102, 107, 102, 102, 102, - 102, 102, 106, 102, 102, 102, 110, 107, 107, 102, - 102, 102, 102, 108, 102, 111, 102, 102, 102, 102, - 102, 109, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 110, 107, 107, 102, 112, 102, 102, 102, 107, - 107, 102, 102, 102, 107, 102, 102, 102, 102, 102, - - 102, 0, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102 + 111, 1, 112, 112, 113, 113, 114, 114, 115, 115, + 111, 111, 111, 111, 111, 111, 116, 111, 111, 117, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 117, + 117, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 118, 111, 111, 119, 111, 111, 120, 120, 111, 116, + 111, 117, 111, 111, 111, 111, 111, 116, 111, 111, + 111, 121, 111, 117, 117, 111, 111, 111, 111, 118, + 111, 122, 111, 111, 111, 111, 111, 119, 111, 111, + 120, 120, 111, 111, 111, 111, 111, 111, 111, 111, + 121, 117, 117, 111, 123, 111, 111, 111, 117, 117, + + 111, 111, 111, 117, 111, 111, 111, 111, 111, 111, + 0, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111 } ; -static yyconst flex_int16_t yy_nxt[253] = +static yyconst flex_int16_t yy_nxt[274] = { 0, - 10, 11, 12, 13, 13, 14, 15, 10, 16, 17, - 18, 19, 20, 19, 21, 22, 23, 24, 25, 26, - 25, 10, 18, 18, 18, 27, 18, 18, 18, 18, - 28, 18, 18, 29, 10, 30, 18, 18, 18, 27, - 18, 18, 18, 18, 28, 18, 31, 32, 33, 36, - 36, 39, 39, 42, 42, 50, 50, 37, 37, 48, - 52, 49, 49, 51, 73, 53, 76, 76, 34, 59, - 60, 76, 76, 93, 65, 86, 54, 51, 49, 49, - 40, 40, 43, 43, 59, 54, 55, 49, 49, 56, - 61, 83, 84, 74, 57, 55, 50, 50, 56, 60, - - 55, 66, 82, 67, 51, 83, 84, 100, 68, 55, - 99, 69, 70, 71, 54, 98, 49, 49, 51, 61, - 50, 50, 77, 77, 55, 80, 80, 56, 51, 75, - 78, 75, 77, 77, 76, 76, 80, 80, 55, 91, - 78, 79, 51, 79, 78, 95, 80, 80, 88, 88, - 87, 97, 87, 91, 78, 88, 88, 88, 88, 95, - 100, 96, 94, 92, 101, 35, 35, 35, 35, 38, - 38, 38, 38, 41, 41, 41, 41, 45, 45, 45, - 45, 47, 47, 64, 90, 64, 64, 72, 89, 72, - 72, 85, 62, 81, 46, 46, 44, 63, 62, 58, - - 46, 44, 102, 9, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102 + 12, 13, 14, 15, 15, 16, 17, 12, 18, 19, + 20, 21, 22, 21, 23, 24, 25, 26, 27, 28, + 29, 27, 12, 12, 12, 20, 20, 20, 30, 20, + 20, 20, 20, 31, 20, 20, 32, 12, 33, 20, + 20, 20, 30, 20, 20, 20, 20, 31, 20, 34, + 35, 36, 39, 39, 42, 42, 45, 45, 55, 55, + 40, 40, 53, 57, 54, 54, 65, 79, 58, 56, + 71, 92, 102, 66, 37, 85, 85, 59, 66, 54, + 54, 65, 95, 56, 91, 92, 43, 43, 46, 46, + 60, 109, 59, 61, 54, 54, 67, 108, 62, 80, + + 72, 67, 73, 107, 60, 60, 93, 74, 61, 100, + 75, 76, 77, 55, 55, 59, 106, 54, 54, 60, + 93, 55, 55, 100, 56, 105, 86, 86, 60, 85, + 85, 61, 56, 104, 84, 103, 84, 87, 56, 85, + 85, 101, 60, 88, 99, 88, 56, 104, 89, 89, + 98, 87, 86, 86, 96, 111, 96, 89, 89, 97, + 97, 89, 89, 87, 97, 97, 97, 97, 109, 82, + 94, 68, 110, 90, 51, 51, 49, 87, 38, 38, + 38, 38, 41, 41, 41, 41, 44, 44, 44, 44, + 47, 47, 47, 47, 50, 50, 50, 50, 52, 52, + + 70, 83, 70, 70, 78, 82, 78, 78, 81, 81, + 81, 81, 69, 68, 64, 63, 51, 49, 111, 48, + 48, 11, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111 } ; -static yyconst flex_int16_t yy_chk[253] = +static yyconst flex_int16_t yy_chk[274] = { 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 2, 3, - 4, 5, 6, 7, 8, 21, 21, 3, 4, 19, - 22, 19, 19, 21, 43, 22, 75, 75, 2, 28, - 33, 76, 76, 112, 40, 111, 23, 21, 23, 23, - 5, 6, 7, 8, 28, 24, 23, 24, 24, 23, - 33, 58, 59, 43, 23, 24, 48, 48, 24, 60, - - 23, 40, 110, 40, 48, 58, 59, 99, 40, 24, - 98, 40, 40, 40, 49, 97, 49, 49, 48, 60, - 50, 50, 54, 54, 49, 79, 79, 49, 50, 51, - 54, 51, 77, 77, 51, 51, 80, 80, 49, 84, - 77, 55, 50, 55, 54, 90, 55, 55, 87, 87, - 78, 96, 78, 84, 77, 78, 78, 88, 88, 90, - 100, 92, 89, 85, 100, 103, 103, 103, 103, 104, - 104, 104, 104, 105, 105, 105, 105, 106, 106, 106, - 106, 107, 107, 108, 83, 108, 108, 109, 82, 109, - 109, 62, 61, 56, 53, 45, 44, 37, 34, 27, - - 15, 11, 9, 102, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102, 102, 102, 102, 102, 102, 102, 102, 102, - 102, 102 + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 2, 3, 4, 5, 6, 7, 8, 23, 23, + 3, 4, 21, 24, 21, 21, 31, 46, 24, 23, + 43, 64, 123, 36, 2, 84, 84, 25, 66, 25, + 25, 31, 122, 23, 121, 64, 5, 6, 7, 8, + 25, 108, 26, 25, 26, 26, 36, 107, 25, 46, + + 43, 66, 43, 106, 25, 26, 65, 43, 26, 93, + 43, 43, 43, 53, 53, 54, 105, 54, 54, 26, + 65, 55, 55, 93, 53, 101, 59, 59, 54, 85, + 85, 54, 55, 99, 56, 98, 56, 59, 53, 56, + 56, 94, 54, 60, 92, 60, 55, 99, 60, 60, + 91, 59, 86, 86, 87, 82, 87, 88, 88, 87, + 87, 89, 89, 86, 96, 96, 97, 97, 109, 81, + 68, 67, 109, 61, 58, 50, 49, 86, 112, 112, + 112, 112, 113, 113, 113, 113, 114, 114, 114, 114, + 115, 115, 115, 115, 116, 116, 116, 116, 117, 117, + + 118, 48, 118, 118, 119, 47, 119, 119, 120, 120, + 120, 120, 40, 37, 30, 29, 17, 13, 11, 10, + 9, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111, 111, 111, 111, 111, 111, 111, 111, + 111, 111, 111 } ; /* Table of booleans, true if rule could match eol. */ -static yyconst flex_int32_t yy_rule_can_match_eol[43] = +static yyconst flex_int32_t yy_rule_can_match_eol[46] = { 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, - 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, }; + 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, }; /* The intent behind this definition is that it'll catch * any uses of REJECT which flex missed. @@ -619,12 +627,13 @@ static unsigned long long fromhex(const char *s) } -#line 623 "scanner.c" +#line 631 "scanner.c" #define INITIAL 0 #define COMMENT 1 #define STRING 2 #define INCLUDE 3 +#define SCRIPTBLOCK 4 #define YY_EXTRA_TYPE struct scan_context * @@ -853,7 +862,7 @@ YY_DECL #line 105 "scanner.l" -#line 857 "scanner.c" +#line 866 "scanner.c" yylval = yylval_param; @@ -909,13 +918,13 @@ yy_match: while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) { yy_current_state = (int) yy_def[yy_current_state]; - if ( yy_current_state >= 103 ) + if ( yy_current_state >= 112 ) yy_c = yy_meta[(unsigned int) yy_c]; } yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; ++yy_cp; } - while ( yy_current_state != 102 ); + while ( yy_current_state != 111 ); yy_cp = yyg->yy_last_accepting_cpos; yy_current_state = yyg->yy_last_accepting_state; @@ -1035,7 +1044,7 @@ YY_RULE_SETUP case 16: YY_RULE_SETUP #line 132 "scanner.l" -{ BEGIN INCLUDE; } +{ BEGIN SCRIPTBLOCK; } YY_BREAK case 17: /* rule 17 can match eol */ @@ -1046,16 +1055,36 @@ YY_RULE_SETUP case 18: YY_RULE_SETUP #line 134 "scanner.l" -{ scanctx_append_string(yyextra, "\\"); } +{ + yylval->sval = scanctx_take_string(yyextra); + BEGIN INITIAL; + return(TOK_STRING); + } YY_BREAK case 19: YY_RULE_SETUP -#line 135 "scanner.l" -{ scanctx_append_string(yyextra, "\""); } +#line 140 "scanner.l" +{ BEGIN INCLUDE; } YY_BREAK case 20: +/* rule 20 can match eol */ +YY_RULE_SETUP +#line 141 "scanner.l" +{ scanctx_append_string(yyextra, yytext); } + YY_BREAK +case 21: YY_RULE_SETUP -#line 136 "scanner.l" +#line 142 "scanner.l" +{ scanctx_append_string(yyextra, "\\"); } + YY_BREAK +case 22: +YY_RULE_SETUP +#line 143 "scanner.l" +{ scanctx_append_string(yyextra, "\""); } + YY_BREAK +case 23: +YY_RULE_SETUP +#line 144 "scanner.l" { const char *error; FILE *fp = scanctx_push_include(yyextra, @@ -1078,123 +1107,124 @@ YY_RULE_SETUP BEGIN INITIAL; } YY_BREAK -case 21: -/* rule 21 can match eol */ +case 24: +/* rule 24 can match eol */ YY_RULE_SETUP -#line 160 "scanner.l" +#line 168 "scanner.l" { /* ignore */ } YY_BREAK -case 22: +case 25: YY_RULE_SETUP -#line 161 "scanner.l" +#line 169 "scanner.l" { /* ignore */ } YY_BREAK -case 23: +case 26: YY_RULE_SETUP -#line 163 "scanner.l" +#line 171 "scanner.l" { return(TOK_EQUALS); } YY_BREAK -case 24: +case 27: YY_RULE_SETUP -#line 164 "scanner.l" +#line 172 "scanner.l" { return(TOK_COMMA); } YY_BREAK -case 25: +case 28: YY_RULE_SETUP -#line 165 "scanner.l" +#line 173 "scanner.l" { return(TOK_GROUP_START); } YY_BREAK -case 26: +case 29: YY_RULE_SETUP -#line 166 "scanner.l" +#line 174 "scanner.l" { return(TOK_GROUP_END); } YY_BREAK -case 27: +case 30: YY_RULE_SETUP -#line 167 "scanner.l" +#line 175 "scanner.l" { yylval->ival = 1; return(TOK_BOOLEAN); } YY_BREAK -case 28: +case 31: YY_RULE_SETUP -#line 168 "scanner.l" +#line 176 "scanner.l" { yylval->ival = 0; return(TOK_BOOLEAN); } YY_BREAK -case 29: +case 32: YY_RULE_SETUP -#line 169 "scanner.l" +#line 177 "scanner.l" { yylval->sval = yytext; return(TOK_NAME); } YY_BREAK -case 30: +case 33: YY_RULE_SETUP -#line 170 "scanner.l" +#line 178 "scanner.l" { yylval->fval = atof(yytext); return(TOK_FLOAT); } YY_BREAK -case 31: +case 34: YY_RULE_SETUP -#line 171 "scanner.l" +#line 179 "scanner.l" { yylval->ival = atoi(yytext); return(TOK_INTEGER); } YY_BREAK -case 32: +case 35: YY_RULE_SETUP -#line 172 "scanner.l" +#line 180 "scanner.l" { yylval->llval = atoll(yytext); return(TOK_INTEGER64); } YY_BREAK -case 33: +case 36: YY_RULE_SETUP -#line 173 "scanner.l" +#line 181 "scanner.l" { yylval->ival = strtoul(yytext, NULL, 16); return(TOK_HEX); } YY_BREAK -case 34: +case 37: YY_RULE_SETUP -#line 177 "scanner.l" +#line 185 "scanner.l" { yylval->llval = fromhex(yytext); return(TOK_HEX64); } YY_BREAK -case 35: +case 38: YY_RULE_SETUP -#line 178 "scanner.l" +#line 186 "scanner.l" { return(TOK_ARRAY_START); } YY_BREAK -case 36: +case 39: YY_RULE_SETUP -#line 179 "scanner.l" +#line 187 "scanner.l" { return(TOK_ARRAY_END); } YY_BREAK -case 37: +case 40: YY_RULE_SETUP -#line 180 "scanner.l" +#line 188 "scanner.l" { return(TOK_LIST_START); } YY_BREAK -case 38: +case 41: YY_RULE_SETUP -#line 181 "scanner.l" +#line 189 "scanner.l" { return(TOK_LIST_END); } YY_BREAK -case 39: +case 42: YY_RULE_SETUP -#line 182 "scanner.l" +#line 190 "scanner.l" { return(TOK_SEMICOLON); } YY_BREAK -case 40: +case 43: *yy_cp = yyg->yy_hold_char; /* undo effects of setting up yytext */ yyg->yy_c_buf_p = yy_cp -= 1; YY_DO_BEFORE_ACTION; /* set up yytext again */ YY_RULE_SETUP -#line 183 "scanner.l" +#line 191 "scanner.l" { /* ignore */ } YY_BREAK -case 41: +case 44: YY_RULE_SETUP -#line 184 "scanner.l" +#line 192 "scanner.l" { return(TOK_GARBAGE); } YY_BREAK case YY_STATE_EOF(INITIAL): case YY_STATE_EOF(COMMENT): case YY_STATE_EOF(STRING): case YY_STATE_EOF(INCLUDE): -#line 186 "scanner.l" +case YY_STATE_EOF(SCRIPTBLOCK): +#line 194 "scanner.l" { YY_BUFFER_STATE buf = (YY_BUFFER_STATE)scanctx_pop_include( yyextra); @@ -1207,12 +1237,12 @@ case YY_STATE_EOF(INCLUDE): yyterminate(); } YY_BREAK -case 42: +case 45: YY_RULE_SETUP -#line 197 "scanner.l" +#line 205 "scanner.l" ECHO; YY_BREAK -#line 1216 "scanner.c" +#line 1246 "scanner.c" case YY_END_OF_BUFFER: { @@ -1506,7 +1536,7 @@ static int yy_get_next_buffer (yyscan_t yyscanner) while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) { yy_current_state = (int) yy_def[yy_current_state]; - if ( yy_current_state >= 103 ) + if ( yy_current_state >= 112 ) yy_c = yy_meta[(unsigned int) yy_c]; } yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; @@ -1535,11 +1565,11 @@ static int yy_get_next_buffer (yyscan_t yyscanner) while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) { yy_current_state = (int) yy_def[yy_current_state]; - if ( yy_current_state >= 103 ) + if ( yy_current_state >= 112 ) yy_c = yy_meta[(unsigned int) yy_c]; } yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; - yy_is_jam = (yy_current_state == 102); + yy_is_jam = (yy_current_state == 111); (void)yyg; return yy_is_jam ? 0 : yy_current_state; @@ -2346,4 +2376,4 @@ void libconfig_yyfree (void * ptr , yyscan_t yyscanner) #define YYTABLES_NAME "yytables" -#line 197 "scanner.l" +#line 205 "scanner.l" diff --git a/3rdparty/libconfig/scanner.h b/3rdparty/libconfig/scanner.h index da1134498..181bc5c94 100644 --- a/3rdparty/libconfig/scanner.h +++ b/3rdparty/libconfig/scanner.h @@ -226,6 +226,7 @@ void libconfig_yyfree (void * ,yyscan_t yyscanner ); #define COMMENT 1 #define STRING 2 #define INCLUDE 3 +#define SCRIPTBLOCK 4 #endif @@ -333,8 +334,8 @@ extern int libconfig_yylex \ #undef YY_DECL #endif -#line 197 "scanner.l" +#line 205 "scanner.l" -#line 339 "scanner.h" +#line 340 "scanner.h" #undef libconfig_yyIN_HEADER #endif /* libconfig_yyHEADER_H */ |