Simon Matter wrote, on 26.09.2012 06:58: > I have not used freedup for restoring the hardlinks but I'm interested in > the patch. If it's not big could you post it here?
Sure! attached. I built a RPM based on http://pkgs.repoforge.org/freedup/freedup-1.5.3-1.rf.src.rpm and latest source. But building based on http://www.freedup.org/freedup-1.6-2.src.rpm should work as well. Greetings, Wolfgang -- Wolfgang Breyha <wbre...@gmx.net> | http://www.blafasel.at/ Vienna University Computer Center | Austria
--- freedup-1.6/freedup.c.orig 2011-02-04 08:22:15.000000000 +0100 +++ freedup-1.6/freedup.c 2011-11-11 10:52:24.788733835 +0100 @@ -613,7 +613,7 @@ */ if( mktemp(tmpfilename) == NULL ) { - perror("There is no unique temporory file name."); + perror("There is no unique temporary file name."); } if( dirmtime!=0 ) { @@ -628,7 +628,7 @@ if( lstat(tmpfilename,&tstat) != 0 ) { /* - * The errror needs not to be catched, since it is wanted + * The error needs not to be catched, since it is wanted * that no file exists with the target name */ rename( bname, tmpfilename ); @@ -643,12 +643,23 @@ } if( lnk( symaname, bname ) != 0 ) { - perror("Linking failed."); - } - if( unlink( tmpfilename ) != 0 ) - { - perror("Unlink failed."); - } + // linking failed! try to move original in place again and + // log that fact + fprintf(stderr, "Linking failed. Trying roleback: \"%s\"", bname); + if ( rename( tmpfilename, bname ) != 0 ) + { + // moving old file in place again failed. + // at least log that -v + fprintf(stderr, "unable to rename: \"%s\"", tmpfilename); + } + } + else + // unlink renamed original only of linking was successful + if( unlink( tmpfilename ) != 0 ) + { + // unlinking failed! log that -v + fprintf(stderr, "Unlink failed: \"%s\"", tmpfilename); + } if( (dirmtime!=0) & (gotdirtime!=0) ) { utimecache.actime = dstat.st_atime;
---- Cyrus Home Page: http://www.cyrusimap.org/ List Archives/Info: http://lists.andrew.cmu.edu/pipermail/info-cyrus/ To Unsubscribe: https://lists.andrew.cmu.edu/mailman/listinfo/info-cyrus