mirror of
https://github.com/openwrt/packages.git
synced 2025-12-20 01:21:21 +00:00
python: Rework filespec install script
* Support wildcards in install (`+`) paths
* Add fourth parameter to set directory permissions
If file permissions are given (third parameter), these will now apply
to files only.
* Add non-recursive set permissions command (`==`)
* Be more strict about filespec format
Blank lines and lines starting with `#` will be ignored. Other errors
(unknown command, missing path parameter, etc.) will cause the script
to exit.
* Be more strict about ensuring paths exist for all commands
* Avoid spawning subshells
This also removes outdated filespec paths in the python3 package; these
paths delete files that are no longer present.
Signed-off-by: Jeffery To <jeffery.to@gmail.com>
(cherry picked from commit 2ffb87726b)
This commit is contained in:
@@ -1,45 +1,140 @@
|
||||
#!/bin/sh
|
||||
set -e
|
||||
|
||||
process_filespec() {
|
||||
local src_dir="$1"
|
||||
local dst_dir="$2"
|
||||
local filespec="$3"
|
||||
echo "$filespec" | (
|
||||
IFS='|'
|
||||
while read fop fspec fperm; do
|
||||
local fop=`echo "$fop" | tr -d ' \t\n'`
|
||||
if [ "$fop" = "+" ]; then
|
||||
if [ ! -e "${src_dir}${fspec}" ]; then
|
||||
echo "File not found '${src_dir}${fspec}'"
|
||||
exit 1
|
||||
fi
|
||||
dpath=`dirname "$fspec"`
|
||||
if [ -z "$fperm" ]; then
|
||||
dperm=`stat -c "%a" ${src_dir}${dpath}`
|
||||
fi
|
||||
mkdir -p -m$dperm ${dst_dir}${dpath}
|
||||
echo "copying: '$fspec'"
|
||||
cp -fpR ${src_dir}${fspec} ${dst_dir}${dpath}/
|
||||
if [ -n "$fperm" ]; then
|
||||
chmod -R $fperm ${dst_dir}${fspec}
|
||||
fi
|
||||
elif [ "$fop" = "-" ]; then
|
||||
echo "removing: '$fspec'"
|
||||
rm -fR ${dst_dir}${fspec}
|
||||
elif [ "$fop" = "=" ]; then
|
||||
echo "setting permissions: '$fperm' on '$fspec'"
|
||||
chmod -R $fperm ${dst_dir}${fspec}
|
||||
fi
|
||||
done
|
||||
)
|
||||
log() {
|
||||
printf '%s\n' "$*"
|
||||
}
|
||||
|
||||
src_dir="$1"
|
||||
dst_dir="$2"
|
||||
error() {
|
||||
printf 'Error: %s\n' "$*" >&2
|
||||
}
|
||||
|
||||
path_exists() {
|
||||
local dir="$1"
|
||||
local path="$2"
|
||||
|
||||
[ -n "$(find "$dir"/$path -print -quit 2>/dev/null)" ]
|
||||
}
|
||||
|
||||
file_dir_chmod() {
|
||||
local dir="$1"
|
||||
local path="$2"
|
||||
local file_mode="$3"
|
||||
local dir_mode="$4"
|
||||
shift; shift; shift; shift;
|
||||
|
||||
if [ -n "$file_mode" ]; then
|
||||
find "$dir"/$path -type f "$@" -exec chmod "$file_mode" -- '{}' +
|
||||
fi
|
||||
|
||||
if [ -n "$dir_mode" ]; then
|
||||
find "$dir"/$path -type d "$@" -exec chmod "$dir_mode" -- '{}' +
|
||||
fi
|
||||
}
|
||||
|
||||
src="$1"
|
||||
dest="$2"
|
||||
filespec="$3"
|
||||
|
||||
process_filespec "$src_dir" "$dst_dir" "$filespec" || {
|
||||
echo "process filespec error-ed"
|
||||
if [ -z "$src" ]; then
|
||||
error "Missing source directory"
|
||||
exit 1
|
||||
}
|
||||
fi
|
||||
if [ -z "$dest" ]; then
|
||||
error "Missing destination directory"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
while IFS='|' read -r cmd path file_mode dir_mode; do
|
||||
|
||||
# trim whitespace
|
||||
|
||||
cmd="${cmd#"${cmd%%[![:space:]]*}"}"
|
||||
cmd="${cmd%"${cmd##*[![:space:]]}"}"
|
||||
|
||||
path="${path#"${path%%[![:space:]]*}"}"
|
||||
path="${path%"${path##*[![:space:]]}"}"
|
||||
|
||||
file_mode="${file_mode#"${file_mode%%[![:space:]]*}"}"
|
||||
file_mode="${file_mode%"${file_mode##*[![:space:]]}"}"
|
||||
|
||||
dir_mode="${dir_mode#"${dir_mode%%[![:space:]]*}"}"
|
||||
dir_mode="${dir_mode%"${dir_mode##*[![:space:]]}"}"
|
||||
|
||||
|
||||
if [ -z "$cmd" ] || [ "$cmd" != "${cmd#\#}" ]; then
|
||||
continue
|
||||
fi
|
||||
|
||||
if [ -z "$path" ]; then
|
||||
error "Missing path for \"$cmd\""
|
||||
exit 1
|
||||
fi
|
||||
|
||||
case "$cmd" in
|
||||
+)
|
||||
log "Copying: \"$path\""
|
||||
|
||||
if ! path_exists "$src" "$path"; then
|
||||
error "\"$src/$path\" not found"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
dir="${path%/*}"
|
||||
mkdir -p "$dest/$dir"
|
||||
cp -fpR "$src"/$path "$dest/$dir/"
|
||||
|
||||
file_dir_chmod "$dest" "$path" "$file_mode" "$dir_mode"
|
||||
;;
|
||||
|
||||
-)
|
||||
log "Removing: \"$path\""
|
||||
|
||||
if ! path_exists "$dest" "$path"; then
|
||||
error "\"$dest/$path\" not found"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
rm -fR -- "$dest"/$path
|
||||
;;
|
||||
|
||||
=)
|
||||
log "Setting recursive permissions \"${file_mode:-(none)}\"/\"${dir_mode:-(none)}\" on \"$path\""
|
||||
|
||||
if ! path_exists "$dest" "$path"; then
|
||||
error "\"$dest/$path\" not found"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ -z "$file_mode$dir_mode" ]; then
|
||||
error "Missing recursive permissions for \"$path\""
|
||||
exit 1
|
||||
fi
|
||||
|
||||
file_dir_chmod "$dest" "$path" "$file_mode" "$dir_mode"
|
||||
;;
|
||||
|
||||
==)
|
||||
log "Setting permissions \"${file_mode:-(none)}\"/\"${dir_mode:-(none)}\" on \"$path\""
|
||||
|
||||
if ! path_exists "$dest" "$path"; then
|
||||
error "\"$dest/$path\" not found"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ -z "$file_mode$dir_mode" ]; then
|
||||
error "Missing permissions for \"$path\""
|
||||
exit 1
|
||||
fi
|
||||
|
||||
file_dir_chmod "$dest" "$path" "$file_mode" "$dir_mode" -maxdepth 0
|
||||
;;
|
||||
|
||||
*)
|
||||
error "Unknown command \"$cmd\""
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
|
||||
done << EOF
|
||||
$filespec
|
||||
EOF
|
||||
|
||||
Reference in New Issue
Block a user