The following commit has been merged in the mc-4.6 branch:
commit adbe38172de077ce943e3de81a954bd7e2fa1b5e
Author: Enrico Weigelt, metux IT service <weig...@metux.de>
Date:   Tue Feb 3 03:21:32 2009 +0100

    added patch from #194

diff --git a/ChangeLog b/ChangeLog
index 6e808b1..2421f92 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -5,6 +5,7 @@
 2009-02-03 Enrico Weigelt, metux ITS <weig...@metux.de>
 
        * lib/mc.lib: added patch on #219 by angel_il
+       * vfs/extfs/u7z: patch from mandriva (#194)
 
 2009-02-01 Enrico Weigelt, metux ITS <weig...@metux.de>
 
diff --git a/vfs/extfs/u7z b/vfs/extfs/u7z
index 0803574..b346d05 100644
--- a/vfs/extfs/u7z
+++ b/vfs/extfs/u7z
@@ -2,6 +2,7 @@
 #
 # extfs support for p7zip
 # Written by Pavel Roskin <pro...@gnu.org>
+# Some Bugfixes/workarounds by Sergiy Niskorodov <s...@mail.zp.ua>
 # Licensed under GNU GPL version 2 or later version.
 
 P7ZIP=7za
@@ -19,7 +20,10 @@ mcu7zip_list ()
 
 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 +35,27 @@ mcu7zip_mkdir ()
 {
        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

-- 
Midnight Commander Development
_______________________________________________
Mc-devel mailing list
http://mail.gnome.org/mailman/listinfo/mc-devel

Reply via email to