The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

POSIX::2008 - Perl interface to POSIX.1-2008

SYNOPSIS

use POSIX::2008 qw(:fcntl openat pwrite);

sysopen my $dh, '/tmp', O_RDONLY|O_DIRECTORY|O_NOFOLLOW or die 'Dafuq?';
my $fh = openat($dh, 'foobar', O_RDWR|O_CREAT);
pwrite($fh, 'fuckyounsa', 10, 0);

DESCRIPTION

POSIX::2008 contains many of the interfaces specified by POSIX.1-2008 that the core POSIX module withholds, implements in Perl or fucked up.

This module is provided "as is" unless someone volunteers to maintain it.

FILE DESCRIPTORS AND HANDLES

Since version 0.05, all I/O functions that take numeric file descriptors also accept Perl file or directory handles.

SYSTEM CALL RETURN VALUES

A system call return value of -1 meaning "error" is mapped to undef.

A system call return value of 0 meaning "success" is mapped to "0 but true".

For system calls where 0 does not just mean "success", 0 is returned unchanged. These are open(), read(), write(), readv(), writev(), pread(), pwrite(), preadv(), pwritev(), getpriority. openat() gets a special treatment in this regard, see below.

FUNCTIONS

a64l

l = a64l(s);

abort

abort();

abs

ui = abs(i);

access

ret = access(path, mode);

acos

y = acos(x);

acosh

y = acosh(x);

alarm

remaining_sec = alarm(sec);

asin

y = asin(x);

asinh

y = asinh(x);

atan2

z = atan2(y, x);

atan

y = atan(x);

atanh

y = atanh(x);

atof

f = atof(s);

atoi

i = atoi(s);

Calls atoll(), atol(), or atoi(), whichever is the maximum available on your system. This is of course silly because you could just use int().

basename

s = basename(path);

cabs

r = cabs(re, im);

cacos

(re, im) = cacos(re, im);

cacosh

(re, im) = cacosh(re, im);

carg

phi = carg(re, im);

casinh

(re, im) = casinh(re, im);

catan

(re, im) = catan(re, im);

catanh

(re, im) = catanh(re, im);

catclose

ret = catclose(catd);

catgets

s = catgets(catd, set_id, msg_id, dflt_string);

catopen

catd = catopen(name, flag);

cbrt

y = cbrt(x);

ccos

(re, im) = ccos(re, im);

ccosh

(re, im) = ccosh(re, im);

ceil

y = ceil(x);

cexp

(re, im) = cexp(re, im);

chdir

ret = chdir(dir);

dir can be a path, a Perl file handle or a file descriptor.

chmod

ret = chmod(what, mode);

what can be a path, a Perl file handle or a file descriptor.

chown

ret = chown(what, uid, gid);

what can be a path, a Perl file handle or a file descriptor.

cimag

im = cimag(re, im);

clock

t = clock()

clock_getcpuclockid

clock_id = clock_getcpuclockid(pid);

pid defaults to $$. Returns undef on error.

clock_getres

(sec, nsec) = clock_getres(clock_id);

clock_id defaults to CLOCK_REALTIME. Returns empty list on error.

clock_gettime

(sec, nsec) = clock_gettime(clock_id);

clock_id defaults to CLOCK_REALTIME. Returns empty list on error.

clock_nanosleep

(rem_sec, rem_nsec) = clock_nanosleep(clock_id, flags, sec, nsec);

In scalar context returns the remaining seconds as a floating point number.

clock_settime

ret = clock_settime(clock_id, sec, nsec);

clog

(re, im) = clog(re, im);

close

ret = close(fd);

confstr

s = confstr(name);

name is one of the _CS_ integer constants.

conj

(re, im) = conj(re, im);

copysign

xs = copysign(x, y);

cos

y = cos(x);

cosh

y = cosh(x);

cpow

(re, im) = cpow(re_x, im_x, re_y, im_y);

cproj

(re, im) = cproj(re, im);

creal

re = creal(re, im);

csin

(re, im) = csin(re, im);

csinh

(re, im) = csinh(re, im);

csqrt

(re, im) = csqrt(re, im);

ctan

(re, im) = ctan(re, im);

ctanh

(re, im) = ctanh(re, im);

dirname

