diff -Naur mc.old/vfs/extfs/u7z mc/vfs/extfs/u7z --- mc.old/vfs/extfs/u7z 2005-06-22 05:21:43.000000000 +0300 +++ mc/vfs/extfs/u7z 2006-06-24 01:57:26.000000000 +0300 @@ -2,9 +2,11 @@ # # extfs support for p7zip # Written by Pavel Roskin +# Some Bugfixes/workarounds by Sergiy Niskorodov # Licensed under GNU GPL version 2 or later version. -P7ZIP=7za +P7ZIP=`which 7z` || \ +P7ZIP=`which 7za` mcu7zip_list () { @@ -19,7 +21,10 @@ mcu7zip_copyout () { - $P7ZIP e -so "$1" "$2" > "$3" 2>/dev/null + #first we check if we have old p7zip archive with prefix ./ in filename + $P7ZIP l "$1" "$2" | grep -q "0 files" && \ + EXFNAME=*./"$2" || EXFNAME="$2" + $P7ZIP e -so "$1" "$EXFNAME" > "$3" 2>/dev/null } mcu7zip_copyin () @@ -31,19 +36,27 @@ { dir=`mktemp -d "${MC_TMPDIR:-/tmp}/mctmpdir-u7z.XXXXXX"` || exit 1 mkdir -p "$dir"/"$2" - $P7ZIP a -w"$dir" "$1" "$2" >/dev/null 2>&1 + $P7ZIP a -w"$dir" "$1" "$dir"/"$2" >/dev/null 2>&1 rm -rf "$dir" } mcu7zip_rm () { # NOTE: Version 4.20 fails to delete files in subdirectories - $P7ZIP d "$1" "$2" >/dev/null 2>&1 + #first we check if we have old p7zip archive with prefix ./ in filename + $P7ZIP l "$1" "$2" | grep -q "0 files" && \ + EXFNAME=*./"$2" || EXFNAME="$2" + $P7ZIP d "$1" "$EXFNAME" 2>&1 | grep -q E_NOTIMPL &> /dev/null && \ + { echo -e "Function not implemented...\n7z cannot delete from solid archive." >&2 ; exit 1 ; } } mcu7zip_rmdir () { - $P7ZIP d "$1" "$2"/ >/dev/null 2>&1 + #first we check if we have old p7zip archive with prefix ./ in filename + $P7ZIP l "$1" "$2" | grep -q "0 files" && \ + EXFNAME=*./"$2" || EXFNAME="$2" + $P7ZIP d "$1" "$EXFNAME"/ 2>&1 | grep -q E_NOTIMPL &> /dev/null && \ + { echo -e "Function not implemented...\n7z cannot delete from solid archive." >&2 ; exit 1 ; } } # override any locale for dates