blob: b2417c790e21174433a667cc97dd582a667e72f9 [file] [log] [blame]
Andrew M. Kuchling66012fe2001-01-26 21:56:58 +00001# Autodetecting setup.py script for building the Python extensions
2#
Fredrik Lundhade711a2001-01-24 08:00:28 +00003
Brett Cannonca5ff3a2013-06-15 17:52:59 -04004import sys, os, importlib.machinery, re, optparse
Christian Heimesaf98da12008-01-27 15:18:18 +00005from glob import glob
Tarek Ziadéedacea32010-01-29 11:41:03 +00006import sysconfig
Michael W. Hudson529a5052002-12-17 16:47:17 +00007
8from distutils import log
Andrew M. Kuchling8d7f0862001-02-23 16:32:32 +00009from distutils import text_file
Marc-André Lemburg7c6fcda2001-01-26 18:03:24 +000010from distutils.errors import *
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +000011from distutils.core import Extension, setup
12from distutils.command.build_ext import build_ext
Andrew M. Kuchlingf52d27e2001-05-21 20:29:27 +000013from distutils.command.install import install
Michael W. Hudson529a5052002-12-17 16:47:17 +000014from distutils.command.install_lib import install_lib
Georg Brandlff52f762010-12-28 09:51:43 +000015from distutils.command.build_scripts import build_scripts
Stefan Krah095b2732010-06-08 13:41:44 +000016from distutils.spawn import find_executable
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +000017
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +020018cross_compiling = "_PYTHON_HOST_PLATFORM" in os.environ
19
doko@ubuntu.com93df16b2012-06-30 14:32:08 +020020def get_platform():
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +020021 # cross build
22 if "_PYTHON_HOST_PLATFORM" in os.environ:
23 return os.environ["_PYTHON_HOST_PLATFORM"]
doko@ubuntu.com93df16b2012-06-30 14:32:08 +020024 # Get value of sys.platform
25 if sys.platform.startswith('osf1'):
26 return 'osf1'
27 return sys.platform
28host_platform = get_platform()
29
Gregory P. Smithb04ded42010-01-03 00:38:10 +000030# Were we compiled --with-pydebug or with #define Py_DEBUG?
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +020031COMPILED_WITH_PYDEBUG = ('--with-pydebug' in sysconfig.get_config_var("CONFIG_ARGS"))
Gregory P. Smithb04ded42010-01-03 00:38:10 +000032
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +000033# This global variable is used to hold the list of modules to be disabled.
34disabled_module_list = []
35
Michael W. Hudson39230b32002-01-16 15:26:48 +000036def add_dir_to_list(dirlist, dir):
Barry Warsaw807bd0a2010-11-24 20:30:00 +000037 """Add the directory 'dir' to the list 'dirlist' (after any relative
38 directories) if:
39
Michael W. Hudson39230b32002-01-16 15:26:48 +000040 1) 'dir' is not already in 'dirlist'
Barry Warsaw807bd0a2010-11-24 20:30:00 +000041 2) 'dir' actually exists, and is a directory.
42 """
43 if dir is None or not os.path.isdir(dir) or dir in dirlist:
44 return
45 for i, path in enumerate(dirlist):
46 if not os.path.isabs(path):
47 dirlist.insert(i + 1, dir)
Barry Warsaw34520cd2010-11-27 20:03:03 +000048 return
49 dirlist.insert(0, dir)
Michael W. Hudson39230b32002-01-16 15:26:48 +000050
Ronald Oussoren2c12ab12010-06-03 14:42:25 +000051def macosx_sdk_root():
52 """
53 Return the directory of the current OSX SDK,
54 or '/' if no SDK was specified.
55 """
56 cflags = sysconfig.get_config_var('CFLAGS')
57 m = re.search(r'-isysroot\s+(\S+)', cflags)
58 if m is None:
59 sysroot = '/'
60 else:
61 sysroot = m.group(1)
62 return sysroot
63
64def is_macosx_sdk_path(path):
65 """
66 Returns True if 'path' can be located in an OSX SDK
67 """
Ned Deily2910a7b2012-07-30 02:35:58 -070068 return ( (path.startswith('/usr/') and not path.startswith('/usr/local'))
69 or path.startswith('/System/')
70 or path.startswith('/Library/') )
Ronald Oussoren2c12ab12010-06-03 14:42:25 +000071
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +000072def find_file(filename, std_dirs, paths):
73 """Searches for the directory where a given file is located,
74 and returns a possibly-empty list of additional directories, or None
75 if the file couldn't be found at all.
Fredrik Lundhade711a2001-01-24 08:00:28 +000076
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +000077 'filename' is the name of a file, such as readline.h or libcrypto.a.
78 'std_dirs' is the list of standard system directories; if the
79 file is found in one of them, no additional directives are needed.
80 'paths' is a list of additional locations to check; if the file is
81 found in one of them, the resulting list will contain the directory.
82 """
doko@ubuntu.com93df16b2012-06-30 14:32:08 +020083 if host_platform == 'darwin':
Ronald Oussoren2c12ab12010-06-03 14:42:25 +000084 # Honor the MacOSX SDK setting when one was specified.
85 # An SDK is a directory with the same structure as a real
86 # system, but with only header files and libraries.
87 sysroot = macosx_sdk_root()
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +000088
89 # Check the standard locations
90 for dir in std_dirs:
91 f = os.path.join(dir, filename)
Ronald Oussoren2c12ab12010-06-03 14:42:25 +000092
doko@ubuntu.com93df16b2012-06-30 14:32:08 +020093 if host_platform == 'darwin' and is_macosx_sdk_path(dir):
Ronald Oussoren2c12ab12010-06-03 14:42:25 +000094 f = os.path.join(sysroot, dir[1:], filename)
95
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +000096 if os.path.exists(f): return []
97
98 # Check the additional directories
99 for dir in paths:
100 f = os.path.join(dir, filename)
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000101
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200102 if host_platform == 'darwin' and is_macosx_sdk_path(dir):
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000103 f = os.path.join(sysroot, dir[1:], filename)
104
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000105 if os.path.exists(f):
106 return [dir]
107
108 # Not found anywhere
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000109 return None
110
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000111def find_library_file(compiler, libname, std_dirs, paths):
Andrew M. Kuchlinga246d9f2002-11-27 13:43:46 +0000112 result = compiler.find_library_file(std_dirs + paths, libname)
113 if result is None:
114 return None
Fredrik Lundhade711a2001-01-24 08:00:28 +0000115
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200116 if host_platform == 'darwin':
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000117 sysroot = macosx_sdk_root()
118
Andrew M. Kuchlinga246d9f2002-11-27 13:43:46 +0000119 # Check whether the found file is in one of the standard directories
120 dirname = os.path.dirname(result)
121 for p in std_dirs:
122 # Ensure path doesn't end with path separator
Skip Montanaro9f5178a2003-05-06 20:59:57 +0000123 p = p.rstrip(os.sep)
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000124
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200125 if host_platform == 'darwin' and is_macosx_sdk_path(p):
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000126 if os.path.join(sysroot, p[1:]) == dirname:
127 return [ ]
128
Andrew M. Kuchlinga246d9f2002-11-27 13:43:46 +0000129 if p == dirname:
130 return [ ]
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000131
Andrew M. Kuchlinga246d9f2002-11-27 13:43:46 +0000132 # Otherwise, it must have been in one of the additional directories,
133 # so we have to figure out which one.
134 for p in paths:
135 # Ensure path doesn't end with path separator
Skip Montanaro9f5178a2003-05-06 20:59:57 +0000136 p = p.rstrip(os.sep)
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000137
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200138 if host_platform == 'darwin' and is_macosx_sdk_path(p):
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000139 if os.path.join(sysroot, p[1:]) == dirname:
140 return [ p ]
141
Andrew M. Kuchlinga246d9f2002-11-27 13:43:46 +0000142 if p == dirname:
143 return [p]
144 else:
145 assert False, "Internal error: Path not found in std_dirs or paths"
Tim Peters2c60f7a2003-01-29 03:49:43 +0000146
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000147def module_enabled(extlist, modname):
148 """Returns whether the module 'modname' is present in the list
149 of extensions 'extlist'."""
150 extlist = [ext for ext in extlist if ext.name == modname]
151 return len(extlist)
Fredrik Lundhade711a2001-01-24 08:00:28 +0000152
Jack Jansen144ebcc2001-08-05 22:31:19 +0000153def find_module_file(module, dirlist):
154 """Find a module in a set of possible folders. If it is not found
155 return the unadorned filename"""
156 list = find_file(module, [], dirlist)
157 if not list:
158 return module
159 if len(list) > 1:
Guido van Rossum12471d62003-02-20 02:11:43 +0000160 log.info("WARNING: multiple copies of %s found"%module)
Jack Jansen144ebcc2001-08-05 22:31:19 +0000161 return os.path.join(list[0], module)
Michael W. Hudson5b109102002-01-23 15:04:41 +0000162
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000163class PyBuildExt(build_ext):
Fredrik Lundhade711a2001-01-24 08:00:28 +0000164
Guido van Rossumd8faa362007-04-27 19:54:29 +0000165 def __init__(self, dist):
166 build_ext.__init__(self, dist)
167 self.failed = []
168
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000169 def build_extensions(self):
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000170
171 # Detect which modules should be compiled
doko@ubuntu.comd5537d02013-03-21 13:21:49 -0700172 missing = self.detect_modules()
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000173
174 # Remove modules that are present on the disabled list
Christian Heimes679db4a2008-01-18 09:56:22 +0000175 extensions = [ext for ext in self.extensions
176 if ext.name not in disabled_module_list]
177 # move ctypes to the end, it depends on other modules
178 ext_map = dict((ext.name, i) for i, ext in enumerate(extensions))
179 if "_ctypes" in ext_map:
180 ctypes = extensions.pop(ext_map["_ctypes"])
181 extensions.append(ctypes)
182 self.extensions = extensions
Fredrik Lundhade711a2001-01-24 08:00:28 +0000183
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000184 # Fix up the autodetected modules, prefixing all the source files
Neil Schemenauer014bf282009-02-05 16:35:45 +0000185 # with Modules/.
186 srcdir = sysconfig.get_config_var('srcdir')
Guido van Rossume0fea6c2002-10-14 20:48:09 +0000187 if not srcdir:
188 # Maybe running on Windows but not using CYGWIN?
189 raise ValueError("No source directory; cannot proceed.")
Neil Schemenauer4d491a52009-02-06 00:27:50 +0000190 srcdir = os.path.abspath(srcdir)
Neil Schemenauer014bf282009-02-05 16:35:45 +0000191 moddirlist = [os.path.join(srcdir, 'Modules')]
Michael W. Hudson5b109102002-01-23 15:04:41 +0000192
Andrew M. Kuchling3da989c2001-02-28 22:49:26 +0000193 # Fix up the paths for scripts, too
194 self.distribution.scripts = [os.path.join(srcdir, filename)
195 for filename in self.distribution.scripts]
196
Christian Heimesaf98da12008-01-27 15:18:18 +0000197 # Python header files
Neil Schemenauer014bf282009-02-05 16:35:45 +0000198 headers = [sysconfig.get_config_h_filename()]
Stefan Kraheb977da2012-02-29 14:10:53 +0100199 headers += glob(os.path.join(sysconfig.get_path('include'), "*.h"))
Christian Heimesaf98da12008-01-27 15:18:18 +0000200
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000201 for ext in self.extensions[:]:
Jack Jansen144ebcc2001-08-05 22:31:19 +0000202 ext.sources = [ find_module_file(filename, moddirlist)
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000203 for filename in ext.sources ]
Jeremy Hylton340043e2002-06-13 17:38:11 +0000204 if ext.depends is not None:
Neil Schemenauer014bf282009-02-05 16:35:45 +0000205 ext.depends = [find_module_file(filename, moddirlist)
Jeremy Hylton340043e2002-06-13 17:38:11 +0000206 for filename in ext.depends]
Christian Heimesaf98da12008-01-27 15:18:18 +0000207 else:
208 ext.depends = []
209 # re-compile extensions if a header file has been changed
210 ext.depends.extend(headers)
211
Andrew M. Kuchlinge7c87322001-01-19 16:58:21 +0000212 # If a module has already been built statically,
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000213 # don't build it here
Andrew M. Kuchlinge7c87322001-01-19 16:58:21 +0000214 if ext.name in sys.builtin_module_names:
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000215 self.extensions.remove(ext)
Andrew M. Kuchling5bbc7b92001-01-18 20:39:34 +0000216
Ronald Oussoren94f25282010-05-05 19:11:21 +0000217 # Parse Modules/Setup and Modules/Setup.local to figure out which
218 # modules are turned on in the file.
219 remove_modules = []
220 for filename in ('Modules/Setup', 'Modules/Setup.local'):
221 input = text_file.TextFile(filename, join_lines=1)
222 while 1:
223 line = input.readline()
224 if not line: break
225 line = line.split()
226 remove_modules.append(line[0])
227 input.close()
Tim Peters1b27f862005-12-30 18:42:42 +0000228
Ronald Oussoren94f25282010-05-05 19:11:21 +0000229 for ext in self.extensions[:]:
230 if ext.name in remove_modules:
231 self.extensions.remove(ext)
Michael W. Hudson5b109102002-01-23 15:04:41 +0000232
Andrew M. Kuchling5bbc7b92001-01-18 20:39:34 +0000233 # When you run "make CC=altcc" or something similar, you really want
234 # those environment variables passed into the setup.py phase. Here's
235 # a small set of useful ones.
236 compiler = os.environ.get('CC')
Andrew M. Kuchling5bbc7b92001-01-18 20:39:34 +0000237 args = {}
238 # unfortunately, distutils doesn't let us provide separate C and C++
239 # compilers
240 if compiler is not None:
Martin v. Löwisd7c795e2005-04-25 07:14:03 +0000241 (ccshared,cflags) = sysconfig.get_config_vars('CCSHARED','CFLAGS')
242 args['compiler_so'] = compiler + ' ' + ccshared + ' ' + cflags
Tarek Ziadé36797272010-07-22 12:50:05 +0000243 self.compiler.set_executables(**args)
Andrew M. Kuchling5bbc7b92001-01-18 20:39:34 +0000244
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000245 build_ext.build_extensions(self)
246
Guido van Rossumd8faa362007-04-27 19:54:29 +0000247 longest = max([len(e.name) for e in self.extensions])
248 if self.failed:
249 longest = max(longest, max([len(name) for name in self.failed]))
250
251 def print_three_column(lst):
252 lst.sort(key=str.lower)
253 # guarantee zip() doesn't drop anything
254 while len(lst) % 3:
255 lst.append("")
256 for e, f, g in zip(lst[::3], lst[1::3], lst[2::3]):
257 print("%-*s %-*s %-*s" % (longest, e, longest, f,
258 longest, g))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000259
260 if missing:
261 print()
Brett Cannonae95b4f2013-07-12 11:30:32 -0400262 print("Python build finished successfully!")
263 print("The necessary bits to build these optional modules were not "
264 "found:")
Guido van Rossumd8faa362007-04-27 19:54:29 +0000265 print_three_column(missing)
Guido van Rossum04110fb2007-08-24 16:32:05 +0000266 print("To find the necessary bits, look in setup.py in"
267 " detect_modules() for the module's name.")
268 print()
Guido van Rossumd8faa362007-04-27 19:54:29 +0000269
270 if self.failed:
271 failed = self.failed[:]
272 print()
273 print("Failed to build these modules:")
274 print_three_column(failed)
Guido van Rossum04110fb2007-08-24 16:32:05 +0000275 print()
Guido van Rossumd8faa362007-04-27 19:54:29 +0000276
Marc-André Lemburg7c6fcda2001-01-26 18:03:24 +0000277 def build_extension(self, ext):
278
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000279 if ext.name == '_ctypes':
280 if not self.configure_ctypes(ext):
281 return
282
Marc-André Lemburg7c6fcda2001-01-26 18:03:24 +0000283 try:
284 build_ext.build_extension(self, ext)
Guido van Rossumb940e112007-01-10 16:19:56 +0000285 except (CCompilerError, DistutilsError) as why:
Marc-André Lemburg7c6fcda2001-01-26 18:03:24 +0000286 self.announce('WARNING: building of extension "%s" failed: %s' %
287 (ext.name, sys.exc_info()[1]))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000288 self.failed.append(ext.name)
Andrew M. Kuchling62686692001-05-21 20:48:09 +0000289 return
Jack Jansenf49c6f92001-11-01 14:44:15 +0000290 # Workaround for Mac OS X: The Carbon-based modules cannot be
291 # reliably imported into a command-line Python
292 if 'Carbon' in ext.extra_link_args:
Michael W. Hudson5b109102002-01-23 15:04:41 +0000293 self.announce(
294 'WARNING: skipping import check for Carbon-based "%s"' %
295 ext.name)
296 return
Georg Brandlfcaf9102008-07-16 02:17:56 +0000297
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200298 if host_platform == 'darwin' and (
Benjamin Petersonfc576352008-07-16 02:39:02 +0000299 sys.maxsize > 2**32 and '-arch' in ext.extra_link_args):
Georg Brandlfcaf9102008-07-16 02:17:56 +0000300 # Don't bother doing an import check when an extension was
301 # build with an explicit '-arch' flag on OSX. That's currently
302 # only used to build 32-bit only extensions in a 4-way
303 # universal build and loading 32-bit code into a 64-bit
304 # process will fail.
305 self.announce(
306 'WARNING: skipping import check for "%s"' %
307 ext.name)
308 return
309
Jason Tishler24cf7762002-05-22 16:46:15 +0000310 # Workaround for Cygwin: Cygwin currently has fork issues when many
311 # modules have been imported
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200312 if host_platform == 'cygwin':
Jason Tishler24cf7762002-05-22 16:46:15 +0000313 self.announce('WARNING: skipping import check for Cygwin-based "%s"'
314 % ext.name)
315 return
Michael W. Hudsonaf142892002-01-23 15:07:46 +0000316 ext_filename = os.path.join(
317 self.build_lib,
318 self.get_ext_filename(self.get_ext_fullname(ext.name)))
Guido van Rossumc3fee692008-07-17 16:23:53 +0000319
320 # If the build directory didn't exist when setup.py was
321 # started, sys.path_importer_cache has a negative result
322 # cached. Clear that cache before trying to import.
323 sys.path_importer_cache.clear()
324
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200325 # Don't try to load extensions for cross builds
326 if cross_compiling:
327 return
328
Brett Cannonca5ff3a2013-06-15 17:52:59 -0400329 loader = importlib.machinery.ExtensionFileLoader(ext.name, ext_filename)
Andrew M. Kuchling62686692001-05-21 20:48:09 +0000330 try:
Brett Cannonca5ff3a2013-06-15 17:52:59 -0400331 loader.load_module()
Guido van Rossumb940e112007-01-10 16:19:56 +0000332 except ImportError as why:
Guido van Rossumd8faa362007-04-27 19:54:29 +0000333 self.failed.append(ext.name)
Neal Norwitz6e2d1c72003-02-28 17:39:42 +0000334 self.announce('*** WARNING: renaming "%s" since importing it'
335 ' failed: %s' % (ext.name, why), level=3)
336 assert not self.inplace
337 basename, tail = os.path.splitext(ext_filename)
338 newname = basename + "_failed" + tail
339 if os.path.exists(newname):
340 os.remove(newname)
341 os.rename(ext_filename, newname)
342
343 # XXX -- This relies on a Vile HACK in
344 # distutils.command.build_ext.build_extension(). The
345 # _built_objects attribute is stored there strictly for
346 # use here.
347 # If there is a failure, _built_objects may not be there,
348 # so catch the AttributeError and move on.
349 try:
350 for filename in self._built_objects:
351 os.remove(filename)
352 except AttributeError:
353 self.announce('unable to remove files (ignored)')
Neal Norwitz3f5fcc82003-02-28 17:21:39 +0000354 except:
Neal Norwitz3f5fcc82003-02-28 17:21:39 +0000355 exc_type, why, tb = sys.exc_info()
Neal Norwitz6e2d1c72003-02-28 17:39:42 +0000356 self.announce('*** WARNING: importing extension "%s" '
357 'failed with %s: %s' % (ext.name, exc_type, why),
358 level=3)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000359 self.failed.append(ext.name)
Fred Drake9028d0a2001-12-06 22:59:54 +0000360
Barry Warsaw5ca305a2011-04-06 15:18:12 -0400361 def add_multiarch_paths(self):
362 # Debian/Ubuntu multiarch support.
363 # https://wiki.ubuntu.com/MultiarchSpec
doko@ubuntu.com3277b352012-08-08 12:15:55 +0200364 cc = sysconfig.get_config_var('CC')
365 tmpfile = os.path.join(self.build_temp, 'multiarch')
366 if not os.path.exists(self.build_temp):
367 os.makedirs(self.build_temp)
368 ret = os.system(
369 '%s -print-multiarch > %s 2> /dev/null' % (cc, tmpfile))
370 multiarch_path_component = ''
371 try:
372 if ret >> 8 == 0:
373 with open(tmpfile) as fp:
374 multiarch_path_component = fp.readline().strip()
375 finally:
376 os.unlink(tmpfile)
377
378 if multiarch_path_component != '':
379 add_dir_to_list(self.compiler.library_dirs,
380 '/usr/lib/' + multiarch_path_component)
381 add_dir_to_list(self.compiler.include_dirs,
382 '/usr/include/' + multiarch_path_component)
383 return
384
Barry Warsaw88e19452011-04-07 10:40:36 -0400385 if not find_executable('dpkg-architecture'):
386 return
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200387 opt = ''
388 if cross_compiling:
389 opt = '-t' + sysconfig.get_config_var('HOST_GNU_TYPE')
Barry Warsaw5ca305a2011-04-06 15:18:12 -0400390 tmpfile = os.path.join(self.build_temp, 'multiarch')
391 if not os.path.exists(self.build_temp):
392 os.makedirs(self.build_temp)
393 ret = os.system(
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200394 'dpkg-architecture %s -qDEB_HOST_MULTIARCH > %s 2> /dev/null' %
395 (opt, tmpfile))
Barry Warsaw5ca305a2011-04-06 15:18:12 -0400396 try:
397 if ret >> 8 == 0:
398 with open(tmpfile) as fp:
399 multiarch_path_component = fp.readline().strip()
400 add_dir_to_list(self.compiler.library_dirs,
401 '/usr/lib/' + multiarch_path_component)
402 add_dir_to_list(self.compiler.include_dirs,
403 '/usr/include/' + multiarch_path_component)
404 finally:
405 os.unlink(tmpfile)
406
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200407 def add_gcc_paths(self):
408 gcc = sysconfig.get_config_var('CC')
409 tmpfile = os.path.join(self.build_temp, 'gccpaths')
410 if not os.path.exists(self.build_temp):
411 os.makedirs(self.build_temp)
412 ret = os.system('%s -E -v - </dev/null 2>%s 1>/dev/null' % (gcc, tmpfile))
413 is_gcc = False
414 in_incdirs = False
415 inc_dirs = []
416 lib_dirs = []
417 try:
418 if ret >> 8 == 0:
419 with open(tmpfile) as fp:
420 for line in fp.readlines():
421 if line.startswith("gcc version"):
422 is_gcc = True
423 elif line.startswith("#include <...>"):
424 in_incdirs = True
425 elif line.startswith("End of search list"):
426 in_incdirs = False
427 elif is_gcc and line.startswith("LIBRARY_PATH"):
428 for d in line.strip().split("=")[1].split(":"):
429 d = os.path.normpath(d)
430 if '/gcc/' not in d:
431 add_dir_to_list(self.compiler.library_dirs,
432 d)
433 elif is_gcc and in_incdirs and '/gcc/' not in line:
434 add_dir_to_list(self.compiler.include_dirs,
435 line.strip())
436 finally:
437 os.unlink(tmpfile)
438
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000439 def detect_modules(self):
Barry Warsaw807bd0a2010-11-24 20:30:00 +0000440 # Ensure that /usr/local is always used, but the local build
441 # directories (i.e. '.' and 'Include') must be first. See issue
442 # 10520.
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200443 if not cross_compiling:
444 add_dir_to_list(self.compiler.library_dirs, '/usr/local/lib')
445 add_dir_to_list(self.compiler.include_dirs, '/usr/local/include')
doko@ubuntu.comcc5addd2012-07-01 00:23:51 +0200446 # only change this for cross builds for 3.3, issues on Mageia
447 if cross_compiling:
448 self.add_gcc_paths()
Barry Warsaw5ca305a2011-04-06 15:18:12 -0400449 self.add_multiarch_paths()
Michael W. Hudson39230b32002-01-16 15:26:48 +0000450
Brett Cannon516592f2004-12-07 00:42:59 +0000451 # Add paths specified in the environment variables LDFLAGS and
Brett Cannon4810eb92004-12-31 08:11:21 +0000452 # CPPFLAGS for header and library files.
Brett Cannon5399c6d2004-12-18 20:48:09 +0000453 # We must get the values from the Makefile and not the environment
454 # directly since an inconsistently reproducible issue comes up where
455 # the environment variable is not set even though the value were passed
Brett Cannon4810eb92004-12-31 08:11:21 +0000456 # into configure and stored in the Makefile (issue found on OS X 10.3).
Brett Cannon516592f2004-12-07 00:42:59 +0000457 for env_var, arg_name, dir_list in (
Tarek Ziadé36797272010-07-22 12:50:05 +0000458 ('LDFLAGS', '-R', self.compiler.runtime_library_dirs),
459 ('LDFLAGS', '-L', self.compiler.library_dirs),
460 ('CPPFLAGS', '-I', self.compiler.include_dirs)):
Brett Cannon5399c6d2004-12-18 20:48:09 +0000461 env_val = sysconfig.get_config_var(env_var)
Brett Cannon516592f2004-12-07 00:42:59 +0000462 if env_val:
Brett Cannon4810eb92004-12-31 08:11:21 +0000463 # To prevent optparse from raising an exception about any
Skip Montanaroa5c2a512008-10-07 02:51:48 +0000464 # options in env_val that it doesn't know about we strip out
Brett Cannon4810eb92004-12-31 08:11:21 +0000465 # all double dashes and any dashes followed by a character
466 # that is not for the option we are dealing with.
467 #
468 # Please note that order of the regex is important! We must
469 # strip out double-dashes first so that we don't end up with
470 # substituting "--Long" to "-Long" and thus lead to "ong" being
471 # used for a library directory.
Guido van Rossum04110fb2007-08-24 16:32:05 +0000472 env_val = re.sub(r'(^|\s+)-(-|(?!%s))' % arg_name[1],
473 ' ', env_val)
Brett Cannon84667c02004-12-07 03:25:18 +0000474 parser = optparse.OptionParser()
Brett Cannon4810eb92004-12-31 08:11:21 +0000475 # Make sure that allowing args interspersed with options is
476 # allowed
477 parser.allow_interspersed_args = True
478 parser.error = lambda msg: None
Brett Cannon84667c02004-12-07 03:25:18 +0000479 parser.add_option(arg_name, dest="dirs", action="append")
480 options = parser.parse_args(env_val.split())[0]
Brett Cannon44837712005-01-02 21:54:07 +0000481 if options.dirs:
Christian Heimes292d3512008-02-03 16:51:08 +0000482 for directory in reversed(options.dirs):
Brett Cannon44837712005-01-02 21:54:07 +0000483 add_dir_to_list(dir_list, directory)
Skip Montanarodecc6a42003-01-01 20:07:49 +0000484
Vinay Sajip7ded1f02012-05-26 03:45:29 +0100485 if os.path.normpath(sys.base_prefix) != '/usr' \
Ronald Oussorenf3500e12010-10-20 13:10:12 +0000486 and not sysconfig.get_config_var('PYTHONFRAMEWORK'):
487 # OSX note: Don't add LIBDIR and INCLUDEDIR to building a framework
488 # (PYTHONFRAMEWORK is set) to avoid # linking problems when
489 # building a framework with different architectures than
490 # the one that is currently installed (issue #7473)
Tarek Ziadé36797272010-07-22 12:50:05 +0000491 add_dir_to_list(self.compiler.library_dirs,
Michael W. Hudson90b8e4d2002-08-02 13:55:50 +0000492 sysconfig.get_config_var("LIBDIR"))
Tarek Ziadé36797272010-07-22 12:50:05 +0000493 add_dir_to_list(self.compiler.include_dirs,
Michael W. Hudson90b8e4d2002-08-02 13:55:50 +0000494 sysconfig.get_config_var("INCLUDEDIR"))
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000495
496 # lib_dirs and inc_dirs are used to search for files;
497 # if a file is found in one of those directories, it can
498 # be assumed that no additional -I,-L directives are needed.
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200499 if not cross_compiling:
doko@ubuntu.comcc5addd2012-07-01 00:23:51 +0200500 lib_dirs = self.compiler.library_dirs + [
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200501 '/lib64', '/usr/lib64',
502 '/lib', '/usr/lib',
doko@ubuntu.comcc5addd2012-07-01 00:23:51 +0200503 ]
504 inc_dirs = self.compiler.include_dirs + ['/usr/include']
Christian Heimesf19529c2012-12-12 12:41:00 +0100505 else:
Christian Heimesd7832612012-12-12 12:56:51 +0100506 lib_dirs = self.compiler.library_dirs[:]
507 inc_dirs = self.compiler.include_dirs[:]
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000508 exts = []
Guido van Rossumd8faa362007-04-27 19:54:29 +0000509 missing = []
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000510
Brett Cannon4454a1f2005-04-15 20:32:39 +0000511 config_h = sysconfig.get_config_h_filename()
Brett Cannon9f5db072010-10-29 20:19:27 +0000512 with open(config_h) as file:
513 config_h_vars = sysconfig.parse_config_h(file)
Brett Cannon4454a1f2005-04-15 20:32:39 +0000514
Neil Schemenauer014bf282009-02-05 16:35:45 +0000515 srcdir = sysconfig.get_config_var('srcdir')
Michael W. Hudson5b109102002-01-23 15:04:41 +0000516
Andrew M. Kuchling7883dc82003-10-24 18:26:26 +0000517 # OSF/1 and Unixware have some stuff in /usr/ccs/lib (like -ldb)
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200518 if host_platform in ['osf1', 'unixware7', 'openunix8']:
Skip Montanaro22e00c42003-05-06 20:43:34 +0000519 lib_dirs += ['/usr/ccs/lib']
520
Charles-François Natali5739e102012-04-12 19:07:25 +0200521 # HP-UX11iv3 keeps files in lib/hpux folders.
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200522 if host_platform == 'hp-ux11':
Charles-François Natali5739e102012-04-12 19:07:25 +0200523 lib_dirs += ['/usr/lib/hpux64', '/usr/lib/hpux32']
524
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200525 if host_platform == 'darwin':
Thomas Wouters477c8d52006-05-27 19:21:47 +0000526 # This should work on any unixy platform ;-)
527 # If the user has bothered specifying additional -I and -L flags
528 # in OPT and LDFLAGS we might as well use them here.
Barry Warsaw807bd0a2010-11-24 20:30:00 +0000529 #
530 # NOTE: using shlex.split would technically be more correct, but
531 # also gives a bootstrap problem. Let's hope nobody uses
532 # directories with whitespace in the name to store libraries.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000533 cflags, ldflags = sysconfig.get_config_vars(
534 'CFLAGS', 'LDFLAGS')
535 for item in cflags.split():
536 if item.startswith('-I'):
537 inc_dirs.append(item[2:])
538
539 for item in ldflags.split():
540 if item.startswith('-L'):
541 lib_dirs.append(item[2:])
542
Fredrik Lundhade711a2001-01-24 08:00:28 +0000543 # Check for MacOS X, which doesn't need libm.a at all
544 math_libs = ['m']
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200545 if host_platform == 'darwin':
Fredrik Lundhade711a2001-01-24 08:00:28 +0000546 math_libs = []
Michael W. Hudson5b109102002-01-23 15:04:41 +0000547
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000548 # XXX Omitted modules: gl, pure, dl, SGI-specific modules
549
550 #
551 # The following modules are all pretty straightforward, and compile
552 # on pretty much any POSIXish platform.
553 #
Fredrik Lundhade711a2001-01-24 08:00:28 +0000554
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000555 # array objects
556 exts.append( Extension('array', ['arraymodule.c']) )
557 # complex math library functions
Mark Dickinsonf3718592009-12-21 15:27:41 +0000558 exts.append( Extension('cmath', ['cmathmodule.c', '_math.c'],
559 depends=['_math.h'],
Andrew M. Kuchling5ddb25f2001-01-23 22:21:11 +0000560 libraries=math_libs) )
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000561 # math library functions, e.g. sin()
Mark Dickinson664b5112009-12-16 20:23:42 +0000562 exts.append( Extension('math', ['mathmodule.c', '_math.c'],
Mark Dickinson8a591132009-12-17 08:35:56 +0000563 depends=['_math.h'],
Andrew M. Kuchling5ddb25f2001-01-23 22:21:11 +0000564 libraries=math_libs) )
Victor Stinnere0be4232011-10-25 13:06:09 +0200565
566 # time libraries: librt may be needed for clock_gettime()
567 time_libs = []
568 lib = sysconfig.get_config_var('TIMEMODULE_LIB')
569 if lib:
570 time_libs.append(lib)
571
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000572 # time operations and variables
Victor Stinner5d272cc2012-03-13 13:35:55 +0100573 exts.append( Extension('time', ['timemodule.c'],
Victor Stinnere0be4232011-10-25 13:06:09 +0200574 libraries=time_libs) )
Victor Stinner5d272cc2012-03-13 13:35:55 +0100575 exts.append( Extension('_datetime', ['_datetimemodule.c']) )
Christian Heimesfe337bf2008-03-23 21:54:12 +0000576 # random number generator implemented in C
577 exts.append( Extension("_random", ["_randommodule.c"]) )
Raymond Hettinger0c410272004-01-05 10:13:35 +0000578 # bisect
579 exts.append( Extension("_bisect", ["_bisectmodule.c"]) )
Raymond Hettingerb3af1812003-11-08 10:24:38 +0000580 # heapq
Raymond Hettingerc46cb2a2004-04-19 19:06:21 +0000581 exts.append( Extension("_heapq", ["_heapqmodule.c"]) )
Alexandre Vassalottica2d6102008-06-12 18:26:05 +0000582 # C-optimized pickle replacement
583 exts.append( Extension("_pickle", ["_pickle.c"]) )
Collin Winter670e6922007-03-21 02:57:17 +0000584 # atexit
585 exts.append( Extension("atexit", ["atexitmodule.c"]) )
Christian Heimes90540002008-05-08 14:29:10 +0000586 # _json speedups
587 exts.append( Extension("_json", ["_json.c"]) )
Marc-André Lemburg261b8e22001-02-02 12:12:44 +0000588 # Python C API test module
Mark Dickinsona06f44b2009-02-10 16:18:22 +0000589 exts.append( Extension('_testcapi', ['_testcapimodule.c'],
590 depends=['testcapi_long.h']) )
Stefan Krah9a2d99e2012-02-25 12:24:21 +0100591 # Python PEP-3118 (buffer protocol) test module
592 exts.append( Extension('_testbuffer', ['_testbuffer.c']) )
Andrew Svetlov6b2cbeb2012-12-14 17:04:59 +0200593 # Test loading multiple modules from one compiled file (http://bugs.python.org/issue16421)
594 exts.append( Extension('_testimportmultiple', ['_testimportmultiple.c']) )
Fred Drake0e474a82007-10-11 18:01:43 +0000595 # profiler (_lsprof is for cProfile.py)
Armin Rigoa871ef22006-02-08 12:53:56 +0000596 exts.append( Extension('_lsprof', ['_lsprof.c', 'rotatingtree.c']) )
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000597 # static Unicode character database
Walter Dörwalde9eaab42007-05-22 16:02:13 +0000598 exts.append( Extension('unicodedata', ['unicodedata.c']) )
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000599
600 # Modules with some UNIX dependencies -- on by default:
601 # (If you have a really backward UNIX, select and socket may not be
602 # supported...)
603
604 # fcntl(2) and ioctl(2)
Antoine Pitroua3000072010-09-07 14:52:42 +0000605 libs = []
606 if (config_h_vars.get('FLOCK_NEEDS_LIBBSD', False)):
607 # May be necessary on AIX for flock function
608 libs = ['bsd']
609 exts.append( Extension('fcntl', ['fcntlmodule.c'], libraries=libs) )
Ronald Oussoren94f25282010-05-05 19:11:21 +0000610 # pwd(3)
611 exts.append( Extension('pwd', ['pwdmodule.c']) )
612 # grp(3)
613 exts.append( Extension('grp', ['grpmodule.c']) )
614 # spwd, shadow passwords
615 if (config_h_vars.get('HAVE_GETSPNAM', False) or
616 config_h_vars.get('HAVE_GETSPENT', False)):
617 exts.append( Extension('spwd', ['spwdmodule.c']) )
Guido van Rossumd8faa362007-04-27 19:54:29 +0000618 else:
Ronald Oussoren94f25282010-05-05 19:11:21 +0000619 missing.append('spwd')
Guido van Rossumd8faa362007-04-27 19:54:29 +0000620
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000621 # select(2); not on ancient System V
622 exts.append( Extension('select', ['selectmodule.c']) )
623
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000624 # Fred Drake's interface to the Python parser
625 exts.append( Extension('parser', ['parsermodule.c']) )
626
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000627 # Memory-mapped files (also works on Win32).
Ronald Oussoren94f25282010-05-05 19:11:21 +0000628 exts.append( Extension('mmap', ['mmapmodule.c']) )
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000629
Andrew M. Kuchling57269d02004-08-31 13:37:25 +0000630 # Lance Ellinghaus's syslog module
Ronald Oussoren94f25282010-05-05 19:11:21 +0000631 # syslog daemon interface
632 exts.append( Extension('syslog', ['syslogmodule.c']) )
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000633
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000634 #
Andrew M. Kuchling5bbc7b92001-01-18 20:39:34 +0000635 # Here ends the simple stuff. From here on, modules need certain
636 # libraries, are platform-specific, or present other surprises.
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000637 #
638
639 # Multimedia modules
640 # These don't work for 64-bit platforms!!!
641 # These represent audio samples or images as strings:
642
Neal Norwitz5e4a3b82004-07-19 16:55:07 +0000643 # Operations on audio samples
Tim Petersf9cbf212004-07-23 02:50:10 +0000644 # According to #993173, this one should actually work fine on
Martin v. Löwis8fbefe22004-07-19 16:42:20 +0000645 # 64-bit platforms.
646 exts.append( Extension('audioop', ['audioop.c']) )
647
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000648 # readline
Tarek Ziadé36797272010-07-22 12:50:05 +0000649 do_readline = self.compiler.find_library_file(lib_dirs, 'readline')
Stefan Krah095b2732010-06-08 13:41:44 +0000650 readline_termcap_library = ""
651 curses_library = ""
doko@ubuntu.com58844492012-06-30 18:25:32 +0200652 # Cannot use os.popen here in py3k.
653 tmpfile = os.path.join(self.build_temp, 'readline_termcap_lib')
654 if not os.path.exists(self.build_temp):
655 os.makedirs(self.build_temp)
Stefan Krah095b2732010-06-08 13:41:44 +0000656 # Determine if readline is already linked against curses or tinfo.
doko@ubuntu.com58844492012-06-30 18:25:32 +0200657 if do_readline:
658 if cross_compiling:
659 ret = os.system("%s -d %s | grep '(NEEDED)' > %s" \
660 % (sysconfig.get_config_var('READELF'),
661 do_readline, tmpfile))
662 elif find_executable('ldd'):
663 ret = os.system("ldd %s > %s" % (do_readline, tmpfile))
664 else:
665 ret = 256
doko@ubuntu.com4c990712012-06-30 23:28:09 +0200666 if ret >> 8 == 0:
Brett Cannon9f5db072010-10-29 20:19:27 +0000667 with open(tmpfile) as fp:
668 for ln in fp:
669 if 'curses' in ln:
670 readline_termcap_library = re.sub(
671 r'.*lib(n?cursesw?)\.so.*', r'\1', ln
672 ).rstrip()
673 break
674 # termcap interface split out from ncurses
675 if 'tinfo' in ln:
676 readline_termcap_library = 'tinfo'
677 break
doko@ubuntu.com4c990712012-06-30 23:28:09 +0200678 if os.path.exists(tmpfile):
679 os.unlink(tmpfile)
Stefan Krah095b2732010-06-08 13:41:44 +0000680 # Issue 7384: If readline is already linked against curses,
681 # use the same library for the readline and curses modules.
682 if 'curses' in readline_termcap_library:
683 curses_library = readline_termcap_library
Tarek Ziadé36797272010-07-22 12:50:05 +0000684 elif self.compiler.find_library_file(lib_dirs, 'ncursesw'):
Stefan Krah095b2732010-06-08 13:41:44 +0000685 curses_library = 'ncursesw'
Tarek Ziadé36797272010-07-22 12:50:05 +0000686 elif self.compiler.find_library_file(lib_dirs, 'ncurses'):
Stefan Krah095b2732010-06-08 13:41:44 +0000687 curses_library = 'ncurses'
Tarek Ziadé36797272010-07-22 12:50:05 +0000688 elif self.compiler.find_library_file(lib_dirs, 'curses'):
Stefan Krah095b2732010-06-08 13:41:44 +0000689 curses_library = 'curses'
690
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200691 if host_platform == 'darwin':
Ronald Oussoren2efd9242009-09-20 14:53:22 +0000692 os_release = int(os.uname()[2].split('.')[0])
Ronald Oussoren961683a2010-03-08 07:09:59 +0000693 dep_target = sysconfig.get_config_var('MACOSX_DEPLOYMENT_TARGET')
694 if dep_target and dep_target.split('.') < ['10', '5']:
695 os_release = 8
Ronald Oussoren2efd9242009-09-20 14:53:22 +0000696 if os_release < 9:
697 # MacOSX 10.4 has a broken readline. Don't try to build
698 # the readline module unless the user has installed a fixed
699 # readline package
700 if find_file('readline/rlconf.h', inc_dirs, []) is None:
701 do_readline = False
Jack Jansen81ae2352006-02-23 15:02:23 +0000702 if do_readline:
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200703 if host_platform == 'darwin' and os_release < 9:
Thomas Wouters477c8d52006-05-27 19:21:47 +0000704 # In every directory on the search path search for a dynamic
705 # library and then a static library, instead of first looking
Fred Drake0af17612007-09-04 19:43:19 +0000706 # for dynamic libraries on the entire path.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000707 # This way a staticly linked custom readline gets picked up
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000708 # before the (possibly broken) dynamic library in /usr/lib.
Thomas Wouters477c8d52006-05-27 19:21:47 +0000709 readline_extra_link_args = ('-Wl,-search_paths_first',)
710 else:
711 readline_extra_link_args = ()
712
Marc-André Lemburg2efc3232001-01-26 18:23:02 +0000713 readline_libs = ['readline']
Stefan Krah095b2732010-06-08 13:41:44 +0000714 if readline_termcap_library:
715 pass # Issue 7384: Already linked against curses or tinfo.
716 elif curses_library:
717 readline_libs.append(curses_library)
Tarek Ziadé36797272010-07-22 12:50:05 +0000718 elif self.compiler.find_library_file(lib_dirs +
Tarek Ziadédd07ebb2009-07-06 13:52:17 +0000719 ['/usr/lib/termcap'],
720 'termcap'):
Marc-André Lemburg2efc3232001-01-26 18:23:02 +0000721 readline_libs.append('termcap')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000722 exts.append( Extension('readline', ['readline.c'],
Marc-André Lemburg7c6fcda2001-01-26 18:03:24 +0000723 library_dirs=['/usr/lib/termcap'],
Thomas Wouters477c8d52006-05-27 19:21:47 +0000724 extra_link_args=readline_extra_link_args,
Marc-André Lemburg2efc3232001-01-26 18:23:02 +0000725 libraries=readline_libs) )
Guido van Rossumd8faa362007-04-27 19:54:29 +0000726 else:
727 missing.append('readline')
728
Ronald Oussoren94f25282010-05-05 19:11:21 +0000729 # crypt module.
Tim Peters2c60f7a2003-01-29 03:49:43 +0000730
Tarek Ziadé36797272010-07-22 12:50:05 +0000731 if self.compiler.find_library_file(lib_dirs, 'crypt'):
Ronald Oussoren94f25282010-05-05 19:11:21 +0000732 libs = ['crypt']
Guido van Rossumd8faa362007-04-27 19:54:29 +0000733 else:
Ronald Oussoren94f25282010-05-05 19:11:21 +0000734 libs = []
Sean Reifscheidere2dfefb2011-02-22 10:55:44 +0000735 exts.append( Extension('_crypt', ['_cryptmodule.c'], libraries=libs) )
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000736
Skip Montanaroba9e9782003-03-20 23:34:22 +0000737 # CSV files
738 exts.append( Extension('_csv', ['_csv.c']) )
739
Gregory P. Smithfb94c5f2010-03-14 06:49:55 +0000740 # POSIX subprocess module helper.
741 exts.append( Extension('_posixsubprocess', ['_posixsubprocess.c']) )
742
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000743 # socket(2)
Guido van Rossum47d3a7a2002-06-13 14:41:32 +0000744 exts.append( Extension('_socket', ['socketmodule.c'],
Jeremy Hylton340043e2002-06-13 17:38:11 +0000745 depends = ['socketmodule.h']) )
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000746 # Detect SSL support for the socket module (via _ssl)
Gregory P. Smithade97332005-08-23 21:19:40 +0000747 search_for_ssl_incs_in = [
748 '/usr/local/ssl/include',
Andrew M. Kuchlinge7c87322001-01-19 16:58:21 +0000749 '/usr/contrib/ssl/include/'
750 ]
Gregory P. Smithade97332005-08-23 21:19:40 +0000751 ssl_incs = find_file('openssl/ssl.h', inc_dirs,
752 search_for_ssl_incs_in
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000753 )
Martin v. Löwisa950f7f2003-05-09 09:05:19 +0000754 if ssl_incs is not None:
755 krb5_h = find_file('krb5.h', inc_dirs,
756 ['/usr/kerberos/include'])
757 if krb5_h:
758 ssl_incs += krb5_h
Tarek Ziadé36797272010-07-22 12:50:05 +0000759 ssl_libs = find_library_file(self.compiler, 'ssl',lib_dirs,
Andrew M. Kuchlinge7c87322001-01-19 16:58:21 +0000760 ['/usr/local/ssl/lib',
761 '/usr/contrib/ssl/lib/'
762 ] )
Fredrik Lundhade711a2001-01-24 08:00:28 +0000763
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000764 if (ssl_incs is not None and
765 ssl_libs is not None):
Marc-André Lemburga5d2b4c2002-02-16 18:23:30 +0000766 exts.append( Extension('_ssl', ['_ssl.c'],
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +0000767 include_dirs = ssl_incs,
Fredrik Lundhade711a2001-01-24 08:00:28 +0000768 library_dirs = ssl_libs,
Guido van Rossum47d3a7a2002-06-13 14:41:32 +0000769 libraries = ['ssl', 'crypto'],
Jeremy Hylton340043e2002-06-13 17:38:11 +0000770 depends = ['socketmodule.h']), )
Guido van Rossumd8faa362007-04-27 19:54:29 +0000771 else:
772 missing.append('_ssl')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +0000773
Gregory P. Smithade97332005-08-23 21:19:40 +0000774 # find out which version of OpenSSL we have
775 openssl_ver = 0
776 openssl_ver_re = re.compile(
777 '^\s*#\s*define\s+OPENSSL_VERSION_NUMBER\s+(0x[0-9a-fA-F]+)' )
Gregory P. Smithade97332005-08-23 21:19:40 +0000778
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000779 # look for the openssl version header on the compiler search path.
780 opensslv_h = find_file('openssl/opensslv.h', [],
781 inc_dirs + search_for_ssl_incs_in)
782 if opensslv_h:
783 name = os.path.join(opensslv_h[0], 'openssl/opensslv.h')
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200784 if host_platform == 'darwin' and is_macosx_sdk_path(name):
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000785 name = os.path.join(macosx_sdk_root(), name[1:])
786 try:
Brett Cannon9f5db072010-10-29 20:19:27 +0000787 with open(name, 'r') as incfile:
788 for line in incfile:
789 m = openssl_ver_re.match(line)
790 if m:
Antoine Pitrou2463e5f2013-03-28 22:24:43 +0100791 openssl_ver = int(m.group(1), 16)
792 break
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000793 except IOError as msg:
794 print("IOError while reading opensshv.h:", msg)
Gregory P. Smithade97332005-08-23 21:19:40 +0000795
Guido van Rossumeb1cf4e2007-08-17 17:14:17 +0000796 #print('openssl_ver = 0x%08x' % openssl_ver)
Gregory P. Smithb04ded42010-01-03 00:38:10 +0000797 min_openssl_ver = 0x00907000
798 have_any_openssl = ssl_incs is not None and ssl_libs is not None
799 have_usable_openssl = (have_any_openssl and
800 openssl_ver >= min_openssl_ver)
Gregory P. Smithade97332005-08-23 21:19:40 +0000801
Gregory P. Smithb04ded42010-01-03 00:38:10 +0000802 if have_any_openssl:
803 if have_usable_openssl:
Guido van Rossumeb1cf4e2007-08-17 17:14:17 +0000804 # The _hashlib module wraps optimized implementations
805 # of hash functions from the OpenSSL library.
806 exts.append( Extension('_hashlib', ['_hashopenssl.c'],
Gregory P. Smith5af7fba2010-01-03 14:51:13 +0000807 depends = ['hashlib.h'],
Guido van Rossumeb1cf4e2007-08-17 17:14:17 +0000808 include_dirs = ssl_incs,
809 library_dirs = ssl_libs,
810 libraries = ['ssl', 'crypto']) )
811 else:
812 print("warning: openssl 0x%08x is too old for _hashlib" %
813 openssl_ver)
814 missing.append('_hashlib')
Gregory P. Smithf21a5f72005-08-21 18:45:59 +0000815
Antoine Pitrou019ff192012-05-16 16:41:26 +0200816 # We always compile these even when OpenSSL is available (issue #14693).
817 # It's harmless and the object code is tiny (40-50 KB per module,
818 # only loaded when actually used).
819 exts.append( Extension('_sha256', ['sha256module.c'],
820 depends=['hashlib.h']) )
821 exts.append( Extension('_sha512', ['sha512module.c'],
822 depends=['hashlib.h']) )
823 exts.append( Extension('_md5', ['md5module.c'],
824 depends=['hashlib.h']) )
825 exts.append( Extension('_sha1', ['sha1module.c'],
826 depends=['hashlib.h']) )
Gregory P. Smith2f21eb32007-09-09 06:44:34 +0000827
Christian Heimes4a0270d2012-10-06 02:23:36 +0200828 # SHA-3 (Keccak) module
829 sha3_depends = ['hashlib.h']
830 keccak = os.path.join(os.getcwd(), srcdir, 'Modules', '_sha3',
831 'keccak')
832 for pattern in ('*.c', '*.h', '*.macros'):
833 sha3_depends.extend(glob(os.path.join(keccak, pattern)))
834 exts.append(Extension("_sha3", ["_sha3/sha3module.c"],
835 depends=sha3_depends))
836
Georg Brandl489cb4f2009-07-11 10:08:49 +0000837 # Modules that provide persistent dictionary-like semantics. You will
838 # probably want to arrange for at least one of them to be available on
839 # your machine, though none are defined by default because of library
840 # dependencies. The Python module dbm/__init__.py provides an
841 # implementation independent wrapper for these; dbm/dumb.py provides
842 # similar functionality (but slower of course) implemented in Python.
843
844 # Sleepycat^WOracle Berkeley DB interface.
845 # http://www.oracle.com/database/berkeley-db/db/index.html
846 #
847 # This requires the Sleepycat^WOracle DB code. The supported versions
848 # are set below. Visit the URL above to download
849 # a release. Most open source OSes come with one or more
850 # versions of BerkeleyDB already installed.
851
doko@ubuntu.com15bac0f2012-07-01 10:35:54 +0200852 max_db_ver = (5, 3)
Georg Brandl489cb4f2009-07-11 10:08:49 +0000853 min_db_ver = (3, 3)
854 db_setup_debug = False # verbose debug prints from this script?
855
856 def allow_db_ver(db_ver):
857 """Returns a boolean if the given BerkeleyDB version is acceptable.
858
859 Args:
860 db_ver: A tuple of the version to verify.
861 """
862 if not (min_db_ver <= db_ver <= max_db_ver):
863 return False
864 return True
865
866 def gen_db_minor_ver_nums(major):
867 if major == 4:
868 for x in range(max_db_ver[1]+1):
869 if allow_db_ver((4, x)):
870 yield x
871 elif major == 3:
872 for x in (3,):
873 if allow_db_ver((3, x)):
874 yield x
875 else:
876 raise ValueError("unknown major BerkeleyDB version", major)
877
878 # construct a list of paths to look for the header file in on
879 # top of the normal inc_dirs.
880 db_inc_paths = [
881 '/usr/include/db4',
882 '/usr/local/include/db4',
883 '/opt/sfw/include/db4',
884 '/usr/include/db3',
885 '/usr/local/include/db3',
886 '/opt/sfw/include/db3',
887 # Fink defaults (http://fink.sourceforge.net/)
888 '/sw/include/db4',
889 '/sw/include/db3',
890 ]
891 # 4.x minor number specific paths
892 for x in gen_db_minor_ver_nums(4):
893 db_inc_paths.append('/usr/include/db4%d' % x)
894 db_inc_paths.append('/usr/include/db4.%d' % x)
895 db_inc_paths.append('/usr/local/BerkeleyDB.4.%d/include' % x)
896 db_inc_paths.append('/usr/local/include/db4%d' % x)
897 db_inc_paths.append('/pkg/db-4.%d/include' % x)
898 db_inc_paths.append('/opt/db-4.%d/include' % x)
899 # MacPorts default (http://www.macports.org/)
900 db_inc_paths.append('/opt/local/include/db4%d' % x)
901 # 3.x minor number specific paths
902 for x in gen_db_minor_ver_nums(3):
903 db_inc_paths.append('/usr/include/db3%d' % x)
904 db_inc_paths.append('/usr/local/BerkeleyDB.3.%d/include' % x)
905 db_inc_paths.append('/usr/local/include/db3%d' % x)
906 db_inc_paths.append('/pkg/db-3.%d/include' % x)
907 db_inc_paths.append('/opt/db-3.%d/include' % x)
908
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +0200909 if cross_compiling:
910 db_inc_paths = []
911
Georg Brandl489cb4f2009-07-11 10:08:49 +0000912 # Add some common subdirectories for Sleepycat DB to the list,
913 # based on the standard include directories. This way DB3/4 gets
914 # picked up when it is installed in a non-standard prefix and
915 # the user has added that prefix into inc_dirs.
916 std_variants = []
917 for dn in inc_dirs:
918 std_variants.append(os.path.join(dn, 'db3'))
919 std_variants.append(os.path.join(dn, 'db4'))
920 for x in gen_db_minor_ver_nums(4):
921 std_variants.append(os.path.join(dn, "db4%d"%x))
922 std_variants.append(os.path.join(dn, "db4.%d"%x))
923 for x in gen_db_minor_ver_nums(3):
924 std_variants.append(os.path.join(dn, "db3%d"%x))
925 std_variants.append(os.path.join(dn, "db3.%d"%x))
926
927 db_inc_paths = std_variants + db_inc_paths
928 db_inc_paths = [p for p in db_inc_paths if os.path.exists(p)]
929
930 db_ver_inc_map = {}
931
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200932 if host_platform == 'darwin':
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000933 sysroot = macosx_sdk_root()
934
Georg Brandl489cb4f2009-07-11 10:08:49 +0000935 class db_found(Exception): pass
936 try:
937 # See whether there is a Sleepycat header in the standard
938 # search path.
939 for d in inc_dirs + db_inc_paths:
940 f = os.path.join(d, "db.h")
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200941 if host_platform == 'darwin' and is_macosx_sdk_path(d):
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000942 f = os.path.join(sysroot, d[1:], "db.h")
943
Georg Brandl489cb4f2009-07-11 10:08:49 +0000944 if db_setup_debug: print("db: looking for db.h in", f)
945 if os.path.exists(f):
Brett Cannon9f5db072010-10-29 20:19:27 +0000946 with open(f, 'rb') as file:
947 f = file.read()
Benjamin Peterson019f3612009-08-12 18:18:03 +0000948 m = re.search(br"#define\WDB_VERSION_MAJOR\W(\d+)", f)
Georg Brandl489cb4f2009-07-11 10:08:49 +0000949 if m:
950 db_major = int(m.group(1))
Benjamin Peterson019f3612009-08-12 18:18:03 +0000951 m = re.search(br"#define\WDB_VERSION_MINOR\W(\d+)", f)
Georg Brandl489cb4f2009-07-11 10:08:49 +0000952 db_minor = int(m.group(1))
953 db_ver = (db_major, db_minor)
954
955 # Avoid 4.6 prior to 4.6.21 due to a BerkeleyDB bug
956 if db_ver == (4, 6):
Benjamin Peterson019f3612009-08-12 18:18:03 +0000957 m = re.search(br"#define\WDB_VERSION_PATCH\W(\d+)", f)
Georg Brandl489cb4f2009-07-11 10:08:49 +0000958 db_patch = int(m.group(1))
959 if db_patch < 21:
960 print("db.h:", db_ver, "patch", db_patch,
961 "being ignored (4.6.x must be >= 4.6.21)")
962 continue
963
964 if ( (db_ver not in db_ver_inc_map) and
965 allow_db_ver(db_ver) ):
966 # save the include directory with the db.h version
967 # (first occurrence only)
968 db_ver_inc_map[db_ver] = d
969 if db_setup_debug:
970 print("db.h: found", db_ver, "in", d)
971 else:
972 # we already found a header for this library version
973 if db_setup_debug: print("db.h: ignoring", d)
974 else:
975 # ignore this header, it didn't contain a version number
976 if db_setup_debug:
977 print("db.h: no version number version in", d)
978
979 db_found_vers = list(db_ver_inc_map.keys())
980 db_found_vers.sort()
981
982 while db_found_vers:
983 db_ver = db_found_vers.pop()
984 db_incdir = db_ver_inc_map[db_ver]
985
986 # check lib directories parallel to the location of the header
987 db_dirs_to_check = [
988 db_incdir.replace("include", 'lib64'),
989 db_incdir.replace("include", 'lib'),
990 ]
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000991
doko@ubuntu.com93df16b2012-06-30 14:32:08 +0200992 if host_platform != 'darwin':
Ronald Oussoren2c12ab12010-06-03 14:42:25 +0000993 db_dirs_to_check = list(filter(os.path.isdir, db_dirs_to_check))
994
995 else:
996 # Same as other branch, but takes OSX SDK into account
997 tmp = []
998 for dn in db_dirs_to_check:
999 if is_macosx_sdk_path(dn):
1000 if os.path.isdir(os.path.join(sysroot, dn[1:])):
1001 tmp.append(dn)
1002 else:
1003 if os.path.isdir(dn):
1004 tmp.append(dn)
Ronald Oussorendc969e52010-06-27 12:37:46 +00001005 db_dirs_to_check = tmp
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001006
1007 db_dirs_to_check = tmp
Georg Brandl489cb4f2009-07-11 10:08:49 +00001008
Ezio Melotti42da6632011-03-15 05:18:48 +02001009 # Look for a version specific db-X.Y before an ambiguous dbX
Georg Brandl489cb4f2009-07-11 10:08:49 +00001010 # XXX should we -ever- look for a dbX name? Do any
1011 # systems really not name their library by version and
1012 # symlink to more general names?
1013 for dblib in (('db-%d.%d' % db_ver),
1014 ('db%d%d' % db_ver),
1015 ('db%d' % db_ver[0])):
1016 dblib_file = self.compiler.find_library_file(
1017 db_dirs_to_check + lib_dirs, dblib )
1018 if dblib_file:
1019 dblib_dir = [ os.path.abspath(os.path.dirname(dblib_file)) ]
1020 raise db_found
1021 else:
1022 if db_setup_debug: print("db lib: ", dblib, "not found")
1023
1024 except db_found:
1025 if db_setup_debug:
1026 print("bsddb using BerkeleyDB lib:", db_ver, dblib)
1027 print("bsddb lib dir:", dblib_dir, " inc dir:", db_incdir)
1028 db_incs = [db_incdir]
1029 dblibs = [dblib]
1030 else:
1031 if db_setup_debug: print("db: no appropriate library found")
1032 db_incs = None
1033 dblibs = []
1034 dblib_dir = None
1035
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001036 # The sqlite interface
Thomas Wouters89f507f2006-12-13 04:49:30 +00001037 sqlite_setup_debug = False # verbose debug prints from this script?
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001038
1039 # We hunt for #define SQLITE_VERSION "n.n.n"
1040 # We need to find >= sqlite version 3.0.8
1041 sqlite_incdir = sqlite_libdir = None
1042 sqlite_inc_paths = [ '/usr/include',
1043 '/usr/include/sqlite',
1044 '/usr/include/sqlite3',
1045 '/usr/local/include',
1046 '/usr/local/include/sqlite',
1047 '/usr/local/include/sqlite3',
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +02001048 ]
1049 if cross_compiling:
1050 sqlite_inc_paths = []
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001051 MIN_SQLITE_VERSION_NUMBER = (3, 0, 8)
1052 MIN_SQLITE_VERSION = ".".join([str(x)
1053 for x in MIN_SQLITE_VERSION_NUMBER])
Thomas Wouters477c8d52006-05-27 19:21:47 +00001054
1055 # Scan the default include directories before the SQLite specific
1056 # ones. This allows one to override the copy of sqlite on OSX,
1057 # where /usr/include contains an old version of sqlite.
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001058 if host_platform == 'darwin':
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001059 sysroot = macosx_sdk_root()
1060
Ned Deily9b635832012-08-05 15:13:33 -07001061 for d_ in inc_dirs + sqlite_inc_paths:
1062 d = d_
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001063 if host_platform == 'darwin' and is_macosx_sdk_path(d):
Ned Deily9b635832012-08-05 15:13:33 -07001064 d = os.path.join(sysroot, d[1:])
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001065
Ned Deily9b635832012-08-05 15:13:33 -07001066 f = os.path.join(d, "sqlite3.h")
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001067 if os.path.exists(f):
Guido van Rossum452bf512007-02-09 05:32:43 +00001068 if sqlite_setup_debug: print("sqlite: found %s"%f)
Brett Cannon9f5db072010-10-29 20:19:27 +00001069 with open(f) as file:
1070 incf = file.read()
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001071 m = re.search(
Petri Lehtinened909bc2013-02-23 17:05:28 +01001072 r'\s*.*#\s*.*define\s.*SQLITE_VERSION\W*"([\d\.]*)"', incf)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001073 if m:
1074 sqlite_version = m.group(1)
1075 sqlite_version_tuple = tuple([int(x)
1076 for x in sqlite_version.split(".")])
1077 if sqlite_version_tuple >= MIN_SQLITE_VERSION_NUMBER:
1078 # we win!
Thomas Wouters89f507f2006-12-13 04:49:30 +00001079 if sqlite_setup_debug:
Guido van Rossum452bf512007-02-09 05:32:43 +00001080 print("%s/sqlite3.h: version %s"%(d, sqlite_version))
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001081 sqlite_incdir = d
1082 break
1083 else:
1084 if sqlite_setup_debug:
Guido van Rossum452bf512007-02-09 05:32:43 +00001085 print("%s: version %d is too old, need >= %s"%(d,
1086 sqlite_version, MIN_SQLITE_VERSION))
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001087 elif sqlite_setup_debug:
Guido van Rossum452bf512007-02-09 05:32:43 +00001088 print("sqlite: %s had no SQLITE_VERSION"%(f,))
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001089
1090 if sqlite_incdir:
1091 sqlite_dirs_to_check = [
1092 os.path.join(sqlite_incdir, '..', 'lib64'),
1093 os.path.join(sqlite_incdir, '..', 'lib'),
1094 os.path.join(sqlite_incdir, '..', '..', 'lib64'),
1095 os.path.join(sqlite_incdir, '..', '..', 'lib'),
1096 ]
Tarek Ziadé36797272010-07-22 12:50:05 +00001097 sqlite_libfile = self.compiler.find_library_file(
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001098 sqlite_dirs_to_check + lib_dirs, 'sqlite3')
Benjamin Petersonf10a79a2008-10-11 00:49:57 +00001099 if sqlite_libfile:
1100 sqlite_libdir = [os.path.abspath(os.path.dirname(sqlite_libfile))]
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001101
1102 if sqlite_incdir and sqlite_libdir:
Thomas Wouters477c8d52006-05-27 19:21:47 +00001103 sqlite_srcs = ['_sqlite/cache.c',
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001104 '_sqlite/connection.c',
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001105 '_sqlite/cursor.c',
1106 '_sqlite/microprotocols.c',
1107 '_sqlite/module.c',
1108 '_sqlite/prepare_protocol.c',
1109 '_sqlite/row.c',
1110 '_sqlite/statement.c',
1111 '_sqlite/util.c', ]
1112
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001113 sqlite_defines = []
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001114 if host_platform != "win32":
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001115 sqlite_defines.append(('MODULE_NAME', '"sqlite3"'))
1116 else:
1117 sqlite_defines.append(('MODULE_NAME', '\\"sqlite3\\"'))
1118
Benjamin Peterson076ed002010-10-31 17:11:02 +00001119 # Enable support for loadable extensions in the sqlite3 module
1120 # if --enable-loadable-sqlite-extensions configure option is used.
1121 if '--enable-loadable-sqlite-extensions' not in sysconfig.get_config_var("CONFIG_ARGS"):
1122 sqlite_defines.append(("SQLITE_OMIT_LOAD_EXTENSION", "1"))
Thomas Wouters477c8d52006-05-27 19:21:47 +00001123
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001124 if host_platform == 'darwin':
Thomas Wouters477c8d52006-05-27 19:21:47 +00001125 # In every directory on the search path search for a dynamic
1126 # library and then a static library, instead of first looking
Ezio Melotti13925002011-03-16 11:05:33 +02001127 # for dynamic libraries on the entire path.
1128 # This way a statically linked custom sqlite gets picked up
Thomas Wouters477c8d52006-05-27 19:21:47 +00001129 # before the dynamic library in /usr/lib.
1130 sqlite_extra_link_args = ('-Wl,-search_paths_first',)
1131 else:
1132 sqlite_extra_link_args = ()
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001133
Brett Cannonc5011fe2011-06-06 20:09:10 -07001134 include_dirs = ["Modules/_sqlite"]
1135 # Only include the directory where sqlite was found if it does
1136 # not already exist in set include directories, otherwise you
1137 # can end up with a bad search path order.
1138 if sqlite_incdir not in self.compiler.include_dirs:
1139 include_dirs.append(sqlite_incdir)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001140 exts.append(Extension('_sqlite3', sqlite_srcs,
1141 define_macros=sqlite_defines,
Brett Cannonc5011fe2011-06-06 20:09:10 -07001142 include_dirs=include_dirs,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001143 library_dirs=sqlite_libdir,
1144 runtime_library_dirs=sqlite_libdir,
Thomas Wouters477c8d52006-05-27 19:21:47 +00001145 extra_link_args=sqlite_extra_link_args,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001146 libraries=["sqlite3",]))
Guido van Rossumd8faa362007-04-27 19:54:29 +00001147 else:
1148 missing.append('_sqlite3')
Skip Montanaro22e00c42003-05-06 20:43:34 +00001149
Ross Lagerwall0b63b562012-04-15 08:19:35 +02001150 dbm_setup_debug = False # verbose debug prints from this script?
Benjamin Petersond78735d2010-01-01 16:04:23 +00001151 dbm_order = ['gdbm']
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001152 # The standard Unix dbm module:
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001153 if host_platform not in ['cygwin']:
Matthias Klose55708cc2009-04-30 08:06:49 +00001154 config_args = [arg.strip("'")
1155 for arg in sysconfig.get_config_var("CONFIG_ARGS").split()]
Benjamin Petersond78735d2010-01-01 16:04:23 +00001156 dbm_args = [arg for arg in config_args
Matthias Klose55708cc2009-04-30 08:06:49 +00001157 if arg.startswith('--with-dbmliborder=')]
1158 if dbm_args:
Benjamin Petersond78735d2010-01-01 16:04:23 +00001159 dbm_order = [arg.split('=')[-1] for arg in dbm_args][-1].split(":")
Matthias Klose55708cc2009-04-30 08:06:49 +00001160 else:
Georg Brandl489cb4f2009-07-11 10:08:49 +00001161 dbm_order = "ndbm:gdbm:bdb".split(":")
Matthias Klose55708cc2009-04-30 08:06:49 +00001162 dbmext = None
1163 for cand in dbm_order:
1164 if cand == "ndbm":
1165 if find_file("ndbm.h", inc_dirs, []) is not None:
Nick Coghlan50f147a2012-06-17 18:27:11 +10001166 # Some systems have -lndbm, others have -lgdbm_compat,
1167 # others don't have either
Tarek Ziadé36797272010-07-22 12:50:05 +00001168 if self.compiler.find_library_file(lib_dirs,
Tarek Ziadédd07ebb2009-07-06 13:52:17 +00001169 'ndbm'):
Matthias Klose55708cc2009-04-30 08:06:49 +00001170 ndbm_libs = ['ndbm']
Nick Coghlan50f147a2012-06-17 18:27:11 +10001171 elif self.compiler.find_library_file(lib_dirs,
1172 'gdbm_compat'):
1173 ndbm_libs = ['gdbm_compat']
Matthias Klose55708cc2009-04-30 08:06:49 +00001174 else:
1175 ndbm_libs = []
Ross Lagerwall0b63b562012-04-15 08:19:35 +02001176 if dbm_setup_debug: print("building dbm using ndbm")
Matthias Klose55708cc2009-04-30 08:06:49 +00001177 dbmext = Extension('_dbm', ['_dbmmodule.c'],
1178 define_macros=[
1179 ('HAVE_NDBM_H',None),
1180 ],
1181 libraries=ndbm_libs)
1182 break
1183
1184 elif cand == "gdbm":
Tarek Ziadé36797272010-07-22 12:50:05 +00001185 if self.compiler.find_library_file(lib_dirs, 'gdbm'):
Matthias Klose55708cc2009-04-30 08:06:49 +00001186 gdbm_libs = ['gdbm']
Tarek Ziadé36797272010-07-22 12:50:05 +00001187 if self.compiler.find_library_file(lib_dirs,
Tarek Ziadédd07ebb2009-07-06 13:52:17 +00001188 'gdbm_compat'):
Matthias Klose55708cc2009-04-30 08:06:49 +00001189 gdbm_libs.append('gdbm_compat')
1190 if find_file("gdbm/ndbm.h", inc_dirs, []) is not None:
Ross Lagerwall0b63b562012-04-15 08:19:35 +02001191 if dbm_setup_debug: print("building dbm using gdbm")
Matthias Klose55708cc2009-04-30 08:06:49 +00001192 dbmext = Extension(
1193 '_dbm', ['_dbmmodule.c'],
1194 define_macros=[
1195 ('HAVE_GDBM_NDBM_H', None),
1196 ],
1197 libraries = gdbm_libs)
1198 break
1199 if find_file("gdbm-ndbm.h", inc_dirs, []) is not None:
Ross Lagerwall0b63b562012-04-15 08:19:35 +02001200 if dbm_setup_debug: print("building dbm using gdbm")
Matthias Klose55708cc2009-04-30 08:06:49 +00001201 dbmext = Extension(
1202 '_dbm', ['_dbmmodule.c'],
1203 define_macros=[
1204 ('HAVE_GDBM_DASH_NDBM_H', None),
1205 ],
1206 libraries = gdbm_libs)
1207 break
Georg Brandl489cb4f2009-07-11 10:08:49 +00001208 elif cand == "bdb":
1209 if db_incs is not None:
Ross Lagerwall0b63b562012-04-15 08:19:35 +02001210 if dbm_setup_debug: print("building dbm using bdb")
Georg Brandl489cb4f2009-07-11 10:08:49 +00001211 dbmext = Extension('_dbm', ['_dbmmodule.c'],
1212 library_dirs=dblib_dir,
1213 runtime_library_dirs=dblib_dir,
1214 include_dirs=db_incs,
1215 define_macros=[
1216 ('HAVE_BERKDB_H', None),
1217 ('DB_DBM_HSEARCH', None),
1218 ],
1219 libraries=dblibs)
Matthias Klose55708cc2009-04-30 08:06:49 +00001220 break
1221 if dbmext is not None:
1222 exts.append(dbmext)
Guido van Rossumd8faa362007-04-27 19:54:29 +00001223 else:
Georg Brandl0a7ac7d2008-05-26 10:29:35 +00001224 missing.append('_dbm')
Fredrik Lundhade711a2001-01-24 08:00:28 +00001225
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001226 # Anthony Baxter's gdbm module. GNU dbm(3) will require -lgdbm:
Benjamin Petersond78735d2010-01-01 16:04:23 +00001227 if ('gdbm' in dbm_order and
Tarek Ziadé36797272010-07-22 12:50:05 +00001228 self.compiler.find_library_file(lib_dirs, 'gdbm')):
Georg Brandl0a7ac7d2008-05-26 10:29:35 +00001229 exts.append( Extension('_gdbm', ['_gdbmmodule.c'],
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001230 libraries = ['gdbm'] ) )
Guido van Rossumd8faa362007-04-27 19:54:29 +00001231 else:
Georg Brandl0a7ac7d2008-05-26 10:29:35 +00001232 missing.append('_gdbm')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001233
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001234 # Unix-only modules
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001235 if host_platform != 'win32':
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001236 # Steen Lumholt's termios module
1237 exts.append( Extension('termios', ['termios.c']) )
1238 # Jeremy Hylton's rlimit interface
Antoine Pitrou6103ab12009-10-24 20:11:21 +00001239 exts.append( Extension('resource', ['resource.c']) )
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001240
Andrew M. Kuchlingcf393f32001-02-21 02:38:24 +00001241 # Sun yellow pages. Some systems have the functions in libc.
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001242 if (host_platform not in ['cygwin', 'qnx6'] and
Benjamin Peterson588009e2009-12-30 03:03:54 +00001243 find_file('rpcsvc/yp_prot.h', inc_dirs, []) is not None):
Tarek Ziadé36797272010-07-22 12:50:05 +00001244 if (self.compiler.find_library_file(lib_dirs, 'nsl')):
Andrew M. Kuchling6efc6e72001-02-27 20:54:23 +00001245 libs = ['nsl']
1246 else:
1247 libs = []
1248 exts.append( Extension('nis', ['nismodule.c'],
1249 libraries = libs) )
Guido van Rossumd8faa362007-04-27 19:54:29 +00001250 else:
1251 missing.append('nis')
1252 else:
1253 missing.extend(['nis', 'resource', 'termios'])
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001254
Skip Montanaro72092942004-02-07 12:50:19 +00001255 # Curses support, requiring the System V version of curses, often
Fredrik Lundhade711a2001-01-24 08:00:28 +00001256 # provided by the ncurses library.
Victor Stinneraa35b002011-11-29 00:08:12 +01001257 curses_defines = []
Victor Stinner756c6ec2011-11-27 00:19:53 +01001258 curses_includes = []
Victor Stinneraa35b002011-11-29 00:08:12 +01001259 panel_library = 'panel'
1260 if curses_library == 'ncursesw':
1261 curses_defines.append(('HAVE_NCURSESW', '1'))
1262 curses_includes.append('/usr/include/ncursesw')
1263 # Bug 1464056: If _curses.so links with ncursesw,
1264 # _curses_panel.so must link with panelw.
1265 panel_library = 'panelw'
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001266 if host_platform == 'darwin':
Ned Deily69192232012-06-20 23:47:14 -07001267 # On OS X, there is no separate /usr/lib/libncursesw nor
1268 # libpanelw. If we are here, we found a locally-supplied
1269 # version of libncursesw. There should be also be a
1270 # libpanelw. _XOPEN_SOURCE defines are usually excluded
1271 # for OS X but we need _XOPEN_SOURCE_EXTENDED here for
1272 # ncurses wide char support
1273 curses_defines.append(('_XOPEN_SOURCE_EXTENDED', '1'))
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001274 elif host_platform == 'darwin' and curses_library == 'ncurses':
Ned Deily69192232012-06-20 23:47:14 -07001275 # Building with the system-suppied combined libncurses/libpanel
1276 curses_defines.append(('HAVE_NCURSESW', '1'))
1277 curses_defines.append(('_XOPEN_SOURCE_EXTENDED', '1'))
Victor Stinneraa35b002011-11-29 00:08:12 +01001278
Stefan Krah095b2732010-06-08 13:41:44 +00001279 if curses_library.startswith('ncurses'):
Stefan Krah095b2732010-06-08 13:41:44 +00001280 curses_libs = [curses_library]
Martin v. Löwisa55e55e2006-02-11 15:55:14 +00001281 exts.append( Extension('_curses', ['_cursesmodule.c'],
Victor Stinner756c6ec2011-11-27 00:19:53 +01001282 include_dirs=curses_includes,
Nadeem Vawda9e2e9902011-07-31 15:01:11 +02001283 define_macros=curses_defines,
Martin v. Löwisa55e55e2006-02-11 15:55:14 +00001284 libraries = curses_libs) )
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001285 elif curses_library == 'curses' and host_platform != 'darwin':
Michael W. Hudson5b109102002-01-23 15:04:41 +00001286 # OSX has an old Berkeley curses, not good enough for
1287 # the _curses module.
Tarek Ziadé36797272010-07-22 12:50:05 +00001288 if (self.compiler.find_library_file(lib_dirs, 'terminfo')):
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001289 curses_libs = ['curses', 'terminfo']
Tarek Ziadé36797272010-07-22 12:50:05 +00001290 elif (self.compiler.find_library_file(lib_dirs, 'termcap')):
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001291 curses_libs = ['curses', 'termcap']
Neal Norwitz0b27ff92003-03-31 15:53:49 +00001292 else:
1293 curses_libs = ['curses']
Fredrik Lundhade711a2001-01-24 08:00:28 +00001294
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001295 exts.append( Extension('_curses', ['_cursesmodule.c'],
Nadeem Vawda9e2e9902011-07-31 15:01:11 +02001296 define_macros=curses_defines,
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001297 libraries = curses_libs) )
Guido van Rossumd8faa362007-04-27 19:54:29 +00001298 else:
1299 missing.append('_curses')
Fredrik Lundhade711a2001-01-24 08:00:28 +00001300
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001301 # If the curses module is enabled, check for the panel module
Andrew M. Kuchlinge7ffbb22001-12-06 15:57:16 +00001302 if (module_enabled(exts, '_curses') and
Tarek Ziadé36797272010-07-22 12:50:05 +00001303 self.compiler.find_library_file(lib_dirs, panel_library)):
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001304 exts.append( Extension('_curses_panel', ['_curses_panel.c'],
Victor Stinner756c6ec2011-11-27 00:19:53 +01001305 include_dirs=curses_includes,
Ned Deily69192232012-06-20 23:47:14 -07001306 define_macros=curses_defines,
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001307 libraries = [panel_library] + curses_libs) )
Guido van Rossumd8faa362007-04-27 19:54:29 +00001308 else:
1309 missing.append('_curses_panel')
Fredrik Lundhade711a2001-01-24 08:00:28 +00001310
Barry Warsaw259b1e12002-08-13 20:09:26 +00001311 # Andrew Kuchling's zlib module. Note that some versions of zlib
1312 # 1.1.3 have security problems. See CERT Advisory CA-2002-07:
1313 # http://www.cert.org/advisories/CA-2002-07.html
1314 #
1315 # zlib 1.1.4 is fixed, but at least one vendor (RedHat) has decided to
1316 # patch its zlib 1.1.3 package instead of upgrading to 1.1.4. For
1317 # now, we still accept 1.1.3, because we think it's difficult to
1318 # exploit this in Python, and we'd rather make it RedHat's problem
1319 # than our problem <wink>.
1320 #
1321 # You can upgrade zlib to version 1.1.4 yourself by going to
1322 # http://www.gzip.org/zlib/
Guido van Rossume6970912001-04-15 15:16:12 +00001323 zlib_inc = find_file('zlib.h', [], inc_dirs)
Christian Heimes1dc54002008-03-24 02:19:29 +00001324 have_zlib = False
Guido van Rossume6970912001-04-15 15:16:12 +00001325 if zlib_inc is not None:
1326 zlib_h = zlib_inc[0] + '/zlib.h'
1327 version = '"0.0.0"'
Barry Warsaw259b1e12002-08-13 20:09:26 +00001328 version_req = '"1.1.3"'
Brett Cannon9f5db072010-10-29 20:19:27 +00001329 with open(zlib_h) as fp:
1330 while 1:
1331 line = fp.readline()
1332 if not line:
1333 break
1334 if line.startswith('#define ZLIB_VERSION'):
1335 version = line.split()[2]
1336 break
Guido van Rossume6970912001-04-15 15:16:12 +00001337 if version >= version_req:
Tarek Ziadé36797272010-07-22 12:50:05 +00001338 if (self.compiler.find_library_file(lib_dirs, 'z')):
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001339 if host_platform == "darwin":
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001340 zlib_extra_link_args = ('-Wl,-search_paths_first',)
1341 else:
1342 zlib_extra_link_args = ()
Guido van Rossume6970912001-04-15 15:16:12 +00001343 exts.append( Extension('zlib', ['zlibmodule.c'],
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001344 libraries = ['z'],
1345 extra_link_args = zlib_extra_link_args))
Christian Heimes1dc54002008-03-24 02:19:29 +00001346 have_zlib = True
Guido van Rossumd8faa362007-04-27 19:54:29 +00001347 else:
1348 missing.append('zlib')
1349 else:
1350 missing.append('zlib')
1351 else:
1352 missing.append('zlib')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001353
Christian Heimes1dc54002008-03-24 02:19:29 +00001354 # Helper module for various ascii-encoders. Uses zlib for an optimized
1355 # crc32 if we have it. Otherwise binascii uses its own.
1356 if have_zlib:
1357 extra_compile_args = ['-DUSE_ZLIB_CRC32']
1358 libraries = ['z']
1359 extra_link_args = zlib_extra_link_args
1360 else:
1361 extra_compile_args = []
1362 libraries = []
1363 extra_link_args = []
1364 exts.append( Extension('binascii', ['binascii.c'],
1365 extra_compile_args = extra_compile_args,
1366 libraries = libraries,
1367 extra_link_args = extra_link_args) )
1368
Gustavo Niemeyerf8ca8362002-11-05 16:50:05 +00001369 # Gustavo Niemeyer's bz2 module.
Tarek Ziadé36797272010-07-22 12:50:05 +00001370 if (self.compiler.find_library_file(lib_dirs, 'bz2')):
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001371 if host_platform == "darwin":
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001372 bz2_extra_link_args = ('-Wl,-search_paths_first',)
1373 else:
1374 bz2_extra_link_args = ()
Antoine Pitrou37dc5f82011-04-03 17:05:46 +02001375 exts.append( Extension('_bz2', ['_bz2module.c'],
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001376 libraries = ['bz2'],
1377 extra_link_args = bz2_extra_link_args) )
Guido van Rossumd8faa362007-04-27 19:54:29 +00001378 else:
Antoine Pitrou37dc5f82011-04-03 17:05:46 +02001379 missing.append('_bz2')
Gustavo Niemeyerf8ca8362002-11-05 16:50:05 +00001380
Nadeem Vawda3ff069e2011-11-30 00:25:06 +02001381 # LZMA compression support.
1382 if self.compiler.find_library_file(lib_dirs, 'lzma'):
1383 exts.append( Extension('_lzma', ['_lzmamodule.c'],
1384 libraries = ['lzma']) )
1385 else:
1386 missing.append('_lzma')
1387
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001388 # Interface to the Expat XML parser
1389 #
Benjamin Petersona28e7022010-01-09 18:53:06 +00001390 # Expat was written by James Clark and is now maintained by a group of
1391 # developers on SourceForge; see www.libexpat.org for more information.
1392 # The pyexpat module was written by Paul Prescod after a prototype by
1393 # Jack Jansen. The Expat source is included in Modules/expat/. Usage
1394 # of a system shared libexpat.so is possible with --with-system-expat
Benjamin Petersonc73206c2010-10-31 16:38:19 +00001395 # configure option.
Fred Drakefc8341d2002-06-17 17:55:30 +00001396 #
1397 # More information on Expat can be found at www.libexpat.org.
1398 #
Benjamin Petersonb2d90462009-12-31 03:23:10 +00001399 if '--with-system-expat' in sysconfig.get_config_var("CONFIG_ARGS"):
1400 expat_inc = []
1401 define_macros = []
1402 expat_lib = ['expat']
1403 expat_sources = []
Christian Heimesd489c7a2013-02-09 17:02:06 +01001404 expat_depends = []
Benjamin Petersonb2d90462009-12-31 03:23:10 +00001405 else:
1406 expat_inc = [os.path.join(os.getcwd(), srcdir, 'Modules', 'expat')]
1407 define_macros = [
1408 ('HAVE_EXPAT_CONFIG_H', '1'),
1409 ]
1410 expat_lib = []
1411 expat_sources = ['expat/xmlparse.c',
1412 'expat/xmlrole.c',
1413 'expat/xmltok.c']
Christian Heimesd489c7a2013-02-09 17:02:06 +01001414 expat_depends = ['expat/ascii.h',
1415 'expat/asciitab.h',
1416 'expat/expat.h',
1417 'expat/expat_config.h',
1418 'expat/expat_external.h',
1419 'expat/internal.h',
1420 'expat/latin1tab.h',
1421 'expat/utf8tab.h',
1422 'expat/xmlrole.h',
1423 'expat/xmltok.h',
1424 'expat/xmltok_impl.h'
1425 ]
Thomas Wouters477c8d52006-05-27 19:21:47 +00001426
Fred Drake2d59a492003-10-21 15:41:15 +00001427 exts.append(Extension('pyexpat',
1428 define_macros = define_macros,
Benjamin Petersonb2d90462009-12-31 03:23:10 +00001429 include_dirs = expat_inc,
1430 libraries = expat_lib,
Christian Heimesd489c7a2013-02-09 17:02:06 +01001431 sources = ['pyexpat.c'] + expat_sources,
1432 depends = expat_depends,
Fred Drake2d59a492003-10-21 15:41:15 +00001433 ))
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001434
Fredrik Lundh4c86ec62005-12-14 18:46:16 +00001435 # Fredrik Lundh's cElementTree module. Note that this also
1436 # uses expat (via the CAPI hook in pyexpat).
1437
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001438 if os.path.isfile(os.path.join(srcdir, 'Modules', '_elementtree.c')):
Fredrik Lundh4c86ec62005-12-14 18:46:16 +00001439 define_macros.append(('USE_PYEXPAT_CAPI', None))
1440 exts.append(Extension('_elementtree',
1441 define_macros = define_macros,
Benjamin Petersonb2d90462009-12-31 03:23:10 +00001442 include_dirs = expat_inc,
1443 libraries = expat_lib,
Fredrik Lundh4c86ec62005-12-14 18:46:16 +00001444 sources = ['_elementtree.c'],
Christian Heimesd489c7a2013-02-09 17:02:06 +01001445 depends = ['pyexpat.c'] + expat_sources +
1446 expat_depends,
Fredrik Lundh4c86ec62005-12-14 18:46:16 +00001447 ))
Guido van Rossumd8faa362007-04-27 19:54:29 +00001448 else:
1449 missing.append('_elementtree')
Fredrik Lundh4c86ec62005-12-14 18:46:16 +00001450
Hye-Shik Chang3e2a3062004-01-17 14:29:29 +00001451 # Hye-Shik Chang's CJKCodecs modules.
Walter Dörwalde9eaab42007-05-22 16:02:13 +00001452 exts.append(Extension('_multibytecodec',
1453 ['cjkcodecs/multibytecodec.c']))
1454 for loc in ('kr', 'jp', 'cn', 'tw', 'hk', 'iso2022'):
1455 exts.append(Extension('_codecs_%s' % loc,
1456 ['cjkcodecs/_codecs_%s.c' % loc]))
Hye-Shik Chang3e2a3062004-01-17 14:29:29 +00001457
Stefan Krah1919b7e2012-03-21 18:25:23 +01001458 # Stefan Krah's _decimal module
1459 exts.append(self._decimal_ext())
1460
Thomas Hellercf567c12006-03-08 19:51:58 +00001461 # Thomas Heller's _ctypes module
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001462 self.detect_ctypes(inc_dirs, lib_dirs)
Thomas Hellercf567c12006-03-08 19:51:58 +00001463
Benjamin Petersone711caf2008-06-11 16:44:04 +00001464 # Richard Oudkerk's multiprocessing module
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001465 if host_platform == 'win32': # Windows
Benjamin Petersone711caf2008-06-11 16:44:04 +00001466 macros = dict()
1467 libraries = ['ws2_32']
1468
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001469 elif host_platform == 'darwin': # Mac OSX
Benjamin Peterson965ce872009-04-05 21:24:58 +00001470 macros = dict()
Benjamin Petersone711caf2008-06-11 16:44:04 +00001471 libraries = []
1472
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001473 elif host_platform == 'cygwin': # Cygwin
Benjamin Peterson965ce872009-04-05 21:24:58 +00001474 macros = dict()
Benjamin Petersone711caf2008-06-11 16:44:04 +00001475 libraries = []
Benjamin Peterson41181742008-07-02 20:22:54 +00001476
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001477 elif host_platform in ('freebsd4', 'freebsd5', 'freebsd6', 'freebsd7', 'freebsd8'):
Benjamin Peterson41181742008-07-02 20:22:54 +00001478 # FreeBSD's P1003.1b semaphore support is very experimental
1479 # and has many known problems. (as of June 2008)
Benjamin Peterson965ce872009-04-05 21:24:58 +00001480 macros = dict()
Benjamin Peterson41181742008-07-02 20:22:54 +00001481 libraries = []
1482
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001483 elif host_platform.startswith('openbsd'):
Benjamin Peterson965ce872009-04-05 21:24:58 +00001484 macros = dict()
Benjamin Petersone5384b02008-10-04 22:00:42 +00001485 libraries = []
1486
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001487 elif host_platform.startswith('netbsd'):
Benjamin Peterson965ce872009-04-05 21:24:58 +00001488 macros = dict()
Jesse Noller32d68c22009-03-31 18:48:42 +00001489 libraries = []
1490
Benjamin Petersone711caf2008-06-11 16:44:04 +00001491 else: # Linux and other unices
Benjamin Peterson965ce872009-04-05 21:24:58 +00001492 macros = dict()
Benjamin Petersone711caf2008-06-11 16:44:04 +00001493 libraries = ['rt']
1494
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001495 if host_platform == 'win32':
Benjamin Petersone711caf2008-06-11 16:44:04 +00001496 multiprocessing_srcs = [ '_multiprocessing/multiprocessing.c',
1497 '_multiprocessing/semaphore.c',
Benjamin Petersone711caf2008-06-11 16:44:04 +00001498 ]
1499
1500 else:
1501 multiprocessing_srcs = [ '_multiprocessing/multiprocessing.c',
Benjamin Petersone711caf2008-06-11 16:44:04 +00001502 ]
Mark Dickinsona614f042009-11-28 12:48:43 +00001503 if (sysconfig.get_config_var('HAVE_SEM_OPEN') and not
1504 sysconfig.get_config_var('POSIX_SEMAPHORES_NOT_ENABLED')):
Benjamin Petersone711caf2008-06-11 16:44:04 +00001505 multiprocessing_srcs.append('_multiprocessing/semaphore.c')
1506
Jesse Noller6fd47e22009-01-23 14:09:08 +00001507 if sysconfig.get_config_var('WITH_THREAD'):
1508 exts.append ( Extension('_multiprocessing', multiprocessing_srcs,
1509 define_macros=list(macros.items()),
1510 include_dirs=["Modules/_multiprocessing"]))
1511 else:
1512 missing.append('_multiprocessing')
Benjamin Petersone711caf2008-06-11 16:44:04 +00001513 # End multiprocessing
Guido van Rossuma9e20242007-03-08 00:43:48 +00001514
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001515 # Platform-specific libraries
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001516 if host_platform.startswith(('linux', 'freebsd', 'gnukfreebsd')):
Guido van Rossum0c016a92003-02-13 16:12:21 +00001517 exts.append( Extension('ossaudiodev', ['ossaudiodev.c']) )
Guido van Rossumd8faa362007-04-27 19:54:29 +00001518 else:
1519 missing.append('ossaudiodev')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001520
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001521 if host_platform == 'darwin':
Benjamin Petersonebacd262008-05-29 21:09:51 +00001522 exts.append(
1523 Extension('_gestalt', ['_gestalt.c'],
1524 extra_link_args=['-framework', 'Carbon'])
1525 )
Ronald Oussoren84151202010-04-18 20:46:11 +00001526 exts.append(
1527 Extension('_scproxy', ['_scproxy.c'],
1528 extra_link_args=[
1529 '-framework', 'SystemConfiguration',
1530 '-framework', 'CoreFoundation',
1531 ]))
Benjamin Petersonebacd262008-05-29 21:09:51 +00001532
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001533 self.extensions.extend(exts)
1534
1535 # Call the method for detecting whether _tkinter can be compiled
1536 self.detect_tkinter(inc_dirs, lib_dirs)
Fredrik Lundhade711a2001-01-24 08:00:28 +00001537
Guido van Rossumd8faa362007-04-27 19:54:29 +00001538 if '_tkinter' not in [e.name for e in self.extensions]:
1539 missing.append('_tkinter')
1540
1541 return missing
1542
Jack Jansen0b06be72002-06-21 14:48:38 +00001543 def detect_tkinter_darwin(self, inc_dirs, lib_dirs):
1544 # The _tkinter module, using frameworks. Since frameworks are quite
1545 # different the UNIX search logic is not sharable.
1546 from os.path import join, exists
1547 framework_dirs = [
Tim Peters2c60f7a2003-01-29 03:49:43 +00001548 '/Library/Frameworks',
Ronald Oussoren5f734f12009-03-04 21:32:48 +00001549 '/System/Library/Frameworks/',
Jack Jansen0b06be72002-06-21 14:48:38 +00001550 join(os.getenv('HOME'), '/Library/Frameworks')
1551 ]
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001552
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001553 sysroot = macosx_sdk_root()
1554
Skip Montanaro0174ddd2005-12-30 05:01:26 +00001555 # Find the directory that contains the Tcl.framework and Tk.framework
Jack Jansen0b06be72002-06-21 14:48:38 +00001556 # bundles.
1557 # XXX distutils should support -F!
1558 for F in framework_dirs:
Tim Peters2c60f7a2003-01-29 03:49:43 +00001559 # both Tcl.framework and Tk.framework should be present
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001560
1561
Jack Jansen0b06be72002-06-21 14:48:38 +00001562 for fw in 'Tcl', 'Tk':
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001563 if is_macosx_sdk_path(F):
1564 if not exists(join(sysroot, F[1:], fw + '.framework')):
1565 break
1566 else:
1567 if not exists(join(F, fw + '.framework')):
1568 break
Jack Jansen0b06be72002-06-21 14:48:38 +00001569 else:
1570 # ok, F is now directory with both frameworks. Continure
1571 # building
1572 break
1573 else:
1574 # Tk and Tcl frameworks not found. Normal "unix" tkinter search
1575 # will now resume.
1576 return 0
Tim Peters2c60f7a2003-01-29 03:49:43 +00001577
Jack Jansen0b06be72002-06-21 14:48:38 +00001578 # For 8.4a2, we must add -I options that point inside the Tcl and Tk
1579 # frameworks. In later release we should hopefully be able to pass
Tim Peters2c60f7a2003-01-29 03:49:43 +00001580 # the -F option to gcc, which specifies a framework lookup path.
Jack Jansen0b06be72002-06-21 14:48:38 +00001581 #
1582 include_dirs = [
Tim Peters2c60f7a2003-01-29 03:49:43 +00001583 join(F, fw + '.framework', H)
Nick Coghlan650f0d02007-04-15 12:05:43 +00001584 for fw in ('Tcl', 'Tk')
1585 for H in ('Headers', 'Versions/Current/PrivateHeaders')
Jack Jansen0b06be72002-06-21 14:48:38 +00001586 ]
1587
Tim Peters2c60f7a2003-01-29 03:49:43 +00001588 # For 8.4a2, the X11 headers are not included. Rather than include a
Jack Jansen0b06be72002-06-21 14:48:38 +00001589 # complicated search, this is a hard-coded path. It could bail out
1590 # if X11 libs are not found...
1591 include_dirs.append('/usr/X11R6/include')
1592 frameworks = ['-framework', 'Tcl', '-framework', 'Tk']
1593
Georg Brandlfcaf9102008-07-16 02:17:56 +00001594 # All existing framework builds of Tcl/Tk don't support 64-bit
1595 # architectures.
1596 cflags = sysconfig.get_config_vars('CFLAGS')[0]
1597 archs = re.findall('-arch\s+(\w+)', cflags)
Georg Brandlfcaf9102008-07-16 02:17:56 +00001598
Ronald Oussorend097efe2009-09-15 19:07:58 +00001599 tmpfile = os.path.join(self.build_temp, 'tk.arch')
1600 if not os.path.exists(self.build_temp):
1601 os.makedirs(self.build_temp)
1602
1603 # Note: cannot use os.popen or subprocess here, that
1604 # requires extensions that are not available here.
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001605 if is_macosx_sdk_path(F):
1606 os.system("file %s/Tk.framework/Tk | grep 'for architecture' > %s"%(os.path.join(sysroot, F[1:]), tmpfile))
1607 else:
1608 os.system("file %s/Tk.framework/Tk | grep 'for architecture' > %s"%(F, tmpfile))
Ronald Oussoren2c12ab12010-06-03 14:42:25 +00001609
Brett Cannon9f5db072010-10-29 20:19:27 +00001610 with open(tmpfile) as fp:
1611 detected_archs = []
1612 for ln in fp:
1613 a = ln.split()[-1]
1614 if a in archs:
1615 detected_archs.append(ln.split()[-1])
Ronald Oussorend097efe2009-09-15 19:07:58 +00001616 os.unlink(tmpfile)
1617
1618 for a in detected_archs:
1619 frameworks.append('-arch')
1620 frameworks.append(a)
Georg Brandlfcaf9102008-07-16 02:17:56 +00001621
Jack Jansen0b06be72002-06-21 14:48:38 +00001622 ext = Extension('_tkinter', ['_tkinter.c', 'tkappinit.c'],
1623 define_macros=[('WITH_APPINIT', 1)],
1624 include_dirs = include_dirs,
1625 libraries = [],
Georg Brandlfcaf9102008-07-16 02:17:56 +00001626 extra_compile_args = frameworks[2:],
Jack Jansen0b06be72002-06-21 14:48:38 +00001627 extra_link_args = frameworks,
1628 )
1629 self.extensions.append(ext)
1630 return 1
1631
Tim Peters2c60f7a2003-01-29 03:49:43 +00001632
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001633 def detect_tkinter(self, inc_dirs, lib_dirs):
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001634 # The _tkinter module.
Michael W. Hudson5b109102002-01-23 15:04:41 +00001635
Jack Jansen0b06be72002-06-21 14:48:38 +00001636 # Rather than complicate the code below, detecting and building
1637 # AquaTk is a separate method. Only one Tkinter will be built on
1638 # Darwin - either AquaTk, if it is found, or X11 based Tk.
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001639 if (host_platform == 'darwin' and
Skip Montanaro0174ddd2005-12-30 05:01:26 +00001640 self.detect_tkinter_darwin(inc_dirs, lib_dirs)):
Tim Peters2c60f7a2003-01-29 03:49:43 +00001641 return
Jack Jansen0b06be72002-06-21 14:48:38 +00001642
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001643 # Assume we haven't found any of the libraries or include files
Martin v. Löwis3db5b8c2001-07-24 06:54:01 +00001644 # The versions with dots are used on Unix, and the versions without
1645 # dots on Windows, for detection by cygwin.
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001646 tcllib = tklib = tcl_includes = tk_includes = None
Guilherme Polo5d377bd2009-08-16 14:44:14 +00001647 for version in ['8.6', '86', '8.5', '85', '8.4', '84', '8.3', '83',
1648 '8.2', '82', '8.1', '81', '8.0', '80']:
Tarek Ziadé36797272010-07-22 12:50:05 +00001649 tklib = self.compiler.find_library_file(lib_dirs,
Tarek Ziadédd07ebb2009-07-06 13:52:17 +00001650 'tk' + version)
Tarek Ziadé36797272010-07-22 12:50:05 +00001651 tcllib = self.compiler.find_library_file(lib_dirs,
Tarek Ziadédd07ebb2009-07-06 13:52:17 +00001652 'tcl' + version)
Michael W. Hudson5b109102002-01-23 15:04:41 +00001653 if tklib and tcllib:
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001654 # Exit the loop when we've found the Tcl/Tk libraries
1655 break
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001656
Fredrik Lundhade711a2001-01-24 08:00:28 +00001657 # Now check for the header files
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001658 if tklib and tcllib:
Andrew M. Kuchling3c0aa7e2004-03-21 18:57:35 +00001659 # Check for the include files on Debian and {Free,Open}BSD, where
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001660 # they're put in /usr/include/{tcl,tk}X.Y
Andrew M. Kuchling3c0aa7e2004-03-21 18:57:35 +00001661 dotversion = version
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001662 if '.' not in dotversion and "bsd" in host_platform.lower():
Andrew M. Kuchling3c0aa7e2004-03-21 18:57:35 +00001663 # OpenBSD and FreeBSD use Tcl/Tk library names like libtcl83.a,
1664 # but the include subdirs are named like .../include/tcl8.3.
1665 dotversion = dotversion[:-1] + '.' + dotversion[-1]
1666 tcl_include_sub = []
1667 tk_include_sub = []
1668 for dir in inc_dirs:
1669 tcl_include_sub += [dir + os.sep + "tcl" + dotversion]
1670 tk_include_sub += [dir + os.sep + "tk" + dotversion]
1671 tk_include_sub += tcl_include_sub
1672 tcl_includes = find_file('tcl.h', inc_dirs, tcl_include_sub)
1673 tk_includes = find_file('tk.h', inc_dirs, tk_include_sub)
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001674
Martin v. Löwise86a59a2003-05-03 08:45:51 +00001675 if (tcllib is None or tklib is None or
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001676 tcl_includes is None or tk_includes is None):
Andrew M. Kuchling3c0aa7e2004-03-21 18:57:35 +00001677 self.announce("INFO: Can't locate Tcl/Tk libs and/or headers", 2)
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001678 return
Fredrik Lundhade711a2001-01-24 08:00:28 +00001679
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001680 # OK... everything seems to be present for Tcl/Tk.
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001681
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001682 include_dirs = [] ; libs = [] ; defs = [] ; added_lib_dirs = []
1683 for dir in tcl_includes + tk_includes:
1684 if dir not in include_dirs:
1685 include_dirs.append(dir)
Fredrik Lundhade711a2001-01-24 08:00:28 +00001686
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001687 # Check for various platform-specific directories
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001688 if host_platform == 'sunos5':
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001689 include_dirs.append('/usr/openwin/include')
1690 added_lib_dirs.append('/usr/openwin/lib')
1691 elif os.path.exists('/usr/X11R6/include'):
1692 include_dirs.append('/usr/X11R6/include')
Martin v. Löwisfba73692004-11-13 11:13:35 +00001693 added_lib_dirs.append('/usr/X11R6/lib64')
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001694 added_lib_dirs.append('/usr/X11R6/lib')
1695 elif os.path.exists('/usr/X11R5/include'):
1696 include_dirs.append('/usr/X11R5/include')
1697 added_lib_dirs.append('/usr/X11R5/lib')
1698 else:
Fredrik Lundhade711a2001-01-24 08:00:28 +00001699 # Assume default location for X11
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001700 include_dirs.append('/usr/X11/include')
1701 added_lib_dirs.append('/usr/X11/lib')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001702
Jason Tishler9181c942003-02-05 15:16:17 +00001703 # If Cygwin, then verify that X is installed before proceeding
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001704 if host_platform == 'cygwin':
Jason Tishler9181c942003-02-05 15:16:17 +00001705 x11_inc = find_file('X11/Xlib.h', [], include_dirs)
1706 if x11_inc is None:
1707 return
1708
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001709 # Check for BLT extension
Tarek Ziadé36797272010-07-22 12:50:05 +00001710 if self.compiler.find_library_file(lib_dirs + added_lib_dirs,
Tarek Ziadédd07ebb2009-07-06 13:52:17 +00001711 'BLT8.0'):
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001712 defs.append( ('WITH_BLT', 1) )
1713 libs.append('BLT8.0')
Tarek Ziadé36797272010-07-22 12:50:05 +00001714 elif self.compiler.find_library_file(lib_dirs + added_lib_dirs,
Tarek Ziadédd07ebb2009-07-06 13:52:17 +00001715 'BLT'):
Martin v. Löwis427a2902002-12-12 20:23:38 +00001716 defs.append( ('WITH_BLT', 1) )
1717 libs.append('BLT')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001718
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001719 # Add the Tcl/Tk libraries
Jason Tishlercccac1a2003-02-05 15:06:46 +00001720 libs.append('tk'+ version)
1721 libs.append('tcl'+ version)
Fredrik Lundhade711a2001-01-24 08:00:28 +00001722
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001723 if host_platform in ['aix3', 'aix4']:
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001724 libs.append('ld')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001725
Martin v. Löwis3db5b8c2001-07-24 06:54:01 +00001726 # Finally, link with the X11 libraries (not appropriate on cygwin)
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001727 if host_platform != "cygwin":
Martin v. Löwis3db5b8c2001-07-24 06:54:01 +00001728 libs.append('X11')
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001729
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001730 ext = Extension('_tkinter', ['_tkinter.c', 'tkappinit.c'],
1731 define_macros=[('WITH_APPINIT', 1)] + defs,
1732 include_dirs = include_dirs,
1733 libraries = libs,
1734 library_dirs = added_lib_dirs,
1735 )
1736 self.extensions.append(ext)
Fredrik Lundhade711a2001-01-24 08:00:28 +00001737
Guido van Rossum6c7438e2003-02-11 20:05:50 +00001738## # Uncomment these lines if you want to play with xxmodule.c
1739## ext = Extension('xx', ['xxmodule.c'])
1740## self.extensions.append(ext)
Antoine Pitrou8c30a712010-12-04 18:36:03 +00001741 if 'd' not in sys.abiflags:
1742 ext = Extension('xxlimited', ['xxlimited.c'],
1743 define_macros=[('Py_LIMITED_API', 1)])
1744 self.extensions.append(ext)
Guido van Rossum6c7438e2003-02-11 20:05:50 +00001745
Andrew M. Kuchlingfbe73762001-01-18 18:44:20 +00001746 # XXX handle these, but how to detect?
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001747 # *** Uncomment and edit for PIL (TkImaging) extension only:
Fredrik Lundhade711a2001-01-24 08:00:28 +00001748 # -DWITH_PIL -I../Extensions/Imaging/libImaging tkImaging.c \
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001749 # *** Uncomment and edit for TOGL extension only:
Fredrik Lundhade711a2001-01-24 08:00:28 +00001750 # -DWITH_TOGL togl.c \
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001751 # *** Uncomment these for TOGL extension only:
Fredrik Lundhade711a2001-01-24 08:00:28 +00001752 # -lGL -lGLU -lXext -lXmu \
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00001753
Christian Heimes78644762008-03-04 23:39:23 +00001754 def configure_ctypes_darwin(self, ext):
1755 # Darwin (OS X) uses preconfigured files, in
1756 # the Modules/_ctypes/libffi_osx directory.
Neil Schemenauer014bf282009-02-05 16:35:45 +00001757 srcdir = sysconfig.get_config_var('srcdir')
Christian Heimes78644762008-03-04 23:39:23 +00001758 ffi_srcdir = os.path.abspath(os.path.join(srcdir, 'Modules',
1759 '_ctypes', 'libffi_osx'))
1760 sources = [os.path.join(ffi_srcdir, p)
1761 for p in ['ffi.c',
Georg Brandlfcaf9102008-07-16 02:17:56 +00001762 'x86/darwin64.S',
Christian Heimes78644762008-03-04 23:39:23 +00001763 'x86/x86-darwin.S',
1764 'x86/x86-ffi_darwin.c',
1765 'x86/x86-ffi64.c',
1766 'powerpc/ppc-darwin.S',
1767 'powerpc/ppc-darwin_closure.S',
1768 'powerpc/ppc-ffi_darwin.c',
1769 'powerpc/ppc64-darwin_closure.S',
1770 ]]
1771
1772 # Add .S (preprocessed assembly) to C compiler source extensions.
Tarek Ziadé36797272010-07-22 12:50:05 +00001773 self.compiler.src_extensions.append('.S')
Christian Heimes78644762008-03-04 23:39:23 +00001774
1775 include_dirs = [os.path.join(ffi_srcdir, 'include'),
1776 os.path.join(ffi_srcdir, 'powerpc')]
1777 ext.include_dirs.extend(include_dirs)
1778 ext.sources.extend(sources)
1779 return True
1780
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001781 def configure_ctypes(self, ext):
1782 if not self.use_system_libffi:
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001783 if host_platform == 'darwin':
Christian Heimes78644762008-03-04 23:39:23 +00001784 return self.configure_ctypes_darwin(ext)
1785
Neil Schemenauer014bf282009-02-05 16:35:45 +00001786 srcdir = sysconfig.get_config_var('srcdir')
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001787 ffi_builddir = os.path.join(self.build_temp, 'libffi')
1788 ffi_srcdir = os.path.abspath(os.path.join(srcdir, 'Modules',
1789 '_ctypes', 'libffi'))
1790 ffi_configfile = os.path.join(ffi_builddir, 'fficonfig.py')
Thomas Hellercf567c12006-03-08 19:51:58 +00001791
Thomas Wouters477c8d52006-05-27 19:21:47 +00001792 from distutils.dep_util import newer_group
1793
1794 config_sources = [os.path.join(ffi_srcdir, fname)
Thomas Wouterscf297e42007-02-23 15:07:44 +00001795 for fname in os.listdir(ffi_srcdir)
1796 if os.path.isfile(os.path.join(ffi_srcdir, fname))]
Thomas Wouters477c8d52006-05-27 19:21:47 +00001797 if self.force or newer_group(config_sources,
1798 ffi_configfile):
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001799 from distutils.dir_util import mkpath
1800 mkpath(ffi_builddir)
doko@ubuntu.com1abe1c52012-06-30 20:42:45 +02001801 config_args = [arg for arg in sysconfig.get_config_var("CONFIG_ARGS").split()
1802 if (('--host=' in arg) or ('--build=' in arg))]
Christian Heimes7dd06e12012-09-06 18:02:49 +02001803 if not self.verbose:
1804 config_args.append("-q")
Thomas Hellercf567c12006-03-08 19:51:58 +00001805
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001806 # Pass empty CFLAGS because we'll just append the resulting
1807 # CFLAGS to Python's; -g or -O2 is to be avoided.
1808 cmd = "cd %s && env CFLAGS='' '%s/configure' %s" \
1809 % (ffi_builddir, ffi_srcdir, " ".join(config_args))
Thomas Hellercf567c12006-03-08 19:51:58 +00001810
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001811 res = os.system(cmd)
1812 if res or not os.path.exists(ffi_configfile):
Guido van Rossum452bf512007-02-09 05:32:43 +00001813 print("Failed to configure _ctypes module")
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001814 return False
Thomas Hellercf567c12006-03-08 19:51:58 +00001815
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001816 fficonfig = {}
Antoine Pitrou72f4d642010-01-13 12:04:20 +00001817 with open(ffi_configfile) as f:
1818 exec(f.read(), globals(), fficonfig)
Thomas Hellercf567c12006-03-08 19:51:58 +00001819
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001820 # Add .S (preprocessed assembly) to C compiler source extensions.
Tarek Ziadé36797272010-07-22 12:50:05 +00001821 self.compiler.src_extensions.append('.S')
Thomas Hellercf567c12006-03-08 19:51:58 +00001822
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001823 include_dirs = [os.path.join(ffi_builddir, 'include'),
Antoine Pitrou72f4d642010-01-13 12:04:20 +00001824 ffi_builddir,
1825 os.path.join(ffi_srcdir, 'src')]
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001826 extra_compile_args = fficonfig['ffi_cflags'].split()
1827
Antoine Pitrou72f4d642010-01-13 12:04:20 +00001828 ext.sources.extend(os.path.join(ffi_srcdir, f) for f in
1829 fficonfig['ffi_sources'])
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001830 ext.include_dirs.extend(include_dirs)
1831 ext.extra_compile_args.extend(extra_compile_args)
1832 return True
1833
1834 def detect_ctypes(self, inc_dirs, lib_dirs):
1835 self.use_system_libffi = False
1836 include_dirs = []
1837 extra_compile_args = []
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001838 extra_link_args = []
Thomas Hellercf567c12006-03-08 19:51:58 +00001839 sources = ['_ctypes/_ctypes.c',
1840 '_ctypes/callbacks.c',
1841 '_ctypes/callproc.c',
1842 '_ctypes/stgdict.c',
Thomas Heller864cc672010-08-08 17:58:53 +00001843 '_ctypes/cfield.c']
Thomas Hellercf567c12006-03-08 19:51:58 +00001844 depends = ['_ctypes/ctypes.h']
1845
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001846 if host_platform == 'darwin':
Ronald Oussoren2decf222010-09-05 18:25:59 +00001847 sources.append('_ctypes/malloc_closure.c')
Thomas Hellercf567c12006-03-08 19:51:58 +00001848 sources.append('_ctypes/darwin/dlfcn_simple.c')
Christian Heimes78644762008-03-04 23:39:23 +00001849 extra_compile_args.append('-DMACOSX')
Thomas Hellercf567c12006-03-08 19:51:58 +00001850 include_dirs.append('_ctypes/darwin')
1851# XXX Is this still needed?
1852## extra_link_args.extend(['-read_only_relocs', 'warning'])
1853
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001854 elif host_platform == 'sunos5':
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001855 # XXX This shouldn't be necessary; it appears that some
1856 # of the assembler code is non-PIC (i.e. it has relocations
1857 # when it shouldn't. The proper fix would be to rewrite
1858 # the assembler code to be PIC.
1859 # This only works with GCC; the Sun compiler likely refuses
1860 # this option. If you want to compile ctypes with the Sun
1861 # compiler, please research a proper solution, instead of
1862 # finding some -z option for the Sun compiler.
1863 extra_link_args.append('-mimpure-text')
1864
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001865 elif host_platform.startswith('hp-ux'):
Thomas Heller3eaaeb42008-05-23 17:26:46 +00001866 extra_link_args.append('-fPIC')
1867
Thomas Hellercf567c12006-03-08 19:51:58 +00001868 ext = Extension('_ctypes',
1869 include_dirs=include_dirs,
1870 extra_compile_args=extra_compile_args,
Thomas Wouters0e3f5912006-08-11 14:57:12 +00001871 extra_link_args=extra_link_args,
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001872 libraries=[],
Thomas Hellercf567c12006-03-08 19:51:58 +00001873 sources=sources,
1874 depends=depends)
1875 ext_test = Extension('_ctypes_test',
1876 sources=['_ctypes/_ctypes_test.c'])
1877 self.extensions.extend([ext, ext_test])
1878
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001879 if not '--with-system-ffi' in sysconfig.get_config_var("CONFIG_ARGS"):
1880 return
1881
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001882 if host_platform == 'darwin':
Christian Heimes78644762008-03-04 23:39:23 +00001883 # OS X 10.5 comes with libffi.dylib; the include files are
1884 # in /usr/include/ffi
1885 inc_dirs.append('/usr/include/ffi')
1886
Benjamin Petersond78735d2010-01-01 16:04:23 +00001887 ffi_inc = [sysconfig.get_config_var("LIBFFI_INCLUDEDIR")]
Matthias Klose5a204fe2010-04-21 21:47:45 +00001888 if not ffi_inc or ffi_inc[0] == '':
Benjamin Petersond78735d2010-01-01 16:04:23 +00001889 ffi_inc = find_file('ffi.h', [], inc_dirs)
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001890 if ffi_inc is not None:
1891 ffi_h = ffi_inc[0] + '/ffi.h'
Brett Cannon9f5db072010-10-29 20:19:27 +00001892 with open(ffi_h) as fp:
1893 while 1:
1894 line = fp.readline()
1895 if not line:
1896 ffi_inc = None
1897 break
1898 if line.startswith('#define LIBFFI_H'):
1899 break
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001900 ffi_lib = None
1901 if ffi_inc is not None:
1902 for lib_name in ('ffi_convenience', 'ffi_pic', 'ffi'):
Tarek Ziadé36797272010-07-22 12:50:05 +00001903 if (self.compiler.find_library_file(lib_dirs, lib_name)):
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00001904 ffi_lib = lib_name
1905 break
1906
1907 if ffi_inc and ffi_lib:
1908 ext.include_dirs.extend(ffi_inc)
1909 ext.libraries.append(ffi_lib)
1910 self.use_system_libffi = True
1911
Stefan Krah1919b7e2012-03-21 18:25:23 +01001912 def _decimal_ext(self):
Stefan Krah60187b52012-03-23 19:06:27 +01001913 extra_compile_args = []
Stefan Kraha10e2fb2012-09-01 14:21:22 +02001914 undef_macros = []
Stefan Krah60187b52012-03-23 19:06:27 +01001915 if '--with-system-libmpdec' in sysconfig.get_config_var("CONFIG_ARGS"):
1916 include_dirs = []
1917 libraries = ['mpdec']
1918 sources = ['_decimal/_decimal.c']
1919 depends = ['_decimal/docstrings.h']
1920 else:
Ned Deily458a6fb2012-04-01 02:30:46 -07001921 srcdir = sysconfig.get_config_var('srcdir')
1922 include_dirs = [os.path.abspath(os.path.join(srcdir,
1923 'Modules',
1924 '_decimal',
1925 'libmpdec'))]
Stefan Krah60187b52012-03-23 19:06:27 +01001926 libraries = []
1927 sources = [
1928 '_decimal/_decimal.c',
1929 '_decimal/libmpdec/basearith.c',
1930 '_decimal/libmpdec/constants.c',
1931 '_decimal/libmpdec/context.c',
1932 '_decimal/libmpdec/convolute.c',
1933 '_decimal/libmpdec/crt.c',
1934 '_decimal/libmpdec/difradix2.c',
1935 '_decimal/libmpdec/fnt.c',
1936 '_decimal/libmpdec/fourstep.c',
1937 '_decimal/libmpdec/io.c',
1938 '_decimal/libmpdec/memory.c',
1939 '_decimal/libmpdec/mpdecimal.c',
1940 '_decimal/libmpdec/numbertheory.c',
1941 '_decimal/libmpdec/sixstep.c',
1942 '_decimal/libmpdec/transpose.c',
1943 ]
1944 depends = [
1945 '_decimal/docstrings.h',
1946 '_decimal/libmpdec/basearith.h',
1947 '_decimal/libmpdec/bits.h',
1948 '_decimal/libmpdec/constants.h',
1949 '_decimal/libmpdec/convolute.h',
1950 '_decimal/libmpdec/crt.h',
1951 '_decimal/libmpdec/difradix2.h',
1952 '_decimal/libmpdec/fnt.h',
1953 '_decimal/libmpdec/fourstep.h',
1954 '_decimal/libmpdec/io.h',
1955 '_decimal/libmpdec/memory.h',
1956 '_decimal/libmpdec/mpdecimal.h',
1957 '_decimal/libmpdec/numbertheory.h',
1958 '_decimal/libmpdec/sixstep.h',
1959 '_decimal/libmpdec/transpose.h',
1960 '_decimal/libmpdec/typearith.h',
1961 '_decimal/libmpdec/umodarith.h',
1962 ]
1963
Stefan Krah1919b7e2012-03-21 18:25:23 +01001964 config = {
1965 'x64': [('CONFIG_64','1'), ('ASM','1')],
1966 'uint128': [('CONFIG_64','1'), ('ANSI','1'), ('HAVE_UINT128_T','1')],
1967 'ansi64': [('CONFIG_64','1'), ('ANSI','1')],
1968 'ppro': [('CONFIG_32','1'), ('PPRO','1'), ('ASM','1')],
1969 'ansi32': [('CONFIG_32','1'), ('ANSI','1')],
1970 'ansi-legacy': [('CONFIG_32','1'), ('ANSI','1'),
1971 ('LEGACY_COMPILER','1')],
1972 'universal': [('UNIVERSAL','1')]
1973 }
1974
Stefan Krah1919b7e2012-03-21 18:25:23 +01001975 cc = sysconfig.get_config_var('CC')
1976 sizeof_size_t = sysconfig.get_config_var('SIZEOF_SIZE_T')
1977 machine = os.environ.get('PYTHON_DECIMAL_WITH_MACHINE')
1978
1979 if machine:
1980 # Override automatic configuration to facilitate testing.
1981 define_macros = config[machine]
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001982 elif host_platform == 'darwin':
Stefan Krah1919b7e2012-03-21 18:25:23 +01001983 # Universal here means: build with the same options Python
1984 # was built with.
1985 define_macros = config['universal']
1986 elif sizeof_size_t == 8:
1987 if sysconfig.get_config_var('HAVE_GCC_ASM_FOR_X64'):
1988 define_macros = config['x64']
1989 elif sysconfig.get_config_var('HAVE_GCC_UINT128_T'):
1990 define_macros = config['uint128']
1991 else:
1992 define_macros = config['ansi64']
1993 elif sizeof_size_t == 4:
1994 ppro = sysconfig.get_config_var('HAVE_GCC_ASM_FOR_X87')
1995 if ppro and ('gcc' in cc or 'clang' in cc) and \
doko@ubuntu.com93df16b2012-06-30 14:32:08 +02001996 not 'sunos' in host_platform:
Stefan Krah1919b7e2012-03-21 18:25:23 +01001997 # solaris: problems with register allocation.
1998 # icc >= 11.0 works as well.
1999 define_macros = config['ppro']
Stefan Krahce23dbc2012-09-30 21:12:53 +02002000 extra_compile_args.append('-Wno-unknown-pragmas')
Stefan Krah1919b7e2012-03-21 18:25:23 +01002001 else:
2002 define_macros = config['ansi32']
2003 else:
2004 raise DistutilsError("_decimal: unsupported architecture")
2005
2006 # Workarounds for toolchain bugs:
2007 if sysconfig.get_config_var('HAVE_IPA_PURE_CONST_BUG'):
2008 # Some versions of gcc miscompile inline asm:
2009 # http://gcc.gnu.org/bugzilla/show_bug.cgi?id=46491
2010 # http://gcc.gnu.org/ml/gcc/2010-11/msg00366.html
2011 extra_compile_args.append('-fno-ipa-pure-const')
2012 if sysconfig.get_config_var('HAVE_GLIBC_MEMMOVE_BUG'):
2013 # _FORTIFY_SOURCE wrappers for memmove and bcopy are incorrect:
2014 # http://sourceware.org/ml/libc-alpha/2010-12/msg00009.html
2015 undef_macros.append('_FORTIFY_SOURCE')
2016
2017 # Faster version without thread local contexts:
2018 if not sysconfig.get_config_var('WITH_THREAD'):
2019 define_macros.append(('WITHOUT_THREADS', 1))
2020
Stefan Krahce55f082013-01-16 14:45:16 +01002021 # Increase warning level for gcc:
2022 if 'gcc' in cc:
Stefan Krah4f197442013-03-07 01:12:03 +01002023 cmd = ("echo '' | %s -Wextra -Wno-missing-field-initializers -E - "
2024 "> /dev/null 2>&1" % cc)
Stefan Krah13fe6d12013-01-17 12:49:34 +01002025 ret = os.system(cmd)
2026 if ret >> 8 == 0:
2027 extra_compile_args.extend(['-Wextra',
2028 '-Wno-missing-field-initializers'])
Stefan Krahce55f082013-01-16 14:45:16 +01002029
Stefan Krah1919b7e2012-03-21 18:25:23 +01002030 # Uncomment for extra functionality:
2031 #define_macros.append(('EXTRA_FUNCTIONALITY', 1))
2032 ext = Extension (
2033 '_decimal',
2034 include_dirs=include_dirs,
Stefan Krah60187b52012-03-23 19:06:27 +01002035 libraries=libraries,
Stefan Krah1919b7e2012-03-21 18:25:23 +01002036 define_macros=define_macros,
2037 undef_macros=undef_macros,
2038 extra_compile_args=extra_compile_args,
2039 sources=sources,
2040 depends=depends
2041 )
2042 return ext
Thomas Wouters49fd7fa2006-04-21 10:40:58 +00002043
Andrew M. Kuchlingf52d27e2001-05-21 20:29:27 +00002044class PyBuildInstall(install):
2045 # Suppress the warning about installation into the lib_dynload
2046 # directory, which is not in sys.path when running Python during
2047 # installation:
2048 def initialize_options (self):
2049 install.initialize_options(self)
2050 self.warn_dir=0
Michael W. Hudson5b109102002-01-23 15:04:41 +00002051
Éric Araujoe6792c12011-06-09 14:07:02 +02002052 # Customize subcommands to not install an egg-info file for Python
2053 sub_commands = [('install_lib', install.has_lib),
2054 ('install_headers', install.has_headers),
2055 ('install_scripts', install.has_scripts),
2056 ('install_data', install.has_data)]
2057
2058
Michael W. Hudson529a5052002-12-17 16:47:17 +00002059class PyBuildInstallLib(install_lib):
2060 # Do exactly what install_lib does but make sure correct access modes get
2061 # set on installed directories and files. All installed files with get
2062 # mode 644 unless they are a shared library in which case they will get
2063 # mode 755. All installed directories will get mode 755.
2064
doko@ubuntu.comd5537d02013-03-21 13:21:49 -07002065 # this is works for EXT_SUFFIX too, which ends with SHLIB_SUFFIX
2066 shlib_suffix = sysconfig.get_config_var("SHLIB_SUFFIX")
Michael W. Hudson529a5052002-12-17 16:47:17 +00002067
2068 def install(self):
2069 outfiles = install_lib.install(self)
Guido van Rossumcd16bf62007-06-13 18:07:49 +00002070 self.set_file_modes(outfiles, 0o644, 0o755)
2071 self.set_dir_modes(self.install_dir, 0o755)
Michael W. Hudson529a5052002-12-17 16:47:17 +00002072 return outfiles
2073
2074 def set_file_modes(self, files, defaultMode, sharedLibMode):
2075 if not self.is_chmod_supported(): return
2076 if not files: return
2077
2078 for filename in files:
2079 if os.path.islink(filename): continue
2080 mode = defaultMode
doko@ubuntu.comd5537d02013-03-21 13:21:49 -07002081 if filename.endswith(self.shlib_suffix): mode = sharedLibMode
Michael W. Hudson529a5052002-12-17 16:47:17 +00002082 log.info("changing mode of %s to %o", filename, mode)
2083 if not self.dry_run: os.chmod(filename, mode)
2084
2085 def set_dir_modes(self, dirname, mode):
2086 if not self.is_chmod_supported(): return
Amaury Forgeot d'Arc321e5332009-07-02 23:08:45 +00002087 for dirpath, dirnames, fnames in os.walk(dirname):
2088 if os.path.islink(dirpath):
2089 continue
2090 log.info("changing mode of %s to %o", dirpath, mode)
2091 if not self.dry_run: os.chmod(dirpath, mode)
Michael W. Hudson529a5052002-12-17 16:47:17 +00002092
2093 def is_chmod_supported(self):
2094 return hasattr(os, 'chmod')
2095
Georg Brandlff52f762010-12-28 09:51:43 +00002096class PyBuildScripts(build_scripts):
2097 def copy_scripts(self):
2098 outfiles, updated_files = build_scripts.copy_scripts(self)
2099 fullversion = '-{0[0]}.{0[1]}'.format(sys.version_info)
2100 minoronly = '.{0[1]}'.format(sys.version_info)
2101 newoutfiles = []
2102 newupdated_files = []
2103 for filename in outfiles:
Vinay Sajip7ded1f02012-05-26 03:45:29 +01002104 if filename.endswith(('2to3', 'pyvenv')):
Georg Brandlff52f762010-12-28 09:51:43 +00002105 newfilename = filename + fullversion
2106 else:
2107 newfilename = filename + minoronly
2108 log.info('renaming {} to {}'.format(filename, newfilename))
2109 os.rename(filename, newfilename)
2110 newoutfiles.append(newfilename)
2111 if filename in updated_files:
2112 newupdated_files.append(newfilename)
2113 return newoutfiles, newupdated_files
2114
Guido van Rossum14ee89c2003-02-20 02:52:04 +00002115SUMMARY = """
2116Python is an interpreted, interactive, object-oriented programming
2117language. It is often compared to Tcl, Perl, Scheme or Java.
2118
2119Python combines remarkable power with very clear syntax. It has
2120modules, classes, exceptions, very high level dynamic data types, and
2121dynamic typing. There are interfaces to many system calls and
2122libraries, as well as to various windowing systems (X11, Motif, Tk,
2123Mac, MFC). New built-in modules are easily written in C or C++. Python
2124is also usable as an extension language for applications that need a
2125programmable interface.
2126
2127The Python implementation is portable: it runs on many brands of UNIX,
Jesus Ceaf1af7052012-10-05 02:48:46 +02002128on Windows, DOS, Mac, Amiga... If your favorite system isn't
Guido van Rossum14ee89c2003-02-20 02:52:04 +00002129listed here, it may still be supported, if there's a C compiler for
2130it. Ask around on comp.lang.python -- or just try compiling Python
2131yourself.
2132"""
2133
2134CLASSIFIERS = """
Guido van Rossum14ee89c2003-02-20 02:52:04 +00002135Development Status :: 6 - Mature
2136License :: OSI Approved :: Python Software Foundation License
2137Natural Language :: English
2138Programming Language :: C
2139Programming Language :: Python
2140Topic :: Software Development
2141"""
2142
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00002143def main():
Andrew M. Kuchling62686692001-05-21 20:48:09 +00002144 # turn off warnings when deprecated modules are imported
2145 import warnings
2146 warnings.filterwarnings("ignore",category=DeprecationWarning)
Guido van Rossum14ee89c2003-02-20 02:52:04 +00002147 setup(# PyPI Metadata (PEP 301)
2148 name = "Python",
2149 version = sys.version.split()[0],
2150 url = "http://www.python.org/%s" % sys.version[:3],
2151 maintainer = "Guido van Rossum and the Python community",
2152 maintainer_email = "python-dev@python.org",
2153 description = "A high-level object-oriented programming language",
2154 long_description = SUMMARY.strip(),
2155 license = "PSF license",
Guido van Rossumc1f779c2007-07-03 08:25:58 +00002156 classifiers = [x for x in CLASSIFIERS.split("\n") if x],
Guido van Rossum14ee89c2003-02-20 02:52:04 +00002157 platforms = ["Many"],
2158
2159 # Build info
Georg Brandlff52f762010-12-28 09:51:43 +00002160 cmdclass = {'build_ext': PyBuildExt,
2161 'build_scripts': PyBuildScripts,
2162 'install': PyBuildInstall,
2163 'install_lib': PyBuildInstallLib},
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00002164 # The struct module is defined here, because build_ext won't be
2165 # called unless there's at least one extension module defined.
Thomas Wouters477c8d52006-05-27 19:21:47 +00002166 ext_modules=[Extension('_struct', ['_struct.c'])],
Andrew M. Kuchlingaece4272001-02-28 20:56:49 +00002167
Georg Brandlff52f762010-12-28 09:51:43 +00002168 # If you change the scripts installed here, you also need to
2169 # check the PyBuildScripts command above, and change the links
2170 # created by the bininstall target in Makefile.pre.in
Benjamin Petersondfea1922009-05-23 17:13:14 +00002171 scripts = ["Tools/scripts/pydoc3", "Tools/scripts/idle3",
Éric Araujo859aad62012-06-24 00:07:41 -04002172 "Tools/scripts/2to3", "Tools/scripts/pyvenv"]
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00002173 )
Fredrik Lundhade711a2001-01-24 08:00:28 +00002174
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00002175# --install-platlib
2176if __name__ == '__main__':
Andrew M. Kuchling00e0f212001-01-17 15:23:23 +00002177 main()