name = dirname(path);

div

(quot, rem) = div(numer, denom);

Calls lldiv(), ldiv(), or div(), whichever is the maximum supported by your system.

dlclose

dlclose(dlhandle);

dlerror

dlerror();

dlopen

dlhandle = dlopen(file, mode);

dlsym

addr = dlsym(dlhandle, name);

drand48

r = drand48();

endutxent

endutxent();

erand48

(r, X0, X1, X2) = erand48(X0, X1, X2);

erf

y = erf(x);

erfc

y = erfc(x);

exp

y = exp(x);

exp2

y = exp2(x);

expm1

y = expm1(x);

faccessat

ret = faccessat(dirfd, path, amode, flags=0);

flags is the bitwise OR of zero or more of AT_EACCESS, AT_SYMLINK_NOFOLLOW.

fchmodat

ret = fchmodat(dirfd, path, mode, flags=0);

flags can be 0 or AT_SYMLINK_NOFOLLOW.

fchownat

ret = fchownat(dirfd, path, uid, gid, flags=0);

flags can be 0 or AT_SYMLINK_NOFOLLOW.

fdatasync

ret = fdatasync(fd);

fdopen

ret = fdopen(fd, mode)

Returns a file handle associated with the file descriptor fd or undef on error. mode is one of the values "r", "w", "a" with an optional "+" and/or "b".

It's similar to IO::Handle::new_from_fd() with the following improvements:

  • It really calls fdopen(3).

  • It expects POSIX mode strings (e.g. "r", not "<").

  • It fails if mode is not compatible with the flags of fd.

fdopendir

ret = fdopendir(fd)

Returns a directory handle associated with the file descriptor fd or undef on error. Usage example:

my $dh = do {
  sysopen my $fh, '/tmp', O_RDONLY|O_DIRECTORY|O_NOFOLLOW;
  fdopendir($fh); # or fdopendir(fileno $fh) but the former also works
                  # with handles from opendir() for which fileno does
                  # not work before Perl 5.22
};
my @files = readdir $dh;  # this would fail with $fh from sysopen
fdim

d = fdim(double x, double y);

fegetround

round = fegetround();

fesetround

ret = fesetround(round);

ffs

pos = ffs(i);

Calls ffsll(), ffsl(), or ffs(), whichever is the maximum available on your system.

floor

y = floor(x);

fma

r = fma(x, y, z);

fmax

m = fmax(x, y);

fmin

m = fmin(x, y);

fmod

m = fmod(x, y);

fnmatch

ret = fnmatch(pattern, string, flags);

Returns 0 if string matches pattern, FNM_NOMATCH if there is no match, undef if there is an error.

flags is the bitwise OR of zero or more of FNM_NOESCAPE, FNM_PATHNAME, FNM_PERIOD, FNM_FILE_NAME, FNM_LEADING_DIR, FNM_CASEFOLD.

fpclassify

fpclassify(x);

Returns one of FP_NAN, FP_INFINITE, FP_ZERO, FP_SUBNORMAL, FP_NORMAL.

fstatat

(dev, ino, mode, nlink, uid, gid, rdev, size, atim_sec, mtim_sec, ctim_sec, blksize, blocks, atim_nsec, mtim_nsec, ctim_nsec) = fstatat(dirfd, path, flags = 0);

flags is the bitwise OR of zero or more of AT_SYMLINK_NOFOLLOW, AT_NO_AUTOMOUNT.

See stat() for notes on the return values and bugs in CORE::stat().

Returns an empty list on error.

fsync

ret = fsync(fd);

futimens

ret = futimens(fd, atime_sec, atime_nsec, mtime_sec, mtime_nsec);

atime_sec and mtime_sec default to 0, atime_nsec and mtime_nsec default to UTIME_NOW.

getdate

(sec, min, hour, mday, mon, year, wday, yday, isdst) = getdate(string);

getdate_err

getdate_err() returns the value of the getdate_err variable.

getegid

egid = getegid();

geteuid

euid = geteuid();

getgid

gid = getgid();

gethostid

hostid = gethostid();

gethostname

hostname = gethostname();

getitimer

(int_sec, int_usec, val_sec, val_usec) = getitimer(which);

