From: Alan Dunn Date: Wed, 2 Mar 2016 16:59:03 +0000 (-0800) Subject: Allow evaluation of arbitrarily-positioned arguments in GRUB2 parser X-Git-Tag: v1.0.1~2 X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=commitdiff_plain;h=013bf20025957f1b812f0c6e50f8d7afa215e1a3 Allow evaluation of arbitrarily-positioned arguments in GRUB2 parser GRUB2 allows essentially arbitrary numbers of positional arguments, so ensure that they can be evaluated within scripts. GRUB2 also appears to support arbitrary numbers of leading 0's in positional parameters (i.e., $01 should evalute the same as $1), but this doesn't seem like a particularly important case to support. Tested: Modified test-grub2-pos-param to cover higher-numbered positional arguments. Signed-off-by: Alan Dunn Signed-off-by: Samuel Mendoza-Jonas --- diff --git a/discover/grub2/grub2-lexer.l b/discover/grub2/grub2-lexer.l index 81dc5fe..b55a715 100644 --- a/discover/grub2/grub2-lexer.l +++ b/discover/grub2/grub2-lexer.l @@ -24,7 +24,8 @@ void yyerror(struct grub2_parser *parser, const char *fmt, ...); WORD [^{}|&$;<> \t\n'"#]+ DELIM [ \t]+ BLANK ["]{2}|[']{2} -VARNAME ([[:alpha:]][_[:alnum:]]*|[0-9]|[\?@\*#]) +NUMBER 0|[1-9][0-9]* +VARNAME ([[:alpha:]][_[:alnum:]]*|{NUMBER}|[\?@\*#]) %% diff --git a/test/parser/test-grub2-pos-param.c b/test/parser/test-grub2-pos-param.c index 09ac8fc..36447ff 100644 --- a/test/parser/test-grub2-pos-param.c +++ b/test/parser/test-grub2-pos-param.c @@ -4,10 +4,10 @@ #if 0 /* PARSER_EMBEDDED_CONFIG */ function set_params_var { - params="$1 $2" + params="$1 $2 $10" } menuentry 'Linux' { - set_params_var abc 123 + set_params_var abc 123 3 4 5 6 7 8 9 bingo linux test_kernel $params } @@ -31,5 +31,5 @@ void run_test(struct parser_test *test) /* The linux command, $params is expected to have been set when * set_params was called in menuentry. */ - check_args(opt, "abc 123"); + check_args(opt, "abc 123 bingo"); }