From 9e40d7bc916fc072963f9c27ed45235e1ad7f947 Mon Sep 17 00:00:00 2001 From: Nico Schottelius <nico@brief.schottelius.org> Date: Thu, 20 Sep 2012 17:35:14 +0200 Subject: [PATCH] clarify relation between line and regex Signed-off-by: Nico Schottelius <nico@brief.schottelius.org> --- conf/type/__line/gencode-remote | 17 +++++++++++++++-- conf/type/__line/man.text | 13 +++++++++++-- 2 files changed, 26 insertions(+), 4 deletions(-) diff --git a/conf/type/__line/gencode-remote b/conf/type/__line/gencode-remote index 9ca36177..75cd92b4 100755 --- a/conf/type/__line/gencode-remote +++ b/conf/type/__line/gencode-remote @@ -20,8 +20,10 @@ # file="/$__object_id" +regex="" state_should="present" -[ -f "$__object/parameter/file" ] && file=$(cat "$__object/parameter/file") +[ -f "$__object/parameter/file" ] && file=$(cat "$__object/parameter/file") +[ -f "$__object/parameter/regex" ] && regex=$(cat "$__object/parameter/regex") [ -f "$__object/parameter/state" ] && state_should=$(cat "$__object/parameter/state") state_is="$(cat "$__object/explorer/state")" @@ -41,7 +43,18 @@ case "$state_should" in ;; absent) - echo "echo q | ex -c \"/${line}/d|w|q\" \"${file}\"" + if [ "$regex" -a "$line" ]; then + echo "Mutally exclusive parameters regex and line given for state absent" >&2 + exit 1 + fi + + [ "$line" ] && regex="^$line\$" + + cat << eof +tmp=\$(mktemp) +sed '/$regex/d' "$file" > \$tmp && cat "\$tmp" > "$file" && rm -f "\$tmp" +eof + #echo "echo q | ex -c \"/${line}/d|w|q\" \"${file}\"" ;; *) echo "Unknown state: $state_should" >&2 diff --git a/conf/type/__line/man.text b/conf/type/__line/man.text index 137e31d1..e1a5941c 100644 --- a/conf/type/__line/man.text +++ b/conf/type/__line/man.text @@ -23,11 +23,20 @@ state:: line:: Specifies the line which should be absent or present + Must be present, if state is present. + Must not be combined with regex, if state is absent. regex:: - If supplied, search for this regex. - Otherwise entire line must be matched. + If state is present, search for this pattern and add + given line, if the given regular expression does not match. + + In case of absent, ensure all lines matching the + regular expression are absent (cannot be combined with + the line parameter, if state is absent). + + If the regular expression contains / (slashes), they need + to be escaped with \ (backslash): / becomes \/. file:: If supplied, use this as the destination file.