patches/uClibc/0.9.30/100-fix-gethostent_r-failure-retval.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Tue May 31 00:57:36 2011 +0200 (2011-05-31)
changeset 2494 feee36c11ccc
permissions -rw-r--r--
scripts/functions: do not abort on failed svn

In case of eglibc, some add-ons that were previously external are
now internal (bundled with the main sources).

So we do not want to fail if an add-on can't be downloaded; we
want to post-pone the check until we can extract the main archive.

So:
- try to retrieve the add-on
- if it fails, print a warning instead of calling CT_Abort
- return 1

So, components that want to catch the error and want to handle it can,
while components that do not will gracefuly fail thanks to our catching
every errors.

Bonus: it works without changing any existing retrieval procedure! :-)

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
yann@1207
     1
Original patch from Gentoo.
yann@1207
     2
yann@1207
     3
-= BEGIN original header =-
yann@1207
     4
-= END original header =-
yann@1207
     5
yann@1207
     6
diff -durN uClibc-0.9.30.orig/libc/inet/resolv.c uClibc-0.9.30/libc/inet/resolv.c
yann@1207
     7
--- uClibc-0.9.30.orig/libc/inet/resolv.c	2008-11-02 01:25:33.000000000 +0100
yann@1207
     8
+++ uClibc-0.9.30/libc/inet/resolv.c	2009-02-07 09:57:59.000000000 +0100
yann@1207
     9
@@ -1788,7 +1788,7 @@
yann@1207
    10
 int gethostent_r(struct hostent *result_buf, char *buf, size_t buflen,
yann@1207
    11
 	struct hostent **result, int *h_errnop)
yann@1207
    12
 {
yann@1207
    13
-	int ret;
yann@1207
    14
+	int ret = HOST_NOT_FOUND;
yann@1207
    15
 
yann@1207
    16
 	__UCLIBC_MUTEX_LOCK(mylock);
yann@1207
    17
 	if (__gethostent_fp == NULL) {