mirror of
https://codeberg.org/kiss-community/kiss
synced 2025-01-21 18:04:40 -07:00
kiss: only move up directories if there is just one top level dir
This commit is contained in:
parent
d240830906
commit
02c254e388
52
kiss
52
kiss
@ -535,33 +535,39 @@ pkg_source_tar() {
|
|||||||
tar tf "$_tmp_file_pre" | sort -ut / -k1,1 > "$_tmp_file" ||
|
tar tf "$_tmp_file_pre" | sort -ut / -k1,1 > "$_tmp_file" ||
|
||||||
die "$repo_name" "Failed to extract manifest"
|
die "$repo_name" "Failed to extract manifest"
|
||||||
|
|
||||||
# Iterate over all directories in the first level of the
|
# Only move directories up a level if there is one top-level directory
|
||||||
# tarball's manifest. Each directory is moved up a level.
|
# in the tarball. The tarball could contain all the files without a top
|
||||||
while IFS=/ read -r dir _; do case ${dir#.} in *?*)
|
# directory, so in those more complicated cases, just give the build file
|
||||||
# Skip entries which aren't directories.
|
# the original tar structure.
|
||||||
[ -d "$dir" ] || continue
|
case "$(wc -l <"$_tmp_file")" in 1)
|
||||||
|
# Iterate over all directories in the first level of the
|
||||||
|
# tarball's manifest. Each directory is moved up a level.
|
||||||
|
while IFS=/ read -r dir _; do case ${dir#.} in *?*)
|
||||||
|
# Skip entries which aren't directories.
|
||||||
|
[ -d "$dir" ] || continue
|
||||||
|
|
||||||
# Move the parent directory to prevent naming conflicts
|
# Move the parent directory to prevent naming conflicts
|
||||||
# with the to-be-moved children.
|
# with the to-be-moved children.
|
||||||
mv -f "$dir" "$KISS_PID-$dir"
|
mv -f "$dir" "$KISS_PID-$dir"
|
||||||
|
|
||||||
# Move all children up a directory level. If the mv command
|
# Move all children up a directory level. If the mv command
|
||||||
# fails, fallback to copying the remainder of the files.
|
# fails, fallback to copying the remainder of the files.
|
||||||
#
|
#
|
||||||
# We can't use '-exec {} +' with any arguments between
|
# We can't use '-exec {} +' with any arguments between
|
||||||
# the '{}' and '+' as this is not POSIX. We must also
|
# the '{}' and '+' as this is not POSIX. We must also
|
||||||
# use '$0' and '$@' to reference all arguments.
|
# use '$0' and '$@' to reference all arguments.
|
||||||
find "$KISS_PID-$dir/." ! -name . -prune \
|
find "$KISS_PID-$dir/." ! -name . -prune \
|
||||||
-exec sh -c 'mv -f "$0" "$@" .' {} + 2>/dev/null ||
|
-exec sh -c 'mv -f "$0" "$@" .' {} + 2>/dev/null ||
|
||||||
|
|
||||||
find "$KISS_PID-$dir/." ! -name . -prune \
|
find "$KISS_PID-$dir/." ! -name . -prune \
|
||||||
-exec sh -c 'cp -fRPp "$0" "$@" .' {} +
|
-exec sh -c 'cp -fRPp "$0" "$@" .' {} +
|
||||||
|
|
||||||
# Remove the directory now that all files have been
|
# Remove the directory now that all files have been
|
||||||
# transferred out of it. This can't be a simple 'rmdir'
|
# transferred out of it. This can't be a simple 'rmdir'
|
||||||
# as we may leave files in here if any were copied.
|
# as we may leave files in here if any were copied.
|
||||||
rm -rf "$KISS_PID-$dir"
|
rm -rf "$KISS_PID-$dir"
|
||||||
esac done < "$_tmp_file"
|
esac done < "$_tmp_file"
|
||||||
|
esac
|
||||||
|
|
||||||
# Remove the tarball now that we are done with it.
|
# Remove the tarball now that we are done with it.
|
||||||
rm -f "$_tmp_file_pre"
|
rm -f "$_tmp_file_pre"
|
||||||
|
Loading…
Reference in New Issue
Block a user