which is one of ITIMER_REAL, ITIMER_VIRTUAL, ITIMER_PROF.

getpriority

prio = getpriority(which=PRIO_PROCESS, who=0);

which can be one of PRIO_PROCESS, PRIO_PGRP, PRIO_USER, defaults to PRIO_PROCESS. who defaults to 0.

Returns undef on error.

getsid

sid = getsid(pid);

pid defaults to 0.

getuid

uid = getuid();

getutxent

(user, id, line, pid, type, sec, usec) = getutxent();

getutxent() reads a line from the current file position in the utmp file.

getutxid

(user, id, line, pid, type, sec, usec) = getutxid(ut_type, ut_id);

getutxid() searches forward from the current file position in the utmp file based upon ut_type and ut_id. If ut_type is one of RUN_LVL, BOOT_TIME, NEW_TIME, or OLD_TIME, getutxid() will find the first entry whose ut_type field matches ut_type. If ut_type is one of INIT_PROCESS, LOGIN_PROCESS, USER_PROCESS, or DEAD_PROCESS, getutxid() will find the first entry whose ut_id field matches ut_id.

getutxline

(user, id, line, pid, type, sec, usec) = getutxline(ut_line);

getutxline() searches forward from the current file position in the utmp file. It scans entries whose ut_type is USER_PROCESS or LOGIN_PROCESS and returns the first one whose ut_line field matches ut_line.

hypot

r = hypot(x, y);

ilogb

y = ilogb(x);

isalnum

Like POSIX::isalnum() but returns 0 for the empty string.

isalpha

Like POSIX::isalpha() but returns 0 for the empty string.

isascii

POSIX.1-2008 marks it as obsolete, but we include it anyway.

isatty

ret = isatty(fd)

isblank

ret = isblank(charstring)

Returns 1 if charstring consists only of blank characters (i.e. spaces and/or tabs). Returns 0 otherwise (also for the empty string).

iscntrl

Like POSIX::iscntrl() but returns 0 for the empty string.

isdigit

Like POSIX::isdigit() but returns 0 for the empty string.

isfinite

isfinite(x);

isgraph

Like POSIX::isgraph() but returns 0 for the empty string.

isinf

isinf(x);

islower

Like POSIX::islower() but returns 0 for the empty string.

isnan

isnan(x);

isnormal

isnormal(x);

isprint

Like POSIX::isprint() but returns 0 for the empty string.

ispunct

Like POSIX::ispunct() but returns 0 for the empty string.

isspace

Like POSIX::isspace() but returns 0 for the empty string.

isupper

Like POSIX::isupper() but returns 0 for the empty string.

isxdigit

Like POSIX::isxdigit() but returns 0 for the empty string.

j0

y = j0(x);

j0() is the Bessel function of the first kind of order 0.

j1

y = j1(x);

j1() is the Bessel function of the first kind of order 1.

jn

y = jn(n, x);

jn() is the Bessel function of the first kind of order n.

jrand48

(r, X0, X1, X2) = jrand48(X0, X1, X2);

killpg

ret = killpg(pgrp, sig);

l64a

s = l64a(n);

lchown

ret = lchown(path, uid, gid)

ldexp

y = ldexp(x, exp);

lgamma

y = lgamma(x);

ret = link(path1, path2);

linkat

ret = linkat(fd1, path1, fd2, path2, flags=0);

flags can be 0 or AT_SYMLINK_FOLLOW.

log1p

y = log1p(x);

log2

y = log2(x);

logb

y = logb(x);

lrand48

r = lrand48();

lround

l = lround(x)

Calls llround() or lround() whichever is the maximum available on your system. If the rounded value is outside Perl's internal signed integer range, it is returned as a string. If the rounded value is too large to be stored in a long long or long, undef is returned.

lstat

(dev, ino, mode, nlink, uid, gid, rdev, size, atim_sec, mtim_sec, ctim_sec, blksize, blocks, atim_nsec, mtim_nsec, ctim_nsec) = lstat(path);

path is assumed to be a string (or will be converted to a string).

See stat() for notes on the return values and bugs in CORE::stat().

Returns an empty list on error.

mkdir

ret = mkdir(path, [mode = 0777]);

mkdirat

ret = mkdirat(fd, path, mode);

mkdtemp

