]> granicus.if.org Git - python/commitdiff
Issue #13415: Help to locate curses.h when _curses module is linked to ncursesw
authorVictor Stinner <victor.stinner@haypocalc.com>
Sat, 26 Nov 2011 23:19:53 +0000 (00:19 +0100)
committerVictor Stinner <victor.stinner@haypocalc.com>
Sat, 26 Nov 2011 23:19:53 +0000 (00:19 +0100)
Lib/test/test_curses.py
setup.py

index b416403e90094fd855ac7d98a223497df80a0230..ce09855ac52b8eee0f90967d57cef1c54ba60077 100644 (file)
@@ -268,7 +268,10 @@ def test_unget_wch(stdscr):
     if not hasattr(curses, 'unget_wch'):
         return
     for ch in ('a', '\xe9', '\u20ac', '\U0010FFFF'):
-        curses.unget_wch(ch)
+        try:
+            curses.unget_wch(ch)
+        except Exception as err:
+            raise Exception("unget_wch(%a) failed: %s" % (ch, err))
         read = stdscr.get_wch()
         read = chr(read)
         if read != ch:
index 97a92bae0ec6cf531f3d22ea9c2b236eab3efbbc..1e450c782235b558eddb55dbf8ff6e68281ef944 100644 (file)
--- a/setup.py
+++ b/setup.py
@@ -1173,13 +1173,16 @@ class PyBuildExt(build_ext):
         # Curses support, requiring the System V version of curses, often
         # provided by the ncurses library.
         panel_library = 'panel'
+        curses_includes = []
         if curses_library.startswith('ncurses'):
             if curses_library == 'ncursesw':
                 # Bug 1464056: If _curses.so links with ncursesw,
                 # _curses_panel.so must link with panelw.
                 panel_library = 'panelw'
+                curses_includes = ['/usr/include/ncursesw']
             curses_libs = [curses_library]
             exts.append( Extension('_curses', ['_cursesmodule.c'],
+                                   include_dirs=curses_includes,
                                    define_macros=curses_defines,
                                    libraries = curses_libs) )
         elif curses_library == 'curses' and platform != 'darwin':
@@ -1202,6 +1205,7 @@ class PyBuildExt(build_ext):
         if (module_enabled(exts, '_curses') and
             self.compiler.find_library_file(lib_dirs, panel_library)):
             exts.append( Extension('_curses_panel', ['_curses_panel.c'],
+                                   include_dirs=curses_includes,
                                    libraries = [panel_library] + curses_libs) )
         else:
             missing.append('_curses_panel')