/[fuse-comp]/fuse-comp.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /fuse-comp.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 23 by dpavlin, Mon Jul 9 21:41:58 2007 UTC revision 25 by dpavlin, Mon Jul 9 22:44:20 2007 UTC
# Line 28  my $mount = { Line 28  my $mount = {
28          tmp             => '/dev/shm/comp',          tmp             => '/dev/shm/comp',
29  };  };
30    
 my $debug = shift @ARGV;  
   
31  my $skip_extensions_regex = qr/\.(?:sw[a-z]|gif|png|jpeg|jpg|avi|rar|zip|bz2|gz|tgz|avi|mpeg|mpg|tmp|temp)$/i;  my $skip_extensions_regex = qr/\.(?:sw[a-z]|gif|png|jpeg|jpg|avi|rar|zip|bz2|gz|tgz|avi|mpeg|mpg|tmp|temp)$/i;
32    
33  # don't compress files smaller than this  # don't compress files smaller than this
# Line 78  sub gzip_original_size { Line 76  sub gzip_original_size {
76          return unpack("L", $buff);          return unpack("L", $buff);
77  }  }
78    
 sub unlink_all {  
         my $file = shift;  
         warn "# unlink_all( $file )\n";  
   
         my $path = fixup( $file );  
         unlink $path || return 0;  
   
         my $tmp = $mount->{tmp} . '/' . $file;  
         unlink $tmp if ( -e $tmp );  
   
         delete( $pending->{$file} );  
         return 1;  
 }  
   
79  sub x_getattr {  sub x_getattr {
80          my ($file) = fixup(shift);          my ($file) = fixup(shift);
81          my (@list) = lstat($file);          my (@list) = lstat($file);
# Line 209  sub x_read { Line 193  sub x_read {
193    
194  sub x_write {  sub x_write {
195          my ($file,$buf,$off) = @_;          my ($file,$buf,$off) = @_;
196    
197          $pending->{$file}->{write}++;          $pending->{$file}->{write}++;
198          my $rv;          my $rv;
199          my $path = fixup($file);          my $path = fixup($file);
# Line 231  sub x_write { Line 216  sub x_write {
216  sub err { return (-shift || -$!) }  sub err { return (-shift || -$!) }
217    
218  sub x_readlink { return readlink(fixup(shift));         }  sub x_readlink { return readlink(fixup(shift));         }
219  sub x_unlink   { return unlink_all( shift ) ? 0 : -$! }  sub x_unlink   {
220            my $file = shift;
221            my $path = fixup( $file );
222    
223            if ( $file =~ m#\Q/.fuse_hidden\E# ) {
224                    return unlink $path ? 0 : -$1;
225            }
226    
227            warn "# unlink( $file )\n";
228    
229            unlink $path || return 0;
230    
231            my $tmp = $mount->{tmp} . '/' . $file;
232            unlink $tmp if ( -e $tmp );
233    
234            delete( $pending->{$file} );
235            return 0;
236    }
237    
238  sub x_symlink { return symlink(shift,fixup(shift)) ? 0 : -$!; }  sub x_symlink { return symlink(shift,fixup(shift)) ? 0 : -$!; }
239    
# Line 246  sub x_rename { Line 248  sub x_rename {
248    
249          my $tmp = $mount->{tmp} . '/' . $old;          my $tmp = $mount->{tmp} . '/' . $old;
250          if ( -e $tmp ) {          if ( -e $tmp ) {
251                  my $new_tmp = $mount->{tmp} . '/' . $new;                  if ( $new =~ m#\Q/.fuse_hidden\E# ) {
252                  rename $tmp, $new_tmp || confess "can't rename $tmp -> $new_tmp : $!";                          unlink $tmp || confess "can't unlink $tmp for $new\n";
253                    } else {
254                            my $new_tmp = $mount->{tmp} . '/' . $new;
255                            rename $tmp, $new_tmp || confess "can't rename $tmp -> $new_tmp : $!";
256                    }
257          }          }
258    
259          if (defined( $pending->{$old} )) {          if (defined( $pending->{$old} )) {
# Line 256  sub x_rename { Line 262  sub x_rename {
262                  my $path = $pending->{$old}->{path};                  my $path = $pending->{$old}->{path};
263                  $path =~ s/\Q$old\E/$new/;                  $path =~ s/\Q$old\E/$new/;
264                  $pending->{$new}->{path} = $path;                  $pending->{$new}->{path} = $path;
                 $pending->{$old}->{path} = $path;  
265    
266                  #delete( $pending->{$old} );                  delete( $pending->{$old} );
267                    warn "## tweaking pending to ", dump( $pending ) if $debug;
268          }          }
269    
270          return $err;          return $err;
# Line 314  sub x_mknod { Line 320  sub x_mknod {
320    
321  sub x_release {  sub x_release {
322          my ( $file, $mode ) = @_;          my ( $file, $mode ) = @_;
323    
324            if ( $file =~ m#\Q/.fuse_hidden\E# ) {
325                    warn "release internal $file\n" if $debug;
326                    delete( $pending->{$file} );
327                    return 0;
328            }
329    
330          if ( ! defined( $pending->{$file} ) ) {          if ( ! defined( $pending->{$file} ) ) {
331                  warn "release $file, NO PENDING DATA\n";                  warn "release $file, NO PENDING DATA\n";
332                  return 0;                  return 0;

Legend:
Removed from v.23  
changed lines
  Added in v.25

  ViewVC Help
Powered by ViewVC 1.1.26