home *** CD-ROM | disk | FTP | other *** search
/ PC World 2005 December (Special) / PCWorld_2005-12_Special_cd.bin / Bezpecnost / lsti / lsti.exe / framework-2.5.exe / Errno.pm < prev    next >
Text File  |  2005-01-27  |  7KB  |  276 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.12(0.11642)" or
  13.     die "Errno architecture (cygwin-thread-multi-64int-1.5.12(0.11642)) 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 ENOTTY
  22.     EINVAL ENOANO EXDEV EBADE EBADSLT ELOOP ECONNREFUSED ENOSTR ENONET
  23.     EOVERFLOW EISCONN EFBIG EPFNOSUPPORT ECONNRESET ENOENT EWOULDBLOCK
  24.     ELIBMAX EBADMSG ENOMEDIUM EL2HLT ECASECLASH ENOPKG EBFONT EDOM ELIBSCN
  25.     EMSGSIZE ENOCSI EL3RST ENOTSOCK EDESTADDRREQ EIDRM EIO ENOSPC
  26.     EINPROGRESS ERANGE ENOBUFS EAFNOSUPPORT EADDRNOTAVAIL ENOSYS EINTR
  27.     EHOSTDOWN EREMOTE EILSEQ EBADFD ENOSR ENOMEM EPIPE ENETUNREACH
  28.     ENOTCONN ESTALE ENODATA EDQUOT EUSERS EOPNOTSUPP EPROTO EFTYPE ESPIPE
  29.     EALREADY ENAMETOOLONG EMFILE EACCES ENOEXEC EPROCLIM EISDIR ELBIN
  30.     EBUSY EBADRQC EPERM E2BIG ELIBEXEC EEXIST EDOTDOT ETOOMANYREFS ELIBACC
  31.     ENOTUNIQ ECOMM ELIBBAD ENOSHARE EUNATCH ESOCKTNOSUPPORT ETIMEDOUT
  32.     ENXIO ESRCH ETXTBSY ENODEV EFAULT EXFULL EMLINK ENMFILE EDEADLOCK
  33.     EAGAIN ENOPROTOOPT ECHILD EHOSTUNREACH ENETDOWN EPROTOTYPE EREMCHG
  34.     EL2NSYNC 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 $r = ref $errname;
  214.     my $proto = !$r || $r eq 'CODE' ? prototype($errname) : undef;
  215.     defined($proto) && $proto eq "";
  216. }
  217.  
  218. tie %!, __PACKAGE__;
  219.  
  220. 1;
  221. __END__
  222.  
  223. =head1 NAME
  224.  
  225. Errno - System errno constants
  226.  
  227. =head1 SYNOPSIS
  228.  
  229.     use Errno qw(EINTR EIO :POSIX);
  230.  
  231. =head1 DESCRIPTION
  232.  
  233. C<Errno> defines and conditionally exports all the error constants
  234. defined in your system C<errno.h> include file. It has a single export
  235. tag, C<:POSIX>, which will export all POSIX defined error numbers.
  236.  
  237. C<Errno> also makes C<%!> magic such that each element of C<%!> has a
  238. non-zero value only if C<$!> is set to that value. For example:
  239.  
  240.     use Errno;
  241.  
  242.     unless (open(FH, "/fangorn/spouse")) {
  243.         if ($!{ENOENT}) {
  244.             warn "Get a wife!\n";
  245.         } else {
  246.             warn "This path is barred: $!";
  247.         } 
  248.     } 
  249.  
  250. If a specified constant C<EFOO> does not exist on the system, C<$!{EFOO}>
  251. returns C<"">.  You may use C<exists $!{EFOO}> to check whether the
  252. constant is available on the system.
  253.  
  254. =head1 CAVEATS
  255.  
  256. Importing a particular constant may not be very portable, because the
  257. import will fail on platforms that do not have that constant.  A more
  258. portable way to set C<$!> to a valid value is to use:
  259.  
  260.     if (exists &Errno::EFOO) {
  261.         $! = &Errno::EFOO;
  262.     }
  263.  
  264. =head1 AUTHOR
  265.  
  266. Graham Barr <gbarr@pobox.com>
  267.  
  268. =head1 COPYRIGHT
  269.  
  270. Copyright (c) 1997-8 Graham Barr. All rights reserved.
  271. This program is free software; you can redistribute it and/or modify it
  272. under the same terms as Perl itself.
  273.  
  274. =cut
  275.  
  276.