From d38ea02d0e4bcdc4e0114567028596f7bcba45b9 Mon Sep 17 00:00:00 2001 From: neilbrown Date: Fri, 30 May 2003 05:16:52 +0000 Subject: new "mountpoint" export option. --- support/misc/mountpoint.c | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 support/misc/mountpoint.c (limited to 'support/misc/mountpoint.c') diff --git a/support/misc/mountpoint.c b/support/misc/mountpoint.c new file mode 100644 index 0000000..6d0f34e --- /dev/null +++ b/support/misc/mountpoint.c @@ -0,0 +1,34 @@ + +/* + * check if a given path is a mountpoint + */ + +#include +#include +#include + +int +is_mountpoint(char *path) +{ + /* Check if 'path' is a current mountpoint. + * Possibly we should also check it is the mountpoint of the + * filesystem holding the target directory, but there doesn't + * seem a lot of point. + * + * We deem it to be a mountpoint if appending a ".." gives a different + * device or the same inode number. + */ + char *dotdot; + struct stat stb, pstb; + + dotdot = malloc(strlen(path)+4); + strcat(strcpy(dotdot, path), "/.."); + if (lstat(path, &stb) != 0 || + lstat(dotdot, &pstb) != 0) + return 0; + + if (stb.st_dev != pstb.st_dev + || stb.st_ino == pstb.st_ino) + return 1; + return 0; +} -- cgit