kiss: put all temporary files in their own directory

This commit is contained in:
Dylan Araps 2021-07-16 10:46:33 +03:00
parent 6555df6209
commit d1ba479458
No known key found for this signature in database
GPG Key ID: 13295DAC2CF13B5C

38
kiss
View File

@ -53,7 +53,7 @@ tmp_file() {
# for access by the caller (allowing 3 files at once). # for access by the caller (allowing 3 files at once).
_tmp_file_pre_pre=$_tmp_file_pre _tmp_file_pre_pre=$_tmp_file_pre
_tmp_file_pre=$_tmp_file _tmp_file_pre=$_tmp_file
_tmp_file=$mak_dir/.$pid-$1-$2 _tmp_file=$tmp_dir/$pid-$1-$2
: > "$_tmp_file" || : > "$_tmp_file" ||
die "$1" "Failed to create temporary file" die "$1" "Failed to create temporary file"
@ -395,15 +395,17 @@ pkg_extract_tar_hack() {
# This is a portable shell implementation of GNU tar's # This is a portable shell implementation of GNU tar's
# '--strip-components 1'. Use of this function denotes a # '--strip-components 1'. Use of this function denotes a
# performance penalty. # performance penalty.
decompress "$2" > "$tmp_dir/ktar" || tmp_file "$1" tarball
decompress "$2" > "$_tmp_file" ||
die "$1" "Failed to decompress $2" die "$1" "Failed to decompress $2"
tar xf "$tmp_dir/ktar" || tar xf "$_tmp_file" ||
die "$1" "Failed to extract $2" die "$1" "Failed to extract $2"
# Iterate over all directories in the first level of the # Iterate over all directories in the first level of the
# tarball's manifest. # tarball's manifest.
tar tf "$tmp_dir/ktar" | while IFS=/ read -r dir _; do tar tf "$_tmp_file" | while IFS=/ read -r dir _; do
# Skip the directory if seen before. # Skip the directory if seen before.
! contains "$_seen" "$dir" || continue && _seen="$_seen $dir" ! contains "$_seen" "$dir" || continue && _seen="$_seen $dir"
@ -437,6 +439,9 @@ pkg_extract_tar_hack() {
# as we may leave files in here if any were copied. # as we may leave files in here if any were copied.
rm -rf "$pid-$dir" rm -rf "$pid-$dir"
done done
# Remove the tarball now that we are done with it.
rm -f "$_tmp_file"
} }
pkg_extract() { pkg_extract() {
@ -605,6 +610,8 @@ pkg_fix_deps() {
: >> depends : >> depends
tmp_file "${PWD##*/}" fix-depends
find "$pkg_dir/${PWD##*/}/" -type f 2>/dev/null | find "$pkg_dir/${PWD##*/}/" -type f 2>/dev/null |
while read -r _fix_file; do while read -r _fix_file; do
@ -655,12 +662,12 @@ pkg_fix_deps() {
done <<EOF || : done <<EOF || :
$elf_buf $elf_buf
EOF EOF
done | sort -uk1,1 depends - > "$tmp_dir/.fixdeps" done | sort -uk1,1 depends - > "$_tmp_file"
# If the depends file was modified, show a diff and replace it. # If the depends file was modified, show a diff and replace it.
if [ -s "$tmp_dir/.fixdeps" ]; then if [ -s "$_tmp_file" ]; then
diff -U 3 depends - < "$tmp_dir/.fixdeps" 2>/dev/null || : diff -U 3 depends - < "$_tmp_file" 2>/dev/null || :
mv -f "$tmp_dir/.fixdeps" depends mv -f "$_tmp_file" depends
pkg_manifest "${PWD##*/}" pkg_manifest "${PWD##*/}"
else else
rm -f depends rm -f depends
@ -1679,7 +1686,7 @@ pkg_clean() {
0-0) 0-0)
# If we are exiting the top-level package manager process, wipe # If we are exiting the top-level package manager process, wipe
# the entire temporary directory. # the entire temporary directory.
rm -rf "$tmp_dir" rm -rf "$proc"
;; ;;
0-*) 0-*)
@ -1882,16 +1889,17 @@ create_tmp_dirs() {
bin_dir=$cac_dir/bin bin_dir=$cac_dir/bin
# Top-level Temporary cache directory. # Top-level Temporary cache directory.
tmp_dir=${KISS_TMPDIR:="$cac_dir/proc"} proc=${KISS_TMPDIR:="$cac_dir/proc"}
tmp_dir=${tmp_dir%"${tmp_dir##*[!/]}"}/$pid proc=${proc%"${proc##*[!/]}"}/$pid
# Temporary cache directories. # Temporary cache directories.
mak_dir=$tmp_dir/build mak_dir=$proc/build
pkg_dir=$tmp_dir/pkg pkg_dir=$proc/pkg
tar_dir=$tmp_dir/extract tar_dir=$proc/extract
tmp_dir=$proc/tmp
mkdir -p "$src_dir" "$log_dir" "$bin_dir" \ mkdir -p "$src_dir" "$log_dir" "$bin_dir" \
"$mak_dir" "$pkg_dir" "$tar_dir" "$mak_dir" "$pkg_dir" "$tar_dir" "$tmp_dir"
} }
main() { main() {