name = mkdtemp(template);

mkfifo

ret = mkfifo(path, mode);

mkfifoat

ret = mkfifoat(fd, path, mode);

mknod

ret = mknod(path, mode, dev);

mknodat

ret = mknodat(fd, path, mode, dev);

mkstemp

(fd, name) = mkstemp(template);

mrand48

mrand48();

nanosleep

(rem_sec, rem_nsec) = nanosleep(sec, nsec);

In scalar context returns the remaining seconds as a floating point number.

nearbyint

y = nearbyint(x);

nextafter

z = nextafter(x, y);

nexttoward

z = nexttoward(x, y);

Not implemented because y is a long double and Perl doesn't support that type. Besides that, nexttoward() is equivalent to nextafter.

nrand48

r = nrand48()

open

ret = open(path, flags=O_RDONLY, mode=0666);

openat

ret = openat(fd, path, flags=O_RDONLY, mode=0666);

If fd is numeric (i.e. a file descriptor), openat() returns a file descriptor. If fd is a file or directory handle, the return value is also a handle whose type depends on the file type of path: If path is a directory, the return value is a directory handle, otherwise it's a file handle.

To get a handle even for the special fd value AT_FDCWD (which is numeric), you can pass a reference to that value instead, i.e. openat(\AT_FDCWD, ...).

Returns undef on error.

openat2

ret = openat2(fd, path, how)

The openat2() system call is an extension of openat() and provides a superset of its functionality. It is Linux-specific and thus not part of POSIX, but we include it anyway.

The how parameter is a hash reference corresponding to the struct open_how. It currently supports the keys flags, mode and resolve. Missing keys are treated as having a zero value.

Example:

my $fh = openat2(
  \AT_FDCWD, '/foobar',
  {flags => O_RDWR|O_CREAT, mode => 0600, resolve => RESOLVE_IN_ROOT}
);

Note that, unlike open() or openat(), openat2() is very picky about flags and mode. See the manpage for details.

Returns undef on error.

posix_fadvise

ret = posix_fadvise(fd, offset, len, advice);

advice is one of the POSIX_FADV_ constants.

Returns undef on error

posix_fallocate

ret = posix_fallocate(fd, offset, len);

pread

bytes_read = pread(fd, buf, count, [offset, buf_offset]);

pread() reads count bytes (not characters) of data from the file descriptor fd at file offset offset into the scalar buf without changing the file offset. buf will be enlarged automatically if necessary.

offset and buf_offset are set to 0 if omitted or undef.

pread() treats buf just like sysread() does: buf_offset may be specified to place the read data at that position in buf. If buf_offset is past the end of buf, buf will be padded with zeros before appending the data. If buf_offset is negative, it is counted from the end of the string. buf will be grown or shrunk so that the last byte actually read is the last byte of buf after the read.

Returns the number of bytes read, 0 at EOF, undef on error.

preadv

bytes_read = preadv(fd, buffers, sizes, [offset])

preadv() behaves like readv() but adds an optional offset argument, which specifies the file position at which the data is to be read. offset is set to 0 if omitted or undef.

The file offset is not changed by this system call. The file referred to by fd must be capable of seeking.

ptsname

name = ptsname(fd);

pwrite

bytes_written = pwrite(fd, buf, [count, offset, buf_offset]);

pwrite() writes count bytes of data from the scalar buf to the file descriptor fd at file offset offset without changing the file offset. The file referenced by fd must be capable of seeking.

If count is omitted or undef, everything from buf_offset up to the end of buf is written.

buf_offset may be specified to write data from that position in buf. If buf_offset is negative it is counted from the end of the string.

offset and buf_offset are set to 0 if omitted or undef.

Returns the number of bytes written, undef on error.

On Linux, if a file is opened with O_APPEND, pwrite() appends data to the end of the file, regardless of the value of offset (in violation of POSIX).

pwritev

bytes_written = pwritev(fd, buffers, [offset])

pwritev() behaves like writev() but adds an optional offset argument, which specifies the file position at which the data is to be written. offset is set to 0 if omitted or undef.

The file offset is not changed by this system call. The file referred to by fd must be capable of seeking.

On Linux, if a file is opened with O_APPEND, pwritev() appends data to the end of the file, regardless of the value of offset (in violation of POSIX).

