1
0
mirror of https://codeberg.org/kiss-community/kiss synced 2025-01-12 22:00:09 -07:00

kiss: Make temporary files unique.

This commit is contained in:
Dylan Araps 2019-06-19 09:20:37 +03:00
parent c740a78ef8
commit 89c449e967

10
kiss
View File

@ -21,7 +21,7 @@ source_type() {
pkg_clean() { pkg_clean() {
rm -rf -- "$mak_dir" "$pkg_dir" \ rm -rf -- "$mak_dir" "$pkg_dir" \
"$cac_dir/manifest" "$cac_dir/tar" "$cac_dir/checksums" "$cac_dir/manifest-$$" "$cac_dir/tar" "$cac_dir/checksums-$$"
} }
pkg_search() { pkg_search() {
@ -85,9 +85,9 @@ pkg_checksum() {
} }
pkg_verify() { pkg_verify() {
pkg_checksum "$cac_dir/checksums" pkg_checksum "$cac_dir/checksums-$$"
cmp -s "$cac_dir/checksums" checksums || cmp -s "$cac_dir/checksums-$$" checksums ||
die "checksum mismatch, run '$kiss checksum $name'." die "checksum mismatch, run '$kiss checksum $name'."
} }
@ -150,7 +150,7 @@ pkg_conflicts() {
# Extract manifest from tarball and strip directories. # Extract manifest from tarball and strip directories.
tar xf "$bin_dir/$pkg" "./var/db/$kiss/$name/manifest" -O | tar xf "$bin_dir/$pkg" "./var/db/$kiss/$name/manifest" -O |
while read -r line; do while read -r line; do
[ "${line%%*/}" ] && printf '%s\n' "$line" >> "$cac_dir/manifest" [ "${line%%*/}" ] && printf '%s\n' "$line" >> "$cac_dir/manifest-$$"
done done
# Compare extracted manifest to all installed manifests. # Compare extracted manifest to all installed manifests.
@ -159,7 +159,7 @@ pkg_conflicts() {
for db in "$sys_db"/*; do for db in "$sys_db"/*; do
[ "$name" = "${db##*/}" ] && continue [ "$name" = "${db##*/}" ] && continue
grep -Fxf "$cac_dir/manifest" "$db/manifest" && grep -Fxf "$cac_dir/manifest-$$" "$db/manifest" &&
die "Package '$name' conflicts with '${db##*/}'." die "Package '$name' conflicts with '${db##*/}'."
done done
} }