Add support for /etc/filesystem when searching for an "auto" filesystem

This is bug #1246
This commit is contained in:
Robert Griebl 2002-07-24 01:41:30 +00:00
parent 31a2e20bd3
commit 2a4a8d8ffb

View File

@ -272,7 +272,42 @@ mount_one(char *blockDevice, char *directory, char *filesystemType,
#else #else
if (strcmp(filesystemType, "auto") == 0) { if (strcmp(filesystemType, "auto") == 0) {
char buf[255]; char buf[255];
FILE *f = xfopen("/proc/filesystems", "r"); FILE *f;
int read_proc = 0;
f = fopen ( "/etc/filesystems", "r" );
if ( f ) {
while ( fgets ( buf, sizeof( buf ), f )) {
if ( *buf == '*' )
read_proc = 1;
else if ( *buf == '#' )
continue;
else {
filesystemType = buf;
// Add NULL termination to each line
while (*filesystemType && !isspace ( *filesystemType ))
filesystemType++;
*filesystemType = '\0';
filesystemType = buf;
if ( xstrlen ( filesystemType )) {
status = do_mount(blockDevice, directory, filesystemType,
flags | MS_MGC_VAL, string_flags,
useMtab, fakeIt, mtab_opts, mount_all);
if (status)
break;
}
}
}
fclose ( f );
}
if (( !f || read_proc ) && !status ) {
f = xfopen("/proc/filesystems", "r");
while (fgets(buf, sizeof(buf), f) != NULL) { while (fgets(buf, sizeof(buf), f) != NULL) {
filesystemType = buf; filesystemType = buf;
@ -293,6 +328,7 @@ mount_one(char *blockDevice, char *directory, char *filesystemType,
break; break;
} }
} }
}
fclose(f); fclose(f);
} }
#endif #endif