aboutsummaryrefslogtreecommitdiffstats
path: root/e-util/e-host-utils.c
diff options
context:
space:
mode:
authorDan Winship <danw@src.gnome.org>2001-04-27 04:26:08 +0800
committerDan Winship <danw@src.gnome.org>2001-04-27 04:26:08 +0800
commite06a2c8d52cf983bf4bc4b6f13ec69a5d6312de2 (patch)
treed88e8ba14b756ac0c23e72a94abe4675e56ee632 /e-util/e-host-utils.c
parent6b0d304ac8648f779d9bd1002ceba25f2d4bfa50 (diff)
downloadgsoc2013-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.c24
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;