If statvfs() fails don't consider this a critical error; compute free space correctly.

This commit is contained in:
Juan RP 2014-07-14 10:09:34 +02:00
parent 38aba4ce60
commit 607f01b2f5

View File

@ -171,10 +171,10 @@ compute_transaction_stats(struct xbps_handle *xhp)
/* Get free space from target rootdir: return ENOSPC if there's not enough space */ /* Get free space from target rootdir: return ENOSPC if there's not enough space */
if (statvfs(xhp->rootdir, &svfs) == -1) { if (statvfs(xhp->rootdir, &svfs) == -1) {
xbps_dbg_printf(xhp, "%s: statvfs failed: %s\n", __func__, strerror(errno)); xbps_dbg_printf(xhp, "%s: statvfs failed: %s\n", __func__, strerror(errno));
return EINVAL; return 0;
} }
/* compute free space on disk */ /* compute free space on disk */
rootdir_free_size = svfs.f_bfree * svfs.f_bsize - instsize; rootdir_free_size = svfs.f_bavail * svfs.f_bsize - instsize;
if (!xbps_dictionary_set_uint64(xhp->transd, if (!xbps_dictionary_set_uint64(xhp->transd,
"disk-free-size", rootdir_free_size)) "disk-free-size", rootdir_free_size))