From 642b2bcaf65376772bd4b88f3625f9f303a09512 Mon Sep 17 00:00:00 2001 From: merakor Date: Tue, 5 Jan 2021 17:31:48 +0000 Subject: pkg_build(): create package directories manually This ensures that we create the needed directories regardless of pkg_extract() FossilOrigin-Name: c7c7c11246aeb74343f06e1d5d53ea9ad4cab2f4153d745cb00ae0c62f51b048 --- src/cpt-lib.in | 1 + 1 file changed, 1 insertion(+) diff --git a/src/cpt-lib.in b/src/cpt-lib.in index 0c46dbe..9aa232c 100644 --- a/src/cpt-lib.in +++ b/src/cpt-lib.in @@ -1040,6 +1040,7 @@ pkg_build() { for pkg do log "$pkg" "Building package ($((in = in + 1))/$#)" + mkdir -p "$mak_dir/$pkg" pkg_extract "$pkg" repo_dir=$(pkg_find "$pkg") -- cgit v1.2.3 From fce5cc6898a4aaad7d5e2cff32562e6ac7b08489 Mon Sep 17 00:00:00 2001 From: merakor Date: Wed, 6 Jan 2021 11:13:04 +0000 Subject: install.sh: add '-s' flag for calling sed on file FossilOrigin-Name: acca0276be8cc7993174072783c5d7573ce6da9062a762ff1404ffcf27b4c99a --- tools/install.sh | 24 ++++++++++++++++++------ 1 file 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 -- cgit v1.2.3