5 Fcntl - load the C Fcntl.h defines
13 This module is just a translation of the C F<fnctl.h> file.
14 Unlike the old mechanism of requiring a translated F<fnctl.ph>
15 file, this uses the B<h2xs> program (see the Perl source distribution)
16 and your native C compiler. This means that it has a
17 far more likely chance of getting the numbers right.
21 Only C<#define> symbols get translated; you must still correctly
22 pack up your own arguments to pass as args for locking functions, etc.
26 use vars qw($VERSION @ISA @EXPORT @EXPORT_OK $AUTOLOAD);
31 @ISA = qw(Exporter DynaLoader);
33 # Items to export into callers namespace by default
34 # (move infrequently used names to @EXPORT_OK below)
37 F_DUPFD F_GETFD F_GETLK F_SETFD F_GETFL F_SETFL F_SETLK F_SETLKW
38 FD_CLOEXEC F_RDLCK F_UNLCK F_WRLCK
39 O_CREAT O_EXCL O_NOCTTY O_TRUNC
42 O_RDONLY O_RDWR O_WRONLY
44 # Other items we are prepared to export if requested
50 ($constname = $AUTOLOAD) =~ s/.*:://;
51 my $val = constant($constname, @_ ? $_[0] : 0);
53 if ($! =~ /Invalid/) {
54 $AutoLoader::AUTOLOAD = $AUTOLOAD;
55 goto &AutoLoader::AUTOLOAD;
58 my ($pack,$file,$line) = caller;
59 die "Your vendor has not defined Fcntl macro $constname, used at $file line $line.
63 eval "sub $AUTOLOAD { $val }";
67 bootstrap Fcntl $VERSION;
69 # Preloaded methods go here. Autoload methods go after __END__, and are
70 # processed by the autosplit program.
71 package Fcntl; # return to package Fcntl so AutoSplit is happy