random

r = random();

read

bytes_read = read(fd, buf, count);

Like POSIX::read() but returns 0 at EOF instead of "0 but true".

readv

bytes_read = readv(fd, buffers, sizes);

Example:

my $fh = openat(\AT_FDCWD, '/tmp/foobar', O_RDWR|O_CREAT|O_TRUNC);
pwrite($fh, 'foobar', 6, 0);
readv($fh, my @buf, [4, 0, 4, 4]);
# -> @buf is ('foob', '', 'ar')

readv() reads from the file descriptor fd into buffers as many strings as there are elements in sizes.

buffers must be a variable holding either an array or an array reference, i.e. @buf or <$buf>.

sizes must be an array reference, i.e. \@sizes, $sizes, or [...].

sizes is expected to hold unsigned integers that specify how many bytes are to be read into each buffer. A byte count of 0 or undef creates an empty string. sizes is processed in array order.

buffers will be extended if necessary, but it will never be shrunk. If buffers is not empty, any existing elements are replaced as long as sufficient data was read from fd.

If the total byte count of sizes exceeds the number of bytes actually read from fd, there may be one partly filled buffer and the rest of sizes is skipped, so you may end up with less strings in buffers than there are elements in sizes.

readv() returns the number of bytes read (which may be less than the total bytes in sizes) or undef on error.

name = readlink(path);

Returns undef on error.

readlinkat

name = readlinkat(dirfd, path);

Returns undef on error.

realpath

resolved_path = realpath(path);

Calls the actual C library fuction realpath() and relies on it to be able to allocate memory for the resolved path automatically (as required by POSIX-2008).

Returns undef on error.

remainder

r = remainder(x, y);

remove

ret = remove(path);

Calls the actual C library function remove().

Note that core POSIX::remove() fails if path is a symlink to a directory because someone "couldn't read the plans right and did a piss-poor job of putting it together" as (-d $_[0]) ? CORE::rmdir($_[0]) : CORE::unlink($_[0]). Quote from Armageddon.

This could be fixed like this: unlink $_[0] or ($!{EISDIR} || $!{EPERM} ? rmdir $_[0] : undef) (correct errno check depends on OS), or by using the library call right away.

rename

ret = rename(old, new);

renameat

ret = renameat(olddirfd, oldpath, newdirfd, newpath);

round

r = round(x);

scalbn

y = scalbn(x, n);

Calls scalbln() or scalbn(), whichever is the maximum supported by your system.

seed48

(old_seed1, old_seed2, old_seed3) = seed48(seed1, seed2, seed3);

setegid

ret = setegid(gid);

seteuid

ret = seteuid(uid);

setgid

ret = setgid(gid);

setitimer

(old_int_sec, old_int_usec, old_val_sec, old_val_usec) = setitimer(which, int_sec, int_usec, val_sec, val_usec);

which is one of ITIMER_REAL, ITIMER_VIRTUAL, ITIMER_PROF.

setpriority

ret = setpriority(prio, which=PRIO_PROCESS, who=0);

which can be one of PRIO_PROCESS, PRIO_PGRP, PRIO_USER, defaults to PRIO_PROCESS. who defaults to 0.

Note that due to the support of default values for which and who, prio is the first call parameter, whereas in the actual syscall it is the last.

Returns true on success, undef on error.

setregid

ret = setregid(rgid, egid);

setreuid

ret = setreuid(ruid, euid);

setsid

sid = setsid();

setuid

ret = setuid(uid);

setutxent

setutxent();

sighold

ret = sighold(sig);

sigignore

ret = sigignore(sig);

signbit

b = signbit(x);

sigpause

sigpause(sig);

sigrelse

ret = sigrelse(sig);

sin

y = sin(x);

sinh

y = sinh(x);

srand48

srand48(seedval);

srandom

srandom(seed);

stat

(dev, ino, mode, nlink, uid, gid, rdev, size, atim_sec, mtim_sec, ctim_sec, blksize, blocks, atim_nsec, mtim_nsec, ctim_nsec) = stat(what);

what can be a path, a Perl file handle or a file descriptor.

