blob: e91b947fc6f885e87883284def911d89203071cb [file] [log] [blame]
/*
* Copyright (c) 2000-2001,2005 Silicon Graphics, Inc.
* All Rights Reserved.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include <xfs/libxfs.h>
#include <disk/fstyp.h>
/*
* fstyp allows the user to determine the filesystem identifier of
* mounted or unmounted filesystems using heuristics.
*
* The filesystem type is required by mount(2) and sometimes by mount(8)
* to mount filesystems of different types. fstyp uses exactly the same
* heuristics that mount does to determine whether the supplied device
* special file is of a known filesystem type. If it is, fstyp prints
* on standard output the usual filesystem identifier for that type and
* exits with a zero return code. If no filesystem is identified, fstyp
* prints "Unknown" to indicate failure and exits with a non-zero status.
*
* WARNING: The use of heuristics implies that the result of fstyp is not
* guaranteed to be accurate.
*/
int
main(int argc, char *argv[])
{
char *type;
if (argc != 2) {
fprintf(stderr, "Usage: %s <device>\n", basename(argv[0]));
exit(1);
}
if (access(argv[1], R_OK) < 0) {
perror(argv[1]);
exit(1);
}
if ((type = fstype(argv[1])) == NULL) {
printf("Unknown\n");
exit(1);
}
printf("%s\n", type);
exit(0);
}