aboutsummaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authormerakor <cem@ckyln.com>2021-01-06 11:13:04 +0000
committermerakor <cem@ckyln.com>2021-01-06 11:13:04 +0000
commitfce5cc6898a4aaad7d5e2cff32562e6ac7b08489 (patch)
tree7ddcd5096734c7b473c044db970417596f9113ce /tools
parent642b2bcaf65376772bd4b88f3625f9f303a09512 (diff)
downloadcpt-fce5cc6898a4aaad7d5e2cff32562e6ac7b08489.tar.gz
install.sh: add '-s' flag for calling sed on file
FossilOrigin-Name: acca0276be8cc7993174072783c5d7573ce6da9062a762ff1404ffcf27b4c99a
Diffstat (limited to 'tools')
-rwxr-xr-xtools/install.sh24
1 files changed, 18 insertions, 6 deletions
diff --git a/tools/install.sh b/tools/install.sh
index f79cb3b..086c47d 100755
--- a/tools/install.sh
+++ b/tools/install.sh
@@ -1,13 +1,16 @@
#!/bin/sh -e
# Portable install version that supports -D -m and -t
+# We have our own extension flag -s for running sed on the given files while
+# installing.
usage() {
- printf '%s\n' "usage: $0 [-D] [-m mode] source dest" \
- " or: $0 [-D] [-m mode] [-t dir] [source...]" >&2
- exit 1
+ printf '%s\n' "usage: $0 [-D] [-m mode] [-s sedcmd] source dest" \
+ " or: $0 [-D] [-m mode] [-s sedcmd] [-t dir] [source...]" >&2
+ exit 0
}
die() { printf '%s\n' "$@" >&2; exit 1;}
+sed=''
mkdirp=''
target=''
mode=''
@@ -16,7 +19,7 @@ parse() {
OPTIND=$(($#+1))
while OPTARG= && [ $# -gt 0 ]; do
case $1 in
- -[tm]?*) OPTARG=$1; shift
+ -[stm]?*) OPTARG=$1; shift
eval 'set -- "${OPTARG%"${OPTARG#??}"}" "${OPTARG#??}"' ${1+'"$@"'}
;;
-[!-]?*) OPTARG=$1; shift
@@ -29,6 +32,11 @@ parse() {
eval '[ ${OPTARG+x} ] &&:' && OPTARG='1' || OPTARG=''
mkdirp="$OPTARG"
;;
+ '-s')
+ [ $# -le 1 ] && set "required" "$1" && break
+ OPTARG=$2
+ sed="$OPTARG"
+ shift ;;
'-t')
[ $# -le 1 ] && set "required" "$1" && break
OPTARG=$2
@@ -75,7 +83,11 @@ if [ "$target" ]; then
mkdir -p "$target"
for arg; do
[ -d "$target/${arg##*/}" ] && die "$target/${arg##*/} is a directory"
- cp "$arg" "$target/${arg##*/}"
+ if [ "$sed" ]; then
+ sed "$sed" < "$arg" > "$target/${arg##*/}"
+ else
+ cp "$arg" "$target"
+ fi
# Most implementations set the mode to 0755 by default when -t is set.
chmod "${mode:=0755}" "$target/${arg##*/}"
@@ -85,6 +97,6 @@ else
mkdir -p "${2%/*}"
esac
[ -d "$2" ] && die "$2 is a directory"
- cp "$1" "$2"
+ if [ "$sed" ]; then sed "$sed" < "$1" > "$2"; else cp "$1" "$2"; fi
chmod "${mode:=0755}" "$2"
fi