ctime_sec, blksize, blocks and nanoseconds may not be available on your system. Values outside Perl's internal integer range are returned as strings, i.e. if you need the exact values you should, for example, use eq instead of == for comparisons.

Note that CORE::stat() lies to you in some cases: It returns rdev as a signed integer even if your OS's dev_t is unsigned. It returns size as a floating point number if your OS's off_t is bigger than Perl's integer size. It returns the times as floating point numbers if your OS's time_t is unsigned.

POSIX::2008::stat() doesn't mimic these bugs and uses the correct data types instead.

Returns an empty list on error.

strptime

(sec, min, hour, mday, mon, year, wday, yday, isdst) = strptime(s, format[, sec, min, hour, mday, mon, year, wday, yday, isdst]);

strptime() converts the string s into a broken-down time according to the format string format. The time fields may optionally be initialized in whole or in part and will be returned as initialized if they are not affected by the format string. Unprocessed uninitialized or undef fields are returned as undef.

Returns an empty list on error.

In scalar context returns the index of the first byte in s that was not processed or the byte length of s if the whole string was consumed or undef on error.

As strptime() acts on null-terminated strings, strings containing NUL bytes will only be processed up to the first NUL byte.

symlink(target, linkpath);

symlinkat

ret = symlinkat(target, dirfd, linkpath);

sync

sync();

tan

y = tan(x);

tanh

y = tanh(x);

tgamma

y = tgamma(x);

timer_create

timerid = timer_create(clockid, signal);

Returns undef on error.

timer_delete

timer_delete(timerid);

Returns '0 but true' on success, undef on error.

timer_getoverrun

count = timer_getoverrun(timerid);

Returns undef on error.

timer_gettime

(interval_sec, interval_nsec, initial_sec, initial_nsec) = timer_gettime(timerid);

Returns an empty list on error.

timer_settime

(old_int_sec, old_int_nsec, old_init_sec, old_init_nsec) = timer_settime(timerid, flags, int_sec, int_nsec, [init_sec, init_nsec]);

flags may be 0 or TIMER_ABSTIME. If the init values are omitted, they are set to the int values.

truncate

ret = truncate(path, length);

trunc

y = trunc(x);

ttyname

name = ttyname(fd);

unlinkat

ret = unlinkat(dirfd, path, flags=0);

flags can be 0 or AT_REMOVEDIR.

ret = unlink(path);

Calls the actual C library function unlink().

Note that core POSIX::unlink() calls CORE::unlink(), which, unless you start Perl with "-U", a) is prone to time-of-check/time-of-use race conditions due to an additional lstat(), and b) blindly fails with EISDIR for directories (due to said lstat()), ignoring that some OSes use EPERM in this case (as required by POSIX).

utimensat

ret = utimensat(dirfd, path, flags, atime_sec, atime_nsec, mtime_sec, mtime_nsec);

flags can be 0 or AT_SYMLINK_NOFOLLOW, defaults to 0.

atime_sec and mtime_sec default to 0. atime_nsec and mtime_nsec default to UTIME_NOW.

write

bytes_written = write(fd, buf[, count]);

Like POSIX::write() but returns 0 instead of "0 but true" if 0 bytes were written, and never writes more bytes than buf contains even if count exceeds the length of buf.

If count is omitted or undef, it defaults to the length of buf.

writev

bytes_written = writev(fd, buffers);

writev() writes multiple buffers from buffers to the file associated with the file descriptor fd.

buffers must be an array reference, i.e. \@buf, $buf or [...]. The buffers are processed in array order. Undefined or empty elements are skipped.

Returns the number of bytes written or undef on error.

y0

y = y0(x);

y0() is the Bessel function of the second kind of order 0.

y1

y = y1(x);

y1() is the Bessel function of the second kind of order 1.

yn

y = yn(n, x);

yn() is the Bessel function of the second kind of order n.

EXPORTS

This module does not export anything by default. The following export tags are available:

:at     All *at() functions like openat() and all AT_/RESOLVE_ constants
:id     All get/set*id() functions like getuid() etc.
:is     All is* functions like isdigit() etc.
:rw     read(), readv(), write(), writev()
:prw    pread(), preadv(), pwrite(), pwritev()
:clock  All clock* functions and all CLOCK* constants
:fcntl  All F_, FD_, O_, POSIX_FADV_, SEEK_ and _OK constants (for AT_ use :at)
:fnm    C<fnmatch()> and all FNM_ constants
:stat_h All S_I* and UTIME_ constants
:time_h All CLOCK_ and TIMER_ constants
:timer  All timer_ functions and TIMER_ constants

