Diskspace check changed for FreeBSD and NetBSD
This commit is contained in:
parent
54df4da730
commit
3d96ef57b7
@ -4284,6 +4284,8 @@ v0.33.19 26-Oct-2001
|
|||||||
The nodelist information now also holds the Txx flags.
|
The nodelist information now also holds the Txx flags.
|
||||||
The mkdirs function now needs a mode parameter for directory
|
The mkdirs function now needs a mode parameter for directory
|
||||||
creation.
|
creation.
|
||||||
|
The filesystem space check is now reliable on FreeBSD and
|
||||||
|
NetBSD.
|
||||||
|
|
||||||
lang:
|
lang:
|
||||||
Changed language prompts 6, 71, 429.
|
Changed language prompts 6, 71, 429.
|
||||||
|
50
lib/mbfile.c
50
lib/mbfile.c
@ -260,26 +260,29 @@ int mkdirs(char *name, mode_t mode)
|
|||||||
*/
|
*/
|
||||||
int diskfree(int needed)
|
int diskfree(int needed)
|
||||||
{
|
{
|
||||||
|
int RetVal = TRUE;
|
||||||
|
struct statfs sfs;
|
||||||
|
unsigned long temp;
|
||||||
|
#if defined(__linux__)
|
||||||
char *mtab, *dev, *fs, *type;
|
char *mtab, *dev, *fs, *type;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
struct statfs sfs;
|
#elif defined(__FreeBSD__) || defined(__NetBSD__)
|
||||||
int RetVal = TRUE;
|
struct statfs *mntbuf;
|
||||||
unsigned long temp;
|
long mntsize;
|
||||||
|
int i;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (! needed)
|
if (! needed)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
mtab = calloc(PATH_MAX, sizeof(char));
|
#if defined(__linux__)
|
||||||
#ifdef __linux__
|
|
||||||
if ((fp = fopen((char *)"/etc/mtab", "r")) == 0) {
|
if ((fp = fopen((char *)"/etc/mtab", "r")) == 0) {
|
||||||
WriteError("$Can't open /etc/mtab");
|
WriteError("$Can't open /etc/mtab");
|
||||||
#elif __FreeBSD__ || __NetBSD__
|
|
||||||
if ((fp = fopen((char *)"/etc/fstab", "r")) == 0) {
|
|
||||||
WriteError("$Can't open /etc/fstab");
|
|
||||||
#endif
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mtab = calloc(PATH_MAX, sizeof(char));
|
||||||
while (fgets(mtab, PATH_MAX, fp)) {
|
while (fgets(mtab, PATH_MAX, fp)) {
|
||||||
dev = strtok(mtab, " \t");
|
dev = strtok(mtab, " \t");
|
||||||
fs = strtok(NULL, " \t");
|
fs = strtok(NULL, " \t");
|
||||||
@ -291,7 +294,6 @@ int diskfree(int needed)
|
|||||||
*/
|
*/
|
||||||
if (strncmp((char *)"/dev/fd", dev, 7) && strncmp((char *)"/boot", fs, 5) &&
|
if (strncmp((char *)"/dev/fd", dev, 7) && strncmp((char *)"/boot", fs, 5) &&
|
||||||
(!strncmp((char *)"ext2", type, 4) || !strncmp((char *)"reiserfs", type, 8) ||
|
(!strncmp((char *)"ext2", type, 4) || !strncmp((char *)"reiserfs", type, 8) ||
|
||||||
!strncmp((char *)"ufs", type, 3) || !strncmp((char *)"ffs", type, 3) ||
|
|
||||||
!strncmp((char *)"vfat", type, 4) || !strncmp((char *)"msdos", type, 5))) {
|
!strncmp((char *)"vfat", type, 4) || !strncmp((char *)"msdos", type, 5))) {
|
||||||
if (statfs(fs, &sfs) == 0) {
|
if (statfs(fs, &sfs) == 0) {
|
||||||
temp = (unsigned long)(sfs.f_bsize / 512L);
|
temp = (unsigned long)(sfs.f_bsize / 512L);
|
||||||
@ -307,6 +309,34 @@ int diskfree(int needed)
|
|||||||
fclose(fp);
|
fclose(fp);
|
||||||
free(mtab);
|
free(mtab);
|
||||||
|
|
||||||
|
#elif defined(__FreeBSD__) || defined(__NetBSD__)
|
||||||
|
|
||||||
|
if ((mntsize = getmntinfo(&mntbuf, MNT_NOWAIT)) == 0) {
|
||||||
|
WriteError("Huh, no filesystems mounted??");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < mntsize; i++) {
|
||||||
|
/*
|
||||||
|
* Don't check kernfs (NetBSD) and procfs (FreeBSD), floppy and CD.
|
||||||
|
*/
|
||||||
|
if ((strncmp(mntbuf[i].f_fstypename, (char *)"kernfs", 6)) &&
|
||||||
|
(strncmp(mntbuf[i].f_fstypename, (char *)"procfs", 6)) &&
|
||||||
|
(strncmp(mntbuf[i].f_fsfromname, (char *)"/dev/fd", 7)) &&
|
||||||
|
(strncmp(mntbuf[i].f_fstypename, (char *)"cd9660", 6)) &&
|
||||||
|
(strncmp(mntbuf[i].f_fstypename, (char *)"msdos", 5)) &&
|
||||||
|
(statfs(mntbuf[i].f_mntonname, &sfs) == 0)) {
|
||||||
|
temp = (unsigned long)(sfs.f_bsize / 512L);
|
||||||
|
if (((unsigned long)(sfs.f_bavail * temp) / 2048L) < needed) {
|
||||||
|
RetVal = FALSE;
|
||||||
|
WriteError("On \"%s\" only %d kb left, need %d kb", mntbuf[i].f_mntonname,
|
||||||
|
(sfs.f_bavail * sfs.f_bsize) / 1024, needed * 1024);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
return RetVal;
|
return RetVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user