patches/glibc/ports-2.10.1/180-resolv-dynamic.patch
author Remy Bohmer <linux@bohmer.net>
Sun Jul 11 22:23:34 2010 +0200 (2010-07-11)
changeset 2021 3e52a1510f87
permissions -rw-r--r--
debug/gdb: Fix compilation for Mingw hosts

GDB requires PDcurses instead of ncurses while running on Windows.
So, do not always compile ncurses in case GDB needs to build.

PDcurses is provided by an earlier build step and is not described in
this file.

Signed-off-by: Remy Bohmer <linux@bohmer.net>
[yann.morin.1998@anciense.nib.fr: we already have a way to detect ncurses usage]
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
yann@1625
     1
ripped from SuSE
yann@1625
     2
yann@1625
     3
if /etc/resolv.conf is updated, then make sure applications
yann@1625
     4
already running get the updated information.
yann@1625
     5
yann@1625
     6
http://bugs.gentoo.org/177416
yann@1625
     7
yann@1625
     8
diff -durN glibc-2.10.1.orig/resolv/res_libc.c glibc-2.10.1/resolv/res_libc.c
yann@1625
     9
--- glibc-2.10.1.orig/resolv/res_libc.c	2009-02-07 05:27:42.000000000 +0100
yann@1625
    10
+++ glibc-2.10.1/resolv/res_libc.c	2009-11-13 00:49:59.000000000 +0100
yann@1625
    11
@@ -22,6 +22,7 @@
yann@1625
    12
 #include <arpa/nameser.h>
yann@1625
    13
 #include <resolv.h>
yann@1625
    14
 #include <bits/libc-lock.h>
yann@1625
    15
+#include <sys/stat.h>
yann@1625
    16
 
yann@1625
    17
 
yann@1625
    18
 /* The following bit is copied from res_data.c (where it is #ifdef'ed
yann@1625
    19
@@ -95,6 +96,20 @@
yann@1625
    20
 __res_maybe_init (res_state resp, int preinit)
yann@1625
    21
 {
yann@1625
    22
 	if (resp->options & RES_INIT) {
yann@1625
    23
+		static time_t last_mtime, last_check;
yann@1625
    24
+		time_t now;
yann@1625
    25
+		struct stat statbuf;
yann@1625
    26
+		
yann@1625
    27
+		time (&now);
yann@1625
    28
+		if (now != last_check) {
yann@1625
    29
+			last_check = now;
yann@1625
    30
+			if (stat (_PATH_RESCONF, &statbuf) == 0 && last_mtime != statbuf.st_mtime) {
yann@1625
    31
+				last_mtime = statbuf.st_mtime;
yann@1625
    32
+				atomicinclock (lock);
yann@1625
    33
+				atomicinc (__res_initstamp);
yann@1625
    34
+				atomicincunlock (lock);
yann@1625
    35
+			}
yann@1625
    36
+		}
yann@1625
    37
 		if (__res_initstamp != resp->_u._ext.initstamp) {
yann@1625
    38
 			if (resp->nscount > 0)
yann@1625
    39
 				__res_iclose (resp, true);