CONSTANTS

AT_EACCESS AT_EMPTY_PATH AT_FDCWD AT_NO_AUTOMOUNT AT_REMOVEDIR AT_SYMLINK_FOLLOW AT_SYMLINK_NOFOLLOW RESOLVE_BENEATH RESOLVE_IN_ROOT RESOLVE_NO_MAGICLINKS RESOLVE_NO_SYMLINKS RESOLVE_NO_XDEV RESOLVE_CACHED

BOOT_TIME NEW_TIME OLD_TIME DEAD_PROCESS INIT_PROCESS LOGIN_PROCESS USER_PROCESS RUN_LVL

CLOCK_BOOTTIME CLOCK_HIGHRES CLOCK_MONOTONIC CLOCK_MONOTONIC_COARSE CLOCK_MONOTONIC_FAST CLOCK_MONOTONIC_PRECISE CLOCK_MONOTONIC_RAW CLOCK_PROCESS_CPUTIME_ID CLOCK_REALTIME CLOCK_REALTIME_COARSE CLOCK_REALTIME_FAST CLOCK_REALTIME_PRECISE CLOCK_SOFTTIME CLOCK_THREAD_CPUTIME_ID CLOCK_UPTIME CLOCK_UPTIME_FAST CLOCK_UPTIME_PRECISE

_CS_GNU_LIBC_VERSION _CS_GNU_LIBPTHREAD_VERSION _CS_PATH

F_DUPFD F_DUPFD_CLOEXEC F_GETFD F_SETFD F_GETFL F_SETFL F_GETLK F_SETLK F_SETLKW F_GETOWN F_SETOWN F_RDLCK F_UNLCK F_WRLCK

FD_CLOEXEC

FNM_CASEFOLD FNM_FILE_NAME FNM_LEADING_DIR FNM_NOESCAPE FNM_NOMATCH FNM_PATHNAME FNM_PERIOD

FP_INFINITE FP_NAN FP_NORMAL FP_SUBNORMAL FP_ZERO

TIMER_ABSTIME ITIMER_PROF ITIMER_REAL ITIMER_VIRTUAL

O_ACCMODE O_APPEND O_CLOEXEC O_CREAT O_DIRECTORY O_DSYNC O_EXEC O_NOCTTY O_NOFOLLOW O_NONBLOCK O_RDONLY O_RDWR O_RSYNC O_SEARCH O_SYNC O_TMPFILE O_TRUNC O_TTY_INIT O_WRONLY

POSIX_FADV_NORMAL POSIX_FADV_SEQUENTIAL POSIX_FADV_RANDOM POSIX_FADV_NOREUSE POSIX_FADV_WILLNEED POSIX_FADV_DONTNEED

RTLD_GLOBAL RTLD_LAZY RTLD_LOCAL RTLD_NOW

SEEK_SET SEEK_CUR SEEK_END F_OK R_OK W_OK X_OK

S_IFMT S_IFBLK S_IFCHR S_IFIFO S_IFREG S_IFDIR S_IFLNK S_IFSOCK S_ISUID S_ISGID S_IRWXU S_IRUSR S_IWUSR S_IXUSR S_IRWXG S_IRGRP S_IWGRP S_IXGRP S_IRWXO S_IROTH S_IWOTH S_IXOTH S_ISVTX

UTIME_NOW UTIME_OMIT

NOTES

preadv(), pwritev() and openat2() are not part of POSIX. They are included anyway.

fstatat(), lstat() and stat() do not set the special underscore filehandle _ (mostly because I have no clue how that works).

open(), openat() and openat2() do not set the O_CLOEXEC flag automatically. You have to take care of that yourself if needed.

AUTHOR

Initially hacked together by Carsten Gaebler.

LICENSE

This library is free software. You can redistribute and/or modify it under the terms of the Do What The Fuck You Want To Public License, Version 2, as published by Sam Hocevar. See the COPYING file or http://www.wtfpl.net/ for more details.