1
0
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:
phoebos 2022-11-30 11:10:28 +00:00
parent d240830906
commit 02c254e388
No known key found for this signature in database

52
kiss
View File

@ -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"