1 /*
2  * Copyright (c) 1987, 1993
3  *  The Regents of the University of California.  All rights reserved.
4  *
5  * Portions copyright (c) 1999, 2000
6  * Intel Corporation.
7  * All rights reserved.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright
14  *    notice, this list of conditions and the following disclaimer.
15  *
16  * 2. Redistributions in binary form must reproduce the above copyright
17  *    notice, this list of conditions and the following disclaimer in the
18  *    documentation and/or other materials provided with the distribution.
19  *
20  * 3. All advertising materials mentioning features or use of this software
21  *    must display the following acknowledgement:
22  *
23  *    This product includes software developed by the University of
24  *    California, Berkeley, Intel Corporation, and its contributors.
25  *
26  * 4. Neither the name of University, Intel Corporation, or their respective
27  *    contributors may be used to endorse or promote products derived from
28  *    this software without specific prior written permission.
29  *
30  * THIS SOFTWARE IS PROVIDED BY THE REGENTS, INTEL CORPORATION AND
31  * CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING,
32  * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
33  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS,
34  * INTEL CORPORATION OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
35  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
36  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
37  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
38  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
39  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
40  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
41  *
42  */
43 
44 /*
45  * Portions Copyright (c) 1996 by Internet Software Consortium.
46  *
47  * Permission to use, copy, modify, and distribute this software for any
48  * purpose with or without fee is hereby granted, provided that the above
49  * copyright notice and this permission notice appear in all copies.
50  *
51  * THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SOFTWARE CONSORTIUM DISCLAIMS
52  * ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES
53  * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL INTERNET SOFTWARE
54  * CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
55  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
56  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
57  * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
58  * SOFTWARE.
59 
60   herror.c  8.1 (Berkeley) 6/4/93
61   herror.c,v 1.1.1.1 2003/11/19 01:51:28 kyu3 Exp
62  */
63 
64 #include <sys/types.h>
65 #include <sys/uio.h>
66 #include <netdb.h>
67 #include <string.h>
68 #include <stdio.h>
69 #include <unistd.h>
70 
71 const char *h_errlist[] = {
72   "Resolver Error 0 (no error)",
73   "Unknown host",       /* 1 HOST_NOT_FOUND */
74   "Host name lookup failure",   /* 2 TRY_AGAIN */
75   "Unknown server error",     /* 3 NO_RECOVERY */
76   "No address associated with name",  /* 4 NO_ADDRESS */
77 };
78 int h_nerr = { sizeof h_errlist / sizeof h_errlist[0] };
79 
80 int h_errno;
81 
82 const char *
83 hstrerror(
84   int err
85   );
86 
87 /*
88  * herror --
89  *  print the error indicated by the h_errno value.
90  */
91 void
herror(const char * s)92 herror(
93   const char *s
94   )
95 {
96   struct iovec iov[4];
97   register struct iovec *v = iov;
98 
99   if (s && *s) {
100     v->iov_base = (char *)s;
101     v->iov_len = strlen(s);
102     v++;
103     v->iov_base = ": ";
104     v->iov_len = 2;
105     v++;
106   }
107   v->iov_base = (char *)hstrerror(h_errno);
108   v->iov_len = strlen(v->iov_base);
109   v++;
110   v->iov_base = "\n";
111   v->iov_len = 1;
112 #if defined(_ORG_FREEBSD_) || defined(__GNUC__)
113   writev(STDERR_FILENO, iov, (v - iov) + 1);
114 #else
115   {
116     int   i;
117     for (i = 0; i < (v - iov) + 1; i++)
118       fprintf( stderr, iov[i].iov_base);
119   }
120 #endif
121 
122 }
123 
124 const char *
hstrerror(int err)125 hstrerror(
126   int err
127   )
128 {
129   if (err < 0)
130     return ("Resolver internal error");
131   else if (err < h_nerr)
132     return (h_errlist[err]);
133   return ("Unknown resolver error");
134 }
135