X-Git-Url: https://git.jankratochvil.net/?a=blobdiff_plain;f=bin%2Fexx;h=8321cf303a1aa28e7e1112dff8bf826ad6f5c064;hb=ff7bc80f098fc3fe911c7ffcf133052ab2de9ac0;hp=d176d27cf5eec88ef3e373844de7e6232ad12a54;hpb=a5353cd23de429635b2f84e15eca0544d8e6ca64;p=nethome.git diff --git a/bin/exx b/bin/exx index d176d27..8321cf3 100755 --- a/bin/exx +++ b/bin/exx @@ -8,43 +8,48 @@ use warnings; use IO::Handle; use Cwd qw(chdir cwd); -use constant FORMAT_TAR_GZ=>'tar xzf $pathname;i=`echo *`;echo "$i"|grep -q " " || test * = $base &&' - .'(mv "$i" "$i".$$;(set +x;mv "$i".$$/* .);rmdir "$i".$$)'; +use constant FORMAT_TAR=>'tar xf $pathname;i=`echo *`;echo "$i"|grep -q " " || test * != $base ||' + .'(mv "$i" "$i".$$;(set +x;mv "$i".$$/* .);rmdir "$i".$$)'; use constant FORMATS=>{ "rpm" =>'rpm2cpio $pathname|cpio -id --quiet', #-v #FIXME: --sparse doesn't work, why? "zip" =>'unzip -Lq $pathname', + "jar" =>'unzip -Lq $pathname', "a" =>'ar x $pathname', "deb" =>'ar x $pathname;' .'for i in *.tar.gz;do j=`basename $i .tar.gz`;mkdir -p $j;cd $j;tar xzf ../$i;cd ..;rm -f $i;done', "arj" =>'unarj x $pathname', - "tar.gz" =>FORMAT_TAR_GZ, + "tar" =>FORMAT_TAR, + "tar.gz" =>do { $_=FORMAT_TAR; s/xf/xzf/; $_; }, "tgz" =>"tar.gz", - "tar.bz2"=>do { $_=FORMAT_TAR_GZ; s/xzf/xjf/; $_; }, + "tar.bz2"=>do { $_=FORMAT_TAR; s/xf/xjf/; $_; }, "tar.bz" =>"tar.bz2", "tbz" =>"tar.bz", + "msi" =>'cabextract -q $pathname', }; die "Syntax: $0 )>..." if !@ARGV; +my @extdirs; my $origdir=cwd; for my $fname (@ARGV) { my @parsed; - for my $fmt (sort { length $a<=>length $b; } keys %{+FORMATS}) { - (my $fmtt=$fmt)=~s/(\W)/\\$1/g; - last if @parsed=$fname=~m#^(.*?)([^/]+)([.=])($fmtt)$#i; + for my $fmt (sort { length $b<=>length $a; } keys %{+FORMATS}) { + last if @parsed=$fname=~m#^(.*?)([^/]+)([.=])(\Q$fmt\E)$#i; } $parsed[3] or die "Extension not found for archive: $fname"; my($path,$base,$ext)=@parsed[0,1,3]; my($pathname)=($parsed[2] eq "=" ? "$path$base" : $fname); - my($cmdtry,$cmd)=($ext); + my($cmdtry,$cmd)=(lc $ext); do { $cmd=$cmdtry; $cmdtry=FORMATS->{$cmdtry}; } while ($cmdtry); -r $pathname && !-d $pathname or die "Archive not readable: $pathname"; my($extdir)=(-e $base && !-d $base ? "$base.dir" : $base); - -d $extdir or mkdir $extdir or die "Unable to create directory \"$extdir\": $!"; + # Extraction-overwriting cowardly not supported: + # -d $extdir or ... + mkdir $extdir or die "Unable to create directory \"$extdir\": $!"; chdir $extdir or die "Unable to chdir to \"$extdir\": $!"; $pathname="../$pathname" if $pathname!~m#^/#; $path ="../$path" if $path !~m#^/#; @@ -63,8 +68,10 @@ for my $fname (@ARGV) { print "\t$extdir/:\n"; STDOUT->flush(); my $rc; $rc=system $cmd and die "$cmd (rc=".($rc>>8)."): $!"; + push @extdirs,$extdir; } continue { chdir $origdir; } +print "extdir=".$extdirs[0]."\n" if 1==@extdirs; exit 0;