use Fuse;
use IO::File;
use POSIX qw(ENOENT ENOSYS EEXIST EPERM O_RDONLY O_RDWR O_APPEND O_CREAT);
-use Fcntl qw(S_ISBLK S_ISCHR S_ISFIFO SEEK_SET);
+use Fcntl qw(S_ISBLK S_ISCHR S_ISFIFO SEEK_SET S_ISREG S_ISFIFO S_IMODE);
my $can_syscall = eval {
require 'syscall.ph'; # for SYS_mknod and SYS_lchown
};
if (!$can_syscall && open my $fh, '<', '/usr/include/sys/syscall.h') {
- local $/ = undef;
my %sys = do { local $/ = undef;
<$fh> =~ m/\#define \s+ (\w+) \s+ (\d+)/gxms;
};
}
}
-my $tmp = -d '/private' ? '/private/tmp' : '/tmp';
-my $tmp_path = "$tmp/fusetest-" . $ENV{LOGNAME};
-if (! -e $tmp_path) {
- mkdir($tmp_path) || die "can't create $tmp_path: $!";
-}
-
-sub fixup { print STDERR "fixup $_[0] from @{[caller]}\n";
- my ($path) = @_;
- return $tmp_path if $path eq '/';
- return $tmp_path . $path;
-}
+sub fixup { return "/tmp/fusetest-" . $ENV{LOGNAME} . shift }
sub x_getattr {
my ($file) = fixup(shift);
# and possibly run the real mknod command.
my ($file, $modes, $dev) = @_;
$file = fixup($file);
- $! = 0;
+ undef $!;
+ if ($^O eq 'freebsd' || $^O eq 'darwin' || $^O eq 'netbsd') {
+ if (S_ISREG($modes)) {
+ open(FILE, '>', $file) || return -$!;
+ print FILE "";
+ close(FILE);
+ return 0;
+ } elsif (S_ISFIFO($modes)) {
+ my ($rv) = POSIX::mkfifo($file, S_IMODE($modes));
+ return $rv ? 0 : -POSIX::errno();
+ }
+ }
syscall(&SYS_mknod,$file,$modes,$dev);
return -$!;
}