home *** CD-ROM | disk | FTP | other *** search
/ PC World 2005 June / PCWorld_2005-06_cd.bin / software / vyzkuste / firewally / firewally.exe / framework-2.3.exe / Errno.pm < prev    next >
Text File  |  2003-11-07  |  7KB  |  275 lines

  1. #
  2. # This file is auto-generated. ***ANY*** changes here will be lost
  3. #
  4.  
  5. package Errno;
  6. our (@EXPORT_OK,%EXPORT_TAGS,@ISA,$VERSION,%errno,$AUTOLOAD);
  7. use Exporter ();
  8. use Config;
  9. use strict;
  10.  
  11. "$Config{'archname'}-$Config{'osvers'}" eq
  12. "cygwin-thread-multi-64int-1.5.5(0.9432)" or
  13.     die "Errno architecture (cygwin-thread-multi-64int-1.5.5(0.9432)) does not match executable architecture ($Config{'archname'}-$Config{'osvers'})";
  14.  
  15. $VERSION = "1.09_00";
  16. $VERSION = eval $VERSION;
  17. @ISA = qw(Exporter);
  18.  
  19. @EXPORT_OK = qw(EBADR EADV ENOMSG EROFS ENOTSUP ESHUTDOWN EMULTIHOP
  20.     EPROTONOSUPPORT ENOLCK ENFILE EADDRINUSE EL3HLT ECONNABORTED EBADF
  21.     ENOTBLK EDEADLK ECHRNG ENOLINK ESRMNT ELNRNG ETIME ENOTDIR EINVAL
  22.     ENOTTY ENOANO EXDEV EBADE ELOOP EBADSLT ECONNREFUSED ENOSTR EOVERFLOW
  23.     EISCONN ENONET EFBIG ECONNRESET EPFNOSUPPORT ENOENT EWOULDBLOCK
  24.     ELIBMAX EBADMSG ENOMEDIUM EL2HLT ECASECLASH ENOPKG EDOM EBFONT ELIBSCN
  25.     EMSGSIZE ENOCSI EL3RST ENOTSOCK EDESTADDRREQ EIO ENOSPC EIDRM ERANGE
  26.     EINPROGRESS ENOBUFS EADDRNOTAVAIL EAFNOSUPPORT ENOSYS EINTR EHOSTDOWN
  27.     EILSEQ EREMOTE EBADFD ENOMEM ENOSR ENETUNREACH EPIPE ENOTCONN ESTALE
  28.     ENODATA EDQUOT EUSERS EOPNOTSUPP EPROTO EFTYPE ESPIPE EALREADY
  29.     ENAMETOOLONG EMFILE EACCES ENOEXEC EPROCLIM EISDIR ELBIN EBUSY EBADRQC
  30.     EPERM E2BIG ELIBEXEC EEXIST EDOTDOT ETOOMANYREFS ELIBACC ENOTUNIQ
  31.     ECOMM ELIBBAD ENOSHARE ESOCKTNOSUPPORT EUNATCH ETIMEDOUT ENXIO ESRCH
  32.     ENODEV ETXTBSY EFAULT ENMFILE EMLINK EDEADLOCK EXFULL EAGAIN
  33.     ENOPROTOOPT ECHILD ENETDOWN EHOSTUNREACH EPROTOTYPE EREMCHG EL2NSYNC
  34.     ENETRESET ENOTEMPTY);
  35.  
  36. %EXPORT_TAGS = (
  37.     POSIX => [qw(
  38.     E2BIG EACCES EADDRINUSE EADDRNOTAVAIL EAFNOSUPPORT EAGAIN EALREADY
  39.     EBADF EBUSY ECHILD ECONNABORTED ECONNREFUSED ECONNRESET EDEADLK
  40.     EDESTADDRREQ EDOM EDQUOT EEXIST EFAULT EFBIG EHOSTDOWN EHOSTUNREACH
  41.     EINPROGRESS EINTR EINVAL EIO EISCONN EISDIR ELOOP EMFILE EMLINK
  42.     EMSGSIZE ENAMETOOLONG ENETDOWN ENETRESET ENETUNREACH ENFILE ENOBUFS
  43.     ENODEV ENOENT ENOEXEC ENOLCK ENOMEM ENOPROTOOPT ENOSPC ENOSYS ENOTBLK
  44.     ENOTCONN ENOTDIR ENOTEMPTY ENOTSOCK ENOTTY ENXIO EOPNOTSUPP EPERM
  45.     EPFNOSUPPORT EPIPE EPROCLIM EPROTONOSUPPORT EPROTOTYPE ERANGE EREMOTE
  46.     EROFS ESHUTDOWN ESOCKTNOSUPPORT ESPIPE ESRCH ESTALE ETIMEDOUT
  47.     ETOOMANYREFS ETXTBSY EUSERS EWOULDBLOCK EXDEV
  48.     )]
  49. );
  50.  
  51. sub EPERM () { 1 }
  52. sub ENOENT () { 2 }
  53. sub ESRCH () { 3 }
  54. sub EINTR () { 4 }
  55. sub EIO () { 5 }
  56. sub ENXIO () { 6 }
  57. sub E2BIG () { 7 }
  58. sub ENOEXEC () { 8 }
  59. sub EBADF () { 9 }
  60. sub ECHILD () { 10 }
  61. sub EWOULDBLOCK () { 11 }
  62. sub EAGAIN () { 11 }
  63. sub ENOMEM () { 12 }
  64. sub EACCES () { 13 }
  65. sub EFAULT () { 14 }
  66. sub ENOTBLK () { 15 }
  67. sub EBUSY () { 16 }
  68. sub EEXIST () { 17 }
  69. sub EXDEV () { 18 }
  70. sub ENODEV () { 19 }
  71. sub ENOTDIR () { 20 }
  72. sub EISDIR () { 21 }
  73. sub EINVAL () { 22 }
  74. sub ENFILE () { 23 }
  75. sub EMFILE () { 24 }
  76. sub ENOTTY () { 25 }
  77. sub ETXTBSY () { 26 }
  78. sub EFBIG () { 27 }
  79. sub ENOSPC () { 28 }
  80. sub ESPIPE () { 29 }
  81. sub EROFS () { 30 }
  82. sub EMLINK () { 31 }
  83. sub EPIPE () { 32 }
  84. sub EDOM () { 33 }
  85. sub ERANGE () { 34 }
  86. sub ENOMSG () { 35 }
  87. sub EIDRM () { 36 }
  88. sub ECHRNG () { 37 }
  89. sub EL2NSYNC () { 38 }
  90. sub EL3HLT () { 39 }
  91. sub EL3RST () { 40 }
  92. sub ELNRNG () { 41 }
  93. sub EUNATCH () { 42 }
  94. sub ENOCSI () { 43 }
  95. sub EL2HLT () { 44 }
  96. sub EDEADLK () { 45 }
  97. sub ENOLCK () { 46 }
  98. sub EBADE () { 50 }
  99. sub EBADR () { 51 }
  100. sub EXFULL () { 52 }
  101. sub ENOANO () { 53 }
  102. sub EBADRQC () { 54 }
  103. sub EBADSLT () { 55 }
  104. sub EDEADLOCK () { 56 }
  105. sub EBFONT () { 57 }
  106. sub ENOSTR () { 60 }
  107. sub ENODATA () { 61 }
  108. sub ETIME () { 62 }
  109. sub ENOSR () { 63 }
  110. sub ENONET () { 64 }
  111. sub ENOPKG () { 65 }
  112. sub EREMOTE () { 66 }
  113. sub ENOLINK () { 67 }
  114. sub EADV () { 68 }
  115. sub ESRMNT () { 69 }
  116. sub ECOMM () { 70 }
  117. sub EPROTO () { 71 }
  118. sub EMULTIHOP () { 74 }
  119. sub ELBIN () { 75 }
  120. sub EDOTDOT () { 76 }
  121. sub EBADMSG () { 77 }
  122. sub EFTYPE () { 79 }
  123. sub ENOTUNIQ () { 80 }
  124. sub EBADFD () { 81 }
  125. sub EREMCHG () { 82 }
  126. sub ELIBACC () { 83 }
  127. sub ELIBBAD () { 84 }
  128. sub ELIBSCN () { 85 }
  129. sub ELIBMAX () { 86 }
  130. sub ELIBEXEC () { 87 }
  131. sub ENOSYS () { 88 }
  132. sub ENMFILE () { 89 }
  133. sub ENOTEMPTY () { 90 }
  134. sub ENAMETOOLONG () { 91 }
  135. sub ELOOP () { 92 }
  136. sub EOPNOTSUPP () { 95 }
  137. sub EPFNOSUPPORT () { 96 }
  138. sub ECONNRESET () { 104 }
  139. sub ENOBUFS () { 105 }
  140. sub EAFNOSUPPORT () { 106 }
  141. sub EPROTOTYPE () { 107 }
  142. sub ENOTSOCK () { 108 }
  143. sub ENOPROTOOPT () { 109 }
  144. sub ESHUTDOWN () { 110 }
  145. sub ECONNREFUSED () { 111 }
  146. sub EADDRINUSE () { 112 }
  147. sub ECONNABORTED () { 113 }
  148. sub ENETUNREACH () { 114 }
  149. sub ENETDOWN () { 115 }
  150. sub ETIMEDOUT () { 116 }
  151. sub EHOSTDOWN () { 117 }
  152. sub EHOSTUNREACH () { 118 }
  153. sub EINPROGRESS () { 119 }
  154. sub EALREADY () { 120 }
  155. sub EDESTADDRREQ () { 121 }
  156. sub EMSGSIZE () { 122 }
  157. sub EPROTONOSUPPORT () { 123 }
  158. sub ESOCKTNOSUPPORT () { 124 }
  159. sub EADDRNOTAVAIL () { 125 }
  160. sub ENETRESET () { 126 }
  161. sub EISCONN () { 127 }
  162. sub ENOTCONN () { 128 }
  163. sub ETOOMANYREFS () { 129 }
  164. sub EPROCLIM () { 130 }
  165. sub EUSERS () { 131 }
  166. sub EDQUOT () { 132 }
  167. sub ESTALE () { 133 }
  168. sub ENOTSUP () { 134 }
  169. sub ENOMEDIUM () { 135 }
  170. sub ENOSHARE () { 136 }
  171. sub ECASECLASH () { 137 }
  172. sub EILSEQ () { 138 }
  173. sub EOVERFLOW () { 139 }
  174.  
  175. sub TIEHASH { bless [] }
  176.  
  177. sub FETCH {
  178.     my ($self, $errname) = @_;
  179.     my $proto = prototype("Errno::$errname");
  180.     my $errno = "";
  181.     if (defined($proto) && $proto eq "") {
  182.     no strict 'refs';
  183.     $errno = &$errname;
  184.         $errno = 0 unless $! == $errno;
  185.     }
  186.     return $errno;
  187. }
  188.  
  189. sub STORE {
  190.     require Carp;
  191.     Carp::confess("ERRNO hash is read only!");
  192. }
  193.  
  194. *CLEAR = \&STORE;
  195. *DELETE = \&STORE;
  196.  
  197. sub NEXTKEY {
  198.     my($k,$v);
  199.     while(($k,$v) = each %Errno::) {
  200.     my $proto = prototype("Errno::$k");
  201.     last if (defined($proto) && $proto eq "");
  202.     }
  203.     $k
  204. }
  205.  
  206. sub FIRSTKEY {
  207.     my $s = scalar keys %Errno::;    # initialize iterator
  208.     goto &NEXTKEY;
  209. }
  210.  
  211. sub EXISTS {
  212.     my ($self, $errname) = @_;
  213.     my $proto = prototype($errname);
  214.     defined($proto) && $proto eq "";
  215. }
  216.  
  217. tie %!, __PACKAGE__;
  218.  
  219. 1;
  220. __END__
  221.  
  222. =head1 NAME
  223.  
  224. Errno - System errno constants
  225.  
  226. =head1 SYNOPSIS
  227.  
  228.     use Errno qw(EINTR EIO :POSIX);
  229.  
  230. =head1 DESCRIPTION
  231.  
  232. C<Errno> defines and conditionally exports all the error constants
  233. defined in your system C<errno.h> include file. It has a single export
  234. tag, C<:POSIX>, which will export all POSIX defined error numbers.
  235.  
  236. C<Errno> also makes C<%!> magic such that each element of C<%!> has a
  237. non-zero value only if C<$!> is set to that value. For example:
  238.  
  239.     use Errno;
  240.  
  241.     unless (open(FH, "/fangorn/spouse")) {
  242.         if ($!{ENOENT}) {
  243.             warn "Get a wife!\n";
  244.         } else {
  245.             warn "This path is barred: $!";
  246.         } 
  247.     } 
  248.  
  249. If a specified constant C<EFOO> does not exist on the system, C<$!{EFOO}>
  250. returns C<"">.  You may use C<exists $!{EFOO}> to check whether the
  251. constant is available on the system.
  252.  
  253. =head1 CAVEATS
  254.  
  255. Importing a particular constant may not be very portable, because the
  256. import will fail on platforms that do not have that constant.  A more
  257. portable way to set C<$!> to a valid value is to use:
  258.  
  259.     if (exists &Errno::EFOO) {
  260.         $! = &Errno::EFOO;
  261.     }
  262.  
  263. =head1 AUTHOR
  264.  
  265. Graham Barr <gbarr@pobox.com>
  266.  
  267. =head1 COPYRIGHT
  268.  
  269. Copyright (c) 1997-8 Graham Barr. All rights reserved.
  270. This program is free software; you can redistribute it and/or modify it
  271. under the same terms as Perl itself.
  272.  
  273. =cut
  274.  
  275.