Errno.pm 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. # -*- buffer-read-only: t -*-
  2. #
  3. # This file is auto-generated. ***ANY*** changes here will be lost
  4. #
  5. package Errno;
  6. require Exporter;
  7. use strict;
  8. our $VERSION = "1.23";
  9. $VERSION = eval $VERSION;
  10. our @ISA = 'Exporter';
  11. my %err;
  12. BEGIN {
  13. %err = (
  14. EPERM => 1,
  15. ENOENT => 2,
  16. ESRCH => 3,
  17. EINTR => 4,
  18. EIO => 5,
  19. ENXIO => 6,
  20. E2BIG => 7,
  21. ENOEXEC => 8,
  22. EBADF => 9,
  23. ECHILD => 10,
  24. EAGAIN => 11,
  25. EWOULDBLOCK => 11,
  26. ENOMEM => 12,
  27. EACCES => 13,
  28. EFAULT => 14,
  29. ENOTBLK => 15,
  30. EBUSY => 16,
  31. EEXIST => 17,
  32. EXDEV => 18,
  33. ENODEV => 19,
  34. ENOTDIR => 20,
  35. EISDIR => 21,
  36. EINVAL => 22,
  37. ENFILE => 23,
  38. EMFILE => 24,
  39. ENOTTY => 25,
  40. ETXTBSY => 26,
  41. EFBIG => 27,
  42. ENOSPC => 28,
  43. ESPIPE => 29,
  44. EROFS => 30,
  45. EMLINK => 31,
  46. EPIPE => 32,
  47. EDOM => 33,
  48. ERANGE => 34,
  49. EDEADLK => 35,
  50. EDEADLOCK => 35,
  51. ENAMETOOLONG => 36,
  52. ENOLCK => 37,
  53. ENOSYS => 38,
  54. ENOTEMPTY => 39,
  55. ELOOP => 40,
  56. ENOMSG => 42,
  57. EIDRM => 43,
  58. ECHRNG => 44,
  59. EL2NSYNC => 45,
  60. EL3HLT => 46,
  61. EL3RST => 47,
  62. ELNRNG => 48,
  63. EUNATCH => 49,
  64. ENOCSI => 50,
  65. EL2HLT => 51,
  66. EBADE => 52,
  67. EBADR => 53,
  68. EXFULL => 54,
  69. ENOANO => 55,
  70. EBADRQC => 56,
  71. EBADSLT => 57,
  72. EBFONT => 59,
  73. ENOSTR => 60,
  74. ENODATA => 61,
  75. ETIME => 62,
  76. ENOSR => 63,
  77. ENONET => 64,
  78. ENOPKG => 65,
  79. EREMOTE => 66,
  80. ENOLINK => 67,
  81. EADV => 68,
  82. ESRMNT => 69,
  83. ECOMM => 70,
  84. EPROTO => 71,
  85. EMULTIHOP => 72,
  86. EDOTDOT => 73,
  87. EBADMSG => 74,
  88. EOVERFLOW => 75,
  89. ENOTUNIQ => 76,
  90. EBADFD => 77,
  91. EREMCHG => 78,
  92. ELIBACC => 79,
  93. ELIBBAD => 80,
  94. ELIBSCN => 81,
  95. ELIBMAX => 82,
  96. ELIBEXEC => 83,
  97. EILSEQ => 84,
  98. ERESTART => 85,
  99. ESTRPIPE => 86,
  100. EUSERS => 87,
  101. ENOTSOCK => 88,
  102. EDESTADDRREQ => 89,
  103. EMSGSIZE => 90,
  104. EPROTOTYPE => 91,
  105. ENOPROTOOPT => 92,
  106. EPROTONOSUPPORT => 93,
  107. ESOCKTNOSUPPORT => 94,
  108. ENOTSUP => 95,
  109. EOPNOTSUPP => 95,
  110. EPFNOSUPPORT => 96,
  111. EAFNOSUPPORT => 97,
  112. EADDRINUSE => 98,
  113. EADDRNOTAVAIL => 99,
  114. ENETDOWN => 100,
  115. ENETUNREACH => 101,
  116. ENETRESET => 102,
  117. ECONNABORTED => 103,
  118. ECONNRESET => 104,
  119. ENOBUFS => 105,
  120. EISCONN => 106,
  121. ENOTCONN => 107,
  122. ESHUTDOWN => 108,
  123. ETOOMANYREFS => 109,
  124. ETIMEDOUT => 110,
  125. ECONNREFUSED => 111,
  126. EHOSTDOWN => 112,
  127. EHOSTUNREACH => 113,
  128. EALREADY => 114,
  129. EINPROGRESS => 115,
  130. ESTALE => 116,
  131. EUCLEAN => 117,
  132. ENOTNAM => 118,
  133. ENAVAIL => 119,
  134. EISNAM => 120,
  135. EREMOTEIO => 121,
  136. EDQUOT => 122,
  137. ENOMEDIUM => 123,
  138. EMEDIUMTYPE => 124,
  139. ECANCELED => 125,
  140. ENOKEY => 126,
  141. EKEYEXPIRED => 127,
  142. EKEYREVOKED => 128,
  143. EKEYREJECTED => 129,
  144. EOWNERDEAD => 130,
  145. ENOTRECOVERABLE => 131,
  146. ERFKILL => 132,
  147. EHWPOISON => 133,
  148. );
  149. # Generate proxy constant subroutines for all the values.
  150. # Well, almost all the values. Unfortunately we can't assume that at this
  151. # point that our symbol table is empty, as code such as if the parser has
  152. # seen code such as C<exists &Errno::EINVAL>, it will have created the
  153. # typeglob.
  154. # Doing this before defining @EXPORT_OK etc means that even if a platform is
  155. # crazy enough to define EXPORT_OK as an error constant, everything will
  156. # still work, because the parser will upgrade the PCS to a real typeglob.
  157. # We rely on the subroutine definitions below to update the internal caches.
  158. # Don't use %each, as we don't want a copy of the value.
  159. foreach my $name (keys %err) {
  160. if ($Errno::{$name}) {
  161. # We expect this to be reached fairly rarely, so take an approach
  162. # which uses the least compile time effort in the common case:
  163. eval "sub $name() { $err{$name} }; 1" or die $@;
  164. } else {
  165. $Errno::{$name} = \$err{$name};
  166. }
  167. }
  168. }
  169. our @EXPORT_OK = keys %err;
  170. our %EXPORT_TAGS = (
  171. POSIX => [qw(
  172. E2BIG EACCES EADDRINUSE EADDRNOTAVAIL EAFNOSUPPORT EAGAIN EALREADY
  173. EBADF EBUSY ECHILD ECONNABORTED ECONNREFUSED ECONNRESET EDEADLK
  174. EDESTADDRREQ EDOM EDQUOT EEXIST EFAULT EFBIG EHOSTDOWN EHOSTUNREACH
  175. EINPROGRESS EINTR EINVAL EIO EISCONN EISDIR ELOOP EMFILE EMLINK
  176. EMSGSIZE ENAMETOOLONG ENETDOWN ENETRESET ENETUNREACH ENFILE ENOBUFS
  177. ENODEV ENOENT ENOEXEC ENOLCK ENOMEM ENOPROTOOPT ENOSPC ENOSYS ENOTBLK
  178. ENOTCONN ENOTDIR ENOTEMPTY ENOTSOCK ENOTTY ENXIO EOPNOTSUPP EPERM
  179. EPFNOSUPPORT EPIPE EPROTONOSUPPORT EPROTOTYPE ERANGE EREMOTE ERESTART
  180. EROFS ESHUTDOWN ESOCKTNOSUPPORT ESPIPE ESRCH ESTALE ETIMEDOUT
  181. ETOOMANYREFS ETXTBSY EUSERS EWOULDBLOCK EXDEV
  182. )]
  183. );
  184. sub TIEHASH { bless \%err }
  185. sub FETCH {
  186. my (undef, $errname) = @_;
  187. return "" unless exists $err{$errname};
  188. my $errno = $err{$errname};
  189. return $errno == $! ? $errno : 0;
  190. }
  191. sub STORE {
  192. require Carp;
  193. Carp::confess("ERRNO hash is read only!");
  194. }
  195. *CLEAR = *DELETE = \*STORE; # Typeglob aliasing uses less space
  196. sub NEXTKEY {
  197. each %err;
  198. }
  199. sub FIRSTKEY {
  200. my $s = scalar keys %err; # initialize iterator
  201. each %err;
  202. }
  203. sub EXISTS {
  204. my (undef, $errname) = @_;
  205. exists $err{$errname};
  206. }
  207. tie %!, __PACKAGE__; # Returns an object, objects are true.
  208. __END__
  209. =head1 NAME
  210. Errno - System errno constants
  211. =head1 SYNOPSIS
  212. use Errno qw(EINTR EIO :POSIX);
  213. =head1 DESCRIPTION
  214. C<Errno> defines and conditionally exports all the error constants
  215. defined in your system C<errno.h> include file. It has a single export
  216. tag, C<:POSIX>, which will export all POSIX defined error numbers.
  217. C<Errno> also makes C<%!> magic such that each element of C<%!> has a
  218. non-zero value only if C<$!> is set to that value. For example:
  219. use Errno;
  220. unless (open(FH, "/fangorn/spouse")) {
  221. if ($!{ENOENT}) {
  222. warn "Get a wife!\n";
  223. } else {
  224. warn "This path is barred: $!";
  225. }
  226. }
  227. If a specified constant C<EFOO> does not exist on the system, C<$!{EFOO}>
  228. returns C<"">. You may use C<exists $!{EFOO}> to check whether the
  229. constant is available on the system.
  230. =head1 CAVEATS
  231. Importing a particular constant may not be very portable, because the
  232. import will fail on platforms that do not have that constant. A more
  233. portable way to set C<$!> to a valid value is to use:
  234. if (exists &Errno::EFOO) {
  235. $! = &Errno::EFOO;
  236. }
  237. =head1 AUTHOR
  238. Graham Barr <gbarr@pobox.com>
  239. =head1 COPYRIGHT
  240. Copyright (c) 1997-8 Graham Barr. All rights reserved.
  241. This program is free software; you can redistribute it and/or modify it
  242. under the same terms as Perl itself.
  243. =cut
  244. # ex: set ro: