Path from Thomas Heller: resurrect the .def file kludge while preserving the
authorGreg Ward <gward@python.net>
Thu, 10 Feb 2000 02:17:06 +0000 (02:17 +0000)
committerGreg Ward <gward@python.net>
Thu, 10 Feb 2000 02:17:06 +0000 (02:17 +0000)
/export option mini-kludge.

Lib/distutils/command/build_ext.py

index 14c2234e3c550d99564239dda4b27bbe57befb0e..42eab4796dd6643d0b71695e6b1736d657cb8096 100644 (file)
@@ -241,9 +241,21 @@ class BuildExt (Command):
             libraries = build_info.get ('libraries')
             library_dirs = build_info.get ('library_dirs')
             extra_args = build_info.get ('extra_link_args') or []
+
             if self.compiler.compiler_type == 'msvc':
-                mod_name = string.split (extension_name, '.')[-1]
-                extra_args.append ('/export:init%s' % mod_name)
+                def_file = build_info.get ('def_file')
+                if def_file is None:
+                    source_dir = os.path.dirname (sources[0])
+                    ext_base = (string.split (extension_name, '.'))[-1]
+                    def_file = os.path.join (source_dir, "%s.def" % ext_base)
+                    if not os.path.exists (def_file):
+                        def_file = None
+
+                if def_file is not None:
+                    extra_args.append ('/DEF:' + def_file)
+                else:
+                    modname = string.split (extension_name, '.')[-1]
+                    extra_args.append('/export:init%s'%modname)
 
             ext_filename = self.extension_filename \
                            (extension_name, self.package)