diff options
author | Dan Winship <danw@src.gnome.org> | 2001-04-27 04:26:08 +0800 |
---|---|---|
committer | Dan Winship <danw@src.gnome.org> | 2001-04-27 04:26:08 +0800 |
commit | e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2 (patch) | |
tree | d88e8ba14b756ac0c23e72a94abe4675e56ee632 /e-util/e-host-utils.c | |
parent | 6b0d304ac8648f779d9bd1002ceba25f2d4bfa50 (diff) | |
download | gsoc2013-evolution-e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2.tar gsoc2013-evolution-e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2.tar.gz gsoc2013-evolution-e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2.tar.bz2 gsoc2013-evolution-e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2.tar.lz gsoc2013-evolution-e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2.tar.xz gsoc2013-evolution-e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2.tar.zst gsoc2013-evolution-e06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2.zip |
Make the Solaris and no-gethostbyname_r implementations behave more like
* e-host-utils.c (e_gethostbyname_r): Make the Solaris and
no-gethostbyname_r implementations behave more like the Linux one.
Document.
svn path=/trunk/; revision=9594
Diffstat (limited to 'e-util/e-host-utils.c')
-rw-r--r-- | e-util/e-host-utils.c | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/e-util/e-host-utils.c b/e-util/e-host-utils.c index 238674ddcc..d20261e5a6 100644 --- a/e-util/e-host-utils.c +++ b/e-util/e-host-utils.c @@ -31,13 +31,30 @@ G_LOCK_DEFINE_STATIC (gethost_mutex); +/** + * e_gethostbyname_r: + * @name: the host to resolve + * @host: a buffer pointing to a struct hostent to use for storage + * @buf: a buffer to use for hostname storage + * @buflen: the size of @buf + * @herr: a pointer to a variable to store an error code in + * + * Resolves the hostname @name, in a hopefully-reentrant fashion. + * + * Return value: 0 on success, ERANGE if @buflen is too small, + * "something else" otherwise (in which case *@herr will be set to + * one of the gethostbyname() error codes). + **/ int e_gethostbyname_r (const char *name, struct hostent *host, char *buf, int buflen, int *herr) { #ifdef HAVE_GETHOSTBYNAME_R #ifdef GETHOSTBYNAME_R_FIVE_ARGS - return gethostbyname_r(name, host, buf, buflen, herr); + if (gethostbyname_r(name, host, buf, buflen, herr)) + return 0; + else + return errno; #else struct hostent *hp; return gethostbyname_r(name, host, buf, buflen, &hp, herr); @@ -54,6 +71,7 @@ e_gethostbyname_r (const char *name, struct hostent *host, h = gethostbyname (name); if (!h) { + *herr = h_errno; G_UNLOCK (gethost_mutex); return -1; } @@ -78,7 +96,7 @@ e_gethostbyname_r (const char *name, struct hostent *host, if (buflen < req_length) { *herr = ERANGE; G_UNLOCK (gethost_mutex); - return -1; + return ERANGE; } /* we store the alias/addr pointers in the buffer - figure out @@ -125,8 +143,6 @@ e_gethostbyname_r (const char *name, struct hostent *host, host->h_addr_list[num_addrs] = NULL; } - *herr = h_errno; - G_UNLOCK (gethost_mutex); return 0; |