clean up the lock file properly on even hardlink-not-supported filesystem.
This commit is contained in:
parent
997a64a67b
commit
4353df754f
|
@ -105,6 +105,7 @@ FcAtomicLock (FcAtomic *atomic)
|
|||
#ifdef HAVE_LINK
|
||||
int fd = -1;
|
||||
FILE *f = 0;
|
||||
FcBool no_link = FcFalse;
|
||||
|
||||
strcpy ((char *) atomic->tmp, (char *) atomic->file);
|
||||
strcat ((char *) atomic->tmp, TMP_NAME);
|
||||
|
@ -137,6 +138,7 @@ FcAtomicLock (FcAtomic *atomic)
|
|||
* the hard link. so better try to fallback
|
||||
*/
|
||||
ret = mkdir ((char *) atomic->lck, 0600);
|
||||
no_link = FcTrue;
|
||||
}
|
||||
(void) unlink ((char *) atomic->tmp);
|
||||
#else
|
||||
|
@ -156,8 +158,16 @@ FcAtomicLock (FcAtomic *atomic)
|
|||
if ((long int) (now - lck_stat.st_mtime) > 10 * 60)
|
||||
{
|
||||
#ifdef HAVE_LINK
|
||||
if (unlink ((char *) atomic->lck) == 0)
|
||||
return FcAtomicLock (atomic);
|
||||
if (no_link)
|
||||
{
|
||||
if (rmdir ((char *) atomic->lck) == 0)
|
||||
return FcAtomicLock (atomic);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (unlink ((char *) atomic->lck) == 0)
|
||||
return FcAtomicLock (atomic);
|
||||
}
|
||||
#else
|
||||
if (rmdir ((char *) atomic->lck) == 0)
|
||||
return FcAtomicLock (atomic);
|
||||
|
|
Loading…
Reference in New Issue