diff options
author | Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> | 2014-12-08 16:37:28 +0200 |
---|---|---|
committer | Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> | 2014-12-08 16:37:33 +0200 |
commit | 491d4e86baf9fcf4c526f827a70fc8d70b4fd899 (patch) | |
tree | 5b99e070bc1c370d59128f943ee8d58ec4b565c1 /main/augeas/0005-Shellvars-allow-quotes-in-loop-conditions.patch | |
parent | 760934f05b012d865c323a7e4aaf593e3302b008 (diff) | |
download | aports-491d4e86baf9fcf4c526f827a70fc8d70b4fd899.tar.bz2 aports-491d4e86baf9fcf4c526f827a70fc8d70b4fd899.tar.xz |
main/augeas: more fixes to Shellvars lense
parse e.g. main/ruby/APKBUILD
Diffstat (limited to 'main/augeas/0005-Shellvars-allow-quotes-in-loop-conditions.patch')
-rw-r--r-- | main/augeas/0005-Shellvars-allow-quotes-in-loop-conditions.patch | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/main/augeas/0005-Shellvars-allow-quotes-in-loop-conditions.patch b/main/augeas/0005-Shellvars-allow-quotes-in-loop-conditions.patch new file mode 100644 index 0000000000..d4dcdb9a51 --- /dev/null +++ b/main/augeas/0005-Shellvars-allow-quotes-in-loop-conditions.patch @@ -0,0 +1,54 @@ +From 1e842317de344335cf6f0b947156b401df1daae4 Mon Sep 17 00:00:00 2001 +From: Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> +Date: Mon, 8 Dec 2014 14:28:16 +0200 +Subject: [PATCH 05/10] Shellvars: allow quotes in loop conditions + +--- + lenses/shellvars.aug | 8 +------- + lenses/tests/test_shellvars.aug | 4 ++++ + 2 files changed, 5 insertions(+), 7 deletions(-) + +diff --git a/lenses/shellvars.aug b/lenses/shellvars.aug +index e318328..3671186 100644 +--- a/lenses/shellvars.aug ++++ b/lenses/shellvars.aug +@@ -45,12 +45,6 @@ module Shellvars = + let anyquot = (char|dquot|squot|dollar_assign|dollar_arithm)+ | bquot | dbquot + let sto_to_semicol = store (anyquot . (Rx.space . anyquot)*) + +- let sto_to_semicol_quot = +- let no_semicol_re = /[^"'#;\n]/ +- in let no_semicol_spc_re = /[^"'#; \t\n]/ +- in let multi_chars = no_semicol_spc_re . (no_semicol_re|anyquot)+ . no_semicol_spc_re +- in store (no_semicol_spc_re | multi_chars) +- + (* Array values of the form '(val1 val2 val3)'. We do not handle empty *) + (* arrays here because of typechecking headaches. Instead, they are *) + (* treated as a simple value *) +@@ -108,7 +102,7 @@ module Shellvars = + let generic_cond_start (start_kw:string) (lbl:string) + (then_kw:string) (contents:lens) = + keyword_label start_kw lbl . Sep.space +- . sto_to_semicol_quot . semicol_eol ++ . sto_to_semicol . semicol_eol + . keyword then_kw . eol + . contents + +diff --git a/lenses/tests/test_shellvars.aug b/lenses/tests/test_shellvars.aug +index 90e529b..8d8f34d 100644 +--- a/lenses/tests/test_shellvars.aug ++++ b/lenses/tests/test_shellvars.aug +@@ -502,6 +502,10 @@ fi\n" = + test Shellvars.lns get "for x in foo \\\nbar\\\nbaz; do y=$x; done\n" = + { "@for" = "x in foo \\\nbar\\\nbaz" { "y" = "$x" } } + ++ (* Allow quotes in loop conditions *) ++ test Shellvars.lns get "for x in \"$@\"; do y=$x; done\n" = ++ { "@for" = "x in \"$@\"" { "y" = "$x" } } ++ + (* Local Variables: *) + (* mode: caml *) + (* End: *) +-- +1.8.3.1 + |