From f02674e96a7888a7322611b45f6b63a1f5db0fef Mon Sep 17 00:00:00 2001 From: vcrhonek Date: Mon, 27 Aug 2007 15:05:02 +0000 Subject: [PATCH] add patch --- tcsh-6.15.00-closem.patch | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 tcsh-6.15.00-closem.patch diff --git a/tcsh-6.15.00-closem.patch b/tcsh-6.15.00-closem.patch new file mode 100644 index 0000000..b1fa58c --- /dev/null +++ b/tcsh-6.15.00-closem.patch @@ -0,0 +1,27 @@ +--- tcsh-6.15.00/sh.misc.c_old 2006-10-14 19:57:21.000000000 +0200 ++++ tcsh-6.15.00/sh.misc.c 2007-08-27 15:55:20.000000000 +0200 +@@ -255,6 +255,7 @@ + closem(void) + { + int f, num_files; ++ struct stat st; + + #ifdef NLS_BUGS + #ifdef NLS_CATALOGS +@@ -272,6 +273,16 @@ + #ifdef MALLOC_TRACE + && f != 25 + #endif /* MALLOC_TRACE */ ++#ifdef S_ISSOCK ++ /* NSS modules (e.g. Linux nss_ldap) might keep sockets open. ++ * If we close such a socket, both the NSS module and tcsh think ++ * they "own" the descriptor. ++ * ++ * Not closing sockets does not make the cleanup use of closem() ++ * less reliable because tcsh never creates sockets. ++ */ ++ && fstat(f, &st) == 0 && !S_ISSOCK(st.st_mode) ++#endif + ) + { + xclose(f);