]> granicus.if.org Git - python/commitdiff
Merged revisions 82929 via svnmerge from
authorStefan Krah <stefan@bytereef.org>
Sat, 17 Jul 2010 12:31:09 +0000 (12:31 +0000)
committerStefan Krah <stefan@bytereef.org>
Sat, 17 Jul 2010 12:31:09 +0000 (12:31 +0000)
svn+ssh://pythondev@svn.python.org/python/branches/release27-maint

........
  r82929 | stefan.krah | 2010-07-17 14:21:08 +0200 (Sat, 17 Jul 2010) | 4 lines

  Issue #7384: On Gentoo, libreadline.so is a "fake library", so ldd fails.
  In that case, do not attempt to parse stderr output.
........

setup.py

index 3094fdffc51d8954b4958b9ddef0f9bccc0aa1ab..4fe1f4577c14bfacf656ffd55a2148974c2ea633 100644 (file)
--- a/setup.py
+++ b/setup.py
@@ -607,16 +607,18 @@ class PyBuildExt(build_ext):
         # Determine if readline is already linked against curses or tinfo.
         if do_readline and find_executable('ldd'):
             fp = os.popen("ldd %s" % do_readline)
-            for ln in fp:
-                if 'curses' in ln:
-                    readline_termcap_library = re.sub(
-                        r'.*lib(n?cursesw?)\.so.*', r'\1', ln
-                    ).rstrip()
-                    break
-                if 'tinfo' in ln: # termcap interface split out from ncurses
-                    readline_termcap_library = 'tinfo'
-                    break
-            fp.close()
+            ldd_output = fp.readlines()
+            ret = fp.close()
+            if ret is None or ret >> 8 == 0:
+                for ln in ldd_output:
+                    if 'curses' in ln:
+                        readline_termcap_library = re.sub(
+                            r'.*lib(n?cursesw?)\.so.*', r'\1', ln
+                        ).rstrip()
+                        break
+                    if 'tinfo' in ln: # termcap interface split out from ncurses
+                        readline_termcap_library = 'tinfo'
+                        break
         # Issue 7384: If readline is already linked against curses,
         # use the same library for the readline and curses modules.
         # Disabled since applications relying on ncursesw might break.