patches/uClibc/0.9.29/130-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
parent 108 69407950a2a2
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>
     1 diff -ur uClibc-0.9.29/libc/inet/resolv.c uClibc-0.9.29-patched/libc/inet/resolv.c
     2 --- uClibc-0.9.29/libc/inet/resolv.c	2007-04-23 12:01:05.000000000 -0500
     3 +++ uClibc-0.9.29-patched/libc/inet/resolv.c	2007-05-09 18:05:33.563404419 -0500
     4 @@ -1700,7 +1700,7 @@
     5  int gethostent_r(struct hostent *result_buf, char *buf, size_t buflen,
     6  	struct hostent **result, int *h_errnop)
     7  {
     8 -    int ret;
     9 +    int ret = HOST_NOT_FOUND;
    10  
    11      __UCLIBC_MUTEX_LOCK(mylock);
    12      if (__gethostent_fp == NULL) {