[Python-checkins] r67613 - in python/branches/release26-maint: Misc/NEWS Modules/dbmmodule.c setup.py

skip.montanaro python-checkins at python.org
Sat Dec 6 18:39:55 CET 2008


Author: skip.montanaro
Date: Sat Dec  6 18:39:54 2008
New Revision: 67613

Log:
issue4483: dbm build failures on systems with gdbm_compat lib.


Modified:
   python/branches/release26-maint/Misc/NEWS
   python/branches/release26-maint/Modules/dbmmodule.c
   python/branches/release26-maint/setup.py

Modified: python/branches/release26-maint/Misc/NEWS
==============================================================================
--- python/branches/release26-maint/Misc/NEWS	(original)
+++ python/branches/release26-maint/Misc/NEWS	Sat Dec  6 18:39:54 2008
@@ -23,6 +23,9 @@
 Library
 -------
 
+- Issue #4483: _dbm module now builds on systems with gdbm & gdbm_compat
+  libs.
+
 - FileIO's mode attribute now always includes ``"b"``.
 
 

Modified: python/branches/release26-maint/Modules/dbmmodule.c
==============================================================================
--- python/branches/release26-maint/Modules/dbmmodule.c	(original)
+++ python/branches/release26-maint/Modules/dbmmodule.c	Sat Dec  6 18:39:54 2008
@@ -21,6 +21,9 @@
 #elif defined(HAVE_GDBM_NDBM_H)
 #include <gdbm/ndbm.h>
 static char *which_dbm = "GNU gdbm";
+#elif defined(HAVE_GDBM_DASH_NDBM_H)
+#include <gdbm-ndbm.h>
+static char *which_dbm = "GNU gdbm";
 #elif defined(HAVE_BERKDB_H)
 #include <db.h>
 static char *which_dbm = "Berkeley DB";

Modified: python/branches/release26-maint/setup.py
==============================================================================
--- python/branches/release26-maint/setup.py	(original)
+++ python/branches/release26-maint/setup.py	Sat Dec  6 18:39:54 2008
@@ -1019,8 +1019,20 @@
                 exts.append( Extension('dbm', ['dbmmodule.c'],
                                        define_macros=[('HAVE_NDBM_H',None)],
                                        libraries = ndbm_libs ) )
-            elif (self.compiler.find_library_file(lib_dirs, 'gdbm')
-                  and find_file("gdbm/ndbm.h", inc_dirs, []) is not None):
+            elif self.compiler.find_library_file(lib_dirs, 'gdbm'):
+                gdbm_libs = ['gdbm']
+                if self.compiler.find_library_file(lib_dirs, 'gdbm_compat'):
+                    gdbm_libs.append('gdbm_compat')
+                if find_file("gdbm/ndbm.h", inc_dirs, []) is not None:
+                    exts.append( Extension(
+                        'dbm', ['dbmmodule.c'],
+                        define_macros=[('HAVE_GDBM_NDBM_H',None)],
+                        libraries = gdbm_libs ) )
+                elif find_file("gdbm-ndbm.h", inc_dirs, []) is not None:
+                    exts.append( Extension(
+                        'dbm', ['dbmmodule.c'],
+                        define_macros=[('HAVE_GDBM_DASH_NDBM_H',None)],
+                        libraries = gdbm_libs ) )
                 exts.append( Extension('dbm', ['dbmmodule.c'],
                                        define_macros=[('HAVE_GDBM_NDBM_H',None)],
                                        libraries = ['gdbm'] ) )


More information about the Python-checkins mailing list