diff options
author | Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> | 2014-12-05 13:32:47 +0200 |
---|---|---|
committer | Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> | 2014-12-05 13:32:47 +0200 |
commit | a99d67cdf234dab8c937d613c2b81a7f06b04869 (patch) | |
tree | edd1654e0117b8a9b1d9197b8ea571a0076deb46 | |
parent | 82fa7ab6f5bbc2012c92d0ada2785c13519f5525 (diff) | |
download | aports-a99d67cdf234dab8c937d613c2b81a7f06b04869.tar.bz2 aports-a99d67cdf234dab8c937d613c2b81a7f06b04869.tar.xz |
main/augeas: update to 1.3.0
also fix the Shellvars lense to allow parsing of APKBUILD files
6 files changed, 315 insertions, 9 deletions
diff --git a/main/augeas/0001-Shellvars-allow-partial-quoting-mixing-multiple-styl.patch b/main/augeas/0001-Shellvars-allow-partial-quoting-mixing-multiple-styl.patch new file mode 100644 index 0000000000..b3d7012ae1 --- /dev/null +++ b/main/augeas/0001-Shellvars-allow-partial-quoting-mixing-multiple-styl.patch @@ -0,0 +1,68 @@ +From 937653cbb1f9681a575e0fa5e8f2d0e59fd9ab5c Mon Sep 17 00:00:00 2001 +From: Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> +Date: Thu, 4 Dec 2014 14:31:26 +0200 +Subject: [PATCH 1/5] Shellvars: allow partial quoting, mixing multiple styles + +--- + lenses/shellvars.aug | 8 ++++---- + lenses/tests/test_shellvars.aug | 4 ++++ + 2 files changed, 8 insertions(+), 4 deletions(-) + +diff --git a/lenses/shellvars.aug b/lenses/shellvars.aug +index 073f69b..60091a9 100644 +--- a/lenses/shellvars.aug ++++ b/lenses/shellvars.aug +@@ -31,7 +31,7 @@ module Shellvars = + let xchgs = Build.xchgs + let semicol = del /;?/ "" + +- let char = /[^`;() '"\t\n]|\\\\"/ ++ let char = /[^`;() '"\t\n\\]|\\\\./ + let dquot = + let char = /[^"\\]|\\\\./ | Rx.cl + in "\"" . char* . "\"" (* " Emacs, relax *) +@@ -42,7 +42,7 @@ module Shellvars = + let dollar_assign = /\$\([^\(\)#\n]*\)/ + let dollar_arithm = /\$\(\([^\)#\n]*\)\)/ + +- let anyquot = (dquot|squot)+ | bquot | dbquot | dollar_assign | dollar_arithm ++ let anyquot = (char|dquot|squot|dollar_assign|dollar_arithm)+ | bquot | dbquot + + let to_semicol_re = /[^#; \t\n][^#;\n]+[^#; \t\n]|[^#; \t\n]+/ + let sto_to_semicol = store to_semicol_re +@@ -57,7 +57,7 @@ module Shellvars = + (* arrays here because of typechecking headaches. Instead, they are *) + (* treated as a simple value *) + let array = +- let array_value = store (char+ | anyquot) in ++ let array_value = store anyquot in + del /\([ \t]*/ "(" . counter "values" . + [ seq "values" . array_value ] . + [ del /[ \t\n]+/ " " . seq "values" . array_value ] * +@@ -67,7 +67,7 @@ module Shellvars = + (* but fairly close. *) + let simple_value = + let empty_array = /\([ \t]*\)/ in +- store (char* | anyquot | empty_array) ++ store (anyquot | empty_array)? + + let export = [ key "export" . Util.del_ws_spc ] + let kv = Util.indent . export? . key key_re +diff --git a/lenses/tests/test_shellvars.aug b/lenses/tests/test_shellvars.aug +index 42fc2bd..e4fd79f 100644 +--- a/lenses/tests/test_shellvars.aug ++++ b/lenses/tests/test_shellvars.aug +@@ -399,6 +399,10 @@ esac\n" = + test Shellvars.lns get "FOO=``bar``\n" = + { "FOO" = "``bar``" } + ++ (* Partial quoting is allowed *) ++ test Shellvars.lns get "FOO=\"$bar\"/'baz'/$(quux)$((1 + 2))\n" = ++ { "FOO" = "\"$bar\"/'baz'/$(quux)$((1 + 2))" } ++ + (* unset can be used on wildcard variables *) + test Shellvars.lns get "unset ${!LC_*}\n" = + { "@unset" +-- +1.8.3.1 + diff --git a/main/augeas/0002-Shellvars-allow-wrapping-builtin-arguments-to-multip.patch b/main/augeas/0002-Shellvars-allow-wrapping-builtin-arguments-to-multip.patch new file mode 100644 index 0000000000..5dea08e26c --- /dev/null +++ b/main/augeas/0002-Shellvars-allow-wrapping-builtin-arguments-to-multip.patch @@ -0,0 +1,42 @@ +From 0563e64fdd8c8ce3b97d58909697ff7f61c29adb Mon Sep 17 00:00:00 2001 +From: Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> +Date: Thu, 4 Dec 2014 18:25:12 +0200 +Subject: [PATCH 2/5] Shellvars: allow wrapping builtin arguments to multiple + lines + +--- + lenses/shellvars.aug | 2 +- + lenses/tests/test_shellvars.aug | 4 ++++ + 2 files changed, 5 insertions(+), 1 deletion(-) + +diff --git a/lenses/shellvars.aug b/lenses/shellvars.aug +index 60091a9..645d6ed 100644 +--- a/lenses/shellvars.aug ++++ b/lenses/shellvars.aug +@@ -44,7 +44,7 @@ module Shellvars = + + let anyquot = (char|dquot|squot|dollar_assign|dollar_arithm)+ | bquot | dbquot + +- let to_semicol_re = /[^#; \t\n][^#;\n]+[^#; \t\n]|[^#; \t\n]+/ ++ let to_semicol_re = /([^#; \t\n\\]|\\\\.)(([^#;\n\\]|\\\\(.|\n))*([^#; \t\n\\]|\\\\.))?/ + let sto_to_semicol = store to_semicol_re + + let sto_to_semicol_quot = +diff --git a/lenses/tests/test_shellvars.aug b/lenses/tests/test_shellvars.aug +index e4fd79f..65c2927 100644 +--- a/lenses/tests/test_shellvars.aug ++++ b/lenses/tests/test_shellvars.aug +@@ -165,6 +165,10 @@ unset ONBOOT # We do not want this var + { "@builtin" = "exit" } + { "@builtin" = "exit" { "args" = "2" } } + ++ (* Allow wrapping builtin arguments to multiple lines *) ++ test Shellvars.lns get "ulimit -c \\\nunlimited\n" = ++ { "@builtin" = "ulimit" { "args" = "-c \\\nunlimited" } } ++ + (* Test semicolons *) + test lns get "VAR1=\"this;is;a;test\"\nVAR2=this;\n" = + { "VAR1" = "\"this;is;a;test\"" } +-- +1.8.3.1 + diff --git a/main/augeas/0003-Shellvars-Allow-almost-any-command.patch b/main/augeas/0003-Shellvars-Allow-almost-any-command.patch new file mode 100644 index 0000000000..34bb5982ee --- /dev/null +++ b/main/augeas/0003-Shellvars-Allow-almost-any-command.patch @@ -0,0 +1,82 @@ +From 23498cfa489397a60cc0667352fd144d3cdd905d Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Rapha=C3=ABl=20Pinson?= <raphink@gmail.com> +Date: Thu, 24 Apr 2014 16:10:50 +0200 +Subject: [PATCH 3/5] Shellvars: Allow (almost) any command + + Note: this may have edge effects in recursive sublenses + that augparse cannot check. +--- + NEWS | 1 + + lenses/shellvars.aug | 7 +++++++ + lenses/tests/test_shellvars.aug | 11 +++++++++++ + 3 files changed, 19 insertions(+) + +diff --git a/NEWS b/NEWS +index 73b5332..4501226 100644 +--- a/NEWS ++++ b/NEWS +@@ -57,6 +57,7 @@ + conditions (GH issue #118) + Support $(( .. )) arithmetic expansion in variable + assignment, RHBZ#1100550 ++ Allow (almost) any command + * Simplevars: Support flags and empty values + * Sshd: Allow all types of entries in Match groups (GH issue #75) + * Sssd: Allow ; for comments +diff --git a/lenses/shellvars.aug b/lenses/shellvars.aug +index 645d6ed..a50c0f6 100644 +--- a/lenses/shellvars.aug ++++ b/lenses/shellvars.aug +@@ -102,6 +102,11 @@ module Shellvars = + . Util.del_str "return" + . ( Util.del_ws_spc . store Rx.integer )? + ++ let command = ++ let reserved_key = /exit|shift|return|ulimit|unset|export|source|\.|if|for|select|while|until|then|else|fi|done|case/ ++ in let word = /[A-Za-z0-9_.-\/]+/ ++ in Util.indent . label "@command" . store (word - reserved_key) ++ . [ Sep.space . label "@arg" . sto_to_semicol]? + + (************************************************************************ + * Group: CONDITIONALS AND LOOPS +@@ -166,6 +171,7 @@ module Shellvars = + | entry_eol_item bare_export + | entry_eol_item builtin + | entry_eol_item return ++ | entry_eol_item command + + let entry_noeol = + let entry_item (item:lens) = [ item ] in +@@ -175,6 +181,7 @@ module Shellvars = + | entry_item bare_export + | entry_item builtin + | entry_item return ++ | entry_item command + + let rec rec_entry = + let entry = comment | entry_eol | rec_entry in +diff --git a/lenses/tests/test_shellvars.aug b/lenses/tests/test_shellvars.aug +index 65c2927..fd9e299 100644 +--- a/lenses/tests/test_shellvars.aug ++++ b/lenses/tests/test_shellvars.aug +@@ -497,6 +497,17 @@ fi\n" = + { "MALLOC_PERTURB_" = "$(($RANDOM % 255 + 1))" + { "export" } } + ++(* Test: Shellvars.lns ++ Parse (almost) any command *) ++test Shellvars.lns get "echo foobar 'and this is baz' ++/usr/local/bin/myscript.sh with args\n" = ++ { "@command" = "echo" ++ { "@arg" = "foobar 'and this is baz'" } ++ } ++ { "@command" = "/usr/local/bin/myscript.sh" ++ { "@arg" = "with args" } ++ } ++ + (* Local Variables: *) + (* mode: caml *) + (* End: *) +-- +1.8.3.1 + diff --git a/main/augeas/0004-Shellvars-test-case-for-wrapping-command-arguments.patch b/main/augeas/0004-Shellvars-test-case-for-wrapping-command-arguments.patch new file mode 100644 index 0000000000..87c244c0bd --- /dev/null +++ b/main/augeas/0004-Shellvars-test-case-for-wrapping-command-arguments.patch @@ -0,0 +1,37 @@ +From 6b6b88a3725159771ac9c822d04d406a8b0c56e8 Mon Sep 17 00:00:00 2001 +From: Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> +Date: Thu, 4 Dec 2014 18:29:58 +0200 +Subject: [PATCH 4/5] Shellvars: test case for wrapping command arguments + +--- + lenses/tests/test_shellvars.aug | 8 +++++++- + 1 file changed, 7 insertions(+), 1 deletion(-) + +diff --git a/lenses/tests/test_shellvars.aug b/lenses/tests/test_shellvars.aug +index fd9e299..5b9fdba 100644 +--- a/lenses/tests/test_shellvars.aug ++++ b/lenses/tests/test_shellvars.aug +@@ -500,13 +500,19 @@ fi\n" = + (* Test: Shellvars.lns + Parse (almost) any command *) + test Shellvars.lns get "echo foobar 'and this is baz' +-/usr/local/bin/myscript.sh with args\n" = ++/usr/local/bin/myscript.sh with args ++echo foo \ ++bar\n" = + { "@command" = "echo" + { "@arg" = "foobar 'and this is baz'" } + } + { "@command" = "/usr/local/bin/myscript.sh" + { "@arg" = "with args" } + } ++ { "@command" = "echo" ++ { "@arg" = "foo \ ++bar" } ++ } + + (* Local Variables: *) + (* mode: caml *) +-- +1.8.3.1 + diff --git a/main/augeas/0005-Shellvars-case-support-on-same-line-with-multiple-co.patch b/main/augeas/0005-Shellvars-case-support-on-same-line-with-multiple-co.patch new file mode 100644 index 0000000000..420d29fa2f --- /dev/null +++ b/main/augeas/0005-Shellvars-case-support-on-same-line-with-multiple-co.patch @@ -0,0 +1,57 @@ +From 9764767e2c633bcedf91d3d7a9ec2542e4658ff0 Mon Sep 17 00:00:00 2001 +From: Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> +Date: Thu, 4 Dec 2014 21:51:03 +0200 +Subject: [PATCH 5/5] Shellvars: case: support ;; on same line with multiple + commands + +--- + lenses/shellvars.aug | 2 +- + lenses/tests/test_shellvars.aug | 19 +++++++++++++++++++ + 2 files changed, 20 insertions(+), 1 deletion(-) + +diff --git a/lenses/shellvars.aug b/lenses/shellvars.aug +index a50c0f6..b683cc0 100644 +--- a/lenses/shellvars.aug ++++ b/lenses/shellvars.aug +@@ -145,7 +145,7 @@ module Shellvars = + let case_entry = [ label "@case_entry" + . Util.indent . store /[^ \t\n\)]+/ + . Util.del_str ")" . eol +- . ( entry+ | entry_noeol )? ++ . entry* . entry_noeol? + . Util.indent . Util.del_str ";;" . eol ] in + [ keyword_label "case" "@case" . Sep.space + . store (char+ | ("\"" . char+ . "\"")) +diff --git a/lenses/tests/test_shellvars.aug b/lenses/tests/test_shellvars.aug +index 5b9fdba..0ff1b1a 100644 +--- a/lenses/tests/test_shellvars.aug ++++ b/lenses/tests/test_shellvars.aug +@@ -478,6 +478,25 @@ esac\n" = + { "@case_entry" = "1" + { "TestVar" = "\"test1\"" } } } + ++ (* case: support ;; on the same line with multiple commands *) ++ test lns get "case $ARG in ++ 0) Foo=0; Bar=1;; ++ 1) ++ Foo=2 ++ Bar=3; Baz=4;; ++esac\n" = ++ { "@case" = "$ARG" ++ { "@case_entry" = "0" ++ { "Foo" = "0" } ++ { "Bar" = "1" } ++ } ++ { "@case_entry" = "1" ++ { "Foo" = "2" } ++ { "Bar" = "3" } ++ { "Baz" = "4" } ++ } ++ } ++ + (* Test: Shellvars.lns + Support `##` bashism in conditions (GH issue #118) *) + test Shellvars.lns get "if [ \"${APACHE_CONFDIR##/etc/apache2-}\" != \"${APACHE_CONFDIR}\" ] ; then +-- +1.8.3.1 + diff --git a/main/augeas/APKBUILD b/main/augeas/APKBUILD index c416c81b7a..9066016250 100644 --- a/main/augeas/APKBUILD +++ b/main/augeas/APKBUILD @@ -1,7 +1,7 @@ # Maintainer: Natanael Copa <ncopa@alpinelinux.org> pkgname=augeas -pkgver=1.2.0 -pkgrel=2 +pkgver=1.3.0 +pkgrel=0 pkgdesc="A configuration editing tool" url="http://augeas.net" arch="all" @@ -12,7 +12,12 @@ makedepends="$depends_dev readline-dev" install="" subpackages="$pkgname-dev $pkgname-doc $pkgname-tests $pkgname-libs" source="http://download.augeas.net/augeas-$pkgver.tar.gz - 0001-Dnsmasq-add-structure-to-address-and-server-options.patch" + 0001-Dnsmasq-add-structure-to-address-and-server-options.patch + 0001-Shellvars-allow-partial-quoting-mixing-multiple-styl.patch + 0002-Shellvars-allow-wrapping-builtin-arguments-to-multip.patch + 0003-Shellvars-Allow-almost-any-command.patch + 0004-Shellvars-test-case-for-wrapping-command-arguments.patch + 0005-Shellvars-case-support-on-same-line-with-multiple-co.patch" _builddir="$srcdir"/$pkgname-$pkgver prepare() { @@ -63,9 +68,24 @@ libs() { "$subpkgdir"/usr/share/augeas/ || return 1 } -md5sums="dce2f52cbd20f72c7da48e014ad48076 augeas-1.2.0.tar.gz -b140791828aec2037c411164102ef8cd 0001-Dnsmasq-add-structure-to-address-and-server-options.patch" -sha256sums="f4aeb28ebe0b0921920fe1c9b4c016739c25261a15de04cb97db02d669f481e0 augeas-1.2.0.tar.gz -0cb29dfdef3f293c5a4db06704072a6672ce728c82d4b2a7260da341522efc37 0001-Dnsmasq-add-structure-to-address-and-server-options.patch" -sha512sums="fa3cf6bf5143bc4afbf3b360834565a295d7ef815894a019f1e8017a0199f778adc6d6c44ee220b24b37355211264535af7efc56134c81b167df296134095aa8 augeas-1.2.0.tar.gz -f2cdf6fcd84de4f86bc54d89292d3c4c19070b1c6d5149af6a8d7c49678e2a7527b6549ad114e5ccec53d4d9582814153732f69a4c0228243aac96c48a0e1d1d 0001-Dnsmasq-add-structure-to-address-and-server-options.patch" +md5sums="c8890b11a04795ecfe5526eeae946b2d augeas-1.3.0.tar.gz +b140791828aec2037c411164102ef8cd 0001-Dnsmasq-add-structure-to-address-and-server-options.patch +b4cb2352d2291f59cf337a85581155d5 0001-Shellvars-allow-partial-quoting-mixing-multiple-styl.patch +c46a285bbb12463a8464d94e1aa83477 0002-Shellvars-allow-wrapping-builtin-arguments-to-multip.patch +e53532cb842babf3b785369d23437005 0003-Shellvars-Allow-almost-any-command.patch +c14dfc123474916f8329a9cf94eb9209 0004-Shellvars-test-case-for-wrapping-command-arguments.patch +73c032499a48ed2d5847a9a627131eb5 0005-Shellvars-case-support-on-same-line-with-multiple-co.patch" +sha256sums="80763031af76515a8ea66013ddc3c466742a15d2e907c7c8e2e3b7410262e2af augeas-1.3.0.tar.gz +0cb29dfdef3f293c5a4db06704072a6672ce728c82d4b2a7260da341522efc37 0001-Dnsmasq-add-structure-to-address-and-server-options.patch +23a952a8f77e86656d009ad417f109e6e31b1635beb49ff6fcc232bbea6236f4 0001-Shellvars-allow-partial-quoting-mixing-multiple-styl.patch +914ccac060da5a164c7a37e2cfdb05ea20b583a9bb84631b5bafb9ae37f18214 0002-Shellvars-allow-wrapping-builtin-arguments-to-multip.patch +95775c884e42e89136511afcc96802f1ac60872ef4933800b88c92b01413dad9 0003-Shellvars-Allow-almost-any-command.patch +d53ab29203e2d443317e6ac848b0ba421d774bb08c80719863841897e8695c02 0004-Shellvars-test-case-for-wrapping-command-arguments.patch +3ced5d61df3c509c68c135bbe78f855adf92b5bf1cfa25aa6c4ffeb25a930cff 0005-Shellvars-case-support-on-same-line-with-multiple-co.patch" +sha512sums="92cc2cf83faa42e83621fe0f73fe9f7247d802f17da781e51d068056d20b1645de1f0ea0d5070c0d5729a3f6554d64a95e31111bf3e44b959386559619843e79 augeas-1.3.0.tar.gz +f2cdf6fcd84de4f86bc54d89292d3c4c19070b1c6d5149af6a8d7c49678e2a7527b6549ad114e5ccec53d4d9582814153732f69a4c0228243aac96c48a0e1d1d 0001-Dnsmasq-add-structure-to-address-and-server-options.patch +e89edad7188eff4bffa8710af0f4cb79f4f1c1d37019ebd82b545465abfd276289b79d6980a3a065159d01574ab77bffb8bb0e54daeb05d7e5476f7da73552a7 0001-Shellvars-allow-partial-quoting-mixing-multiple-styl.patch +76552267238f097431b61f2aa381846a850b0cec22072e471fbcbc1bb455dc887a4119b7d5ac592e10c509fda43159ea958f7ab6267c05f7963306aff0502a7c 0002-Shellvars-allow-wrapping-builtin-arguments-to-multip.patch +6286efd526f8d4ad75198a0fc02732cf560285cf0a51731faf60cf3c0c75a364852fff399dcc99e1102585c39563c2b2518ee2a4e113bafeadf5e4400a0bff59 0003-Shellvars-Allow-almost-any-command.patch +6d7284139a1ab59fb8d189a1e851592095b511fb88cf1603213d299e0b0ca3b3afcad9ba22da0225cdb3b53a8cb1837047cec04d9a859bfc2fc73f9b78877967 0004-Shellvars-test-case-for-wrapping-command-arguments.patch +4c1b64373dec24eee0eb11d163468852afcf24336795e116e7501804b7c1273a2bfdc78fe1bce1f327f3b4fa80c560854a71bb56ab44ac1a492f6b0905aeb18a 0005-Shellvars-case-support-on-same-line-with-multiple-co.patch" |