mirror of
https://github.com/python/cpython.git
synced 2025-11-13 07:26:31 +00:00
Rene Liebscher:
* use self.debug_print() for debug messages
* uses now copy.copy() to copy lists
* added 'shared_lib_extension=".dll"', ... , this is necessary if you
want use the compiler class outside of the standard distutils build
process.
* changed result type of check_config_h() from int to string
This commit is contained in:
parent
a4662bc1bc
commit
b1dceae3df
1 changed files with 23 additions and 18 deletions
|
|
@ -44,16 +44,19 @@ cygwin in no-cygwin mode).
|
||||||
|
|
||||||
__revision__ = "$Id$"
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
import os,sys
|
import os,sys,copy
|
||||||
from distutils.unixccompiler import UnixCCompiler
|
from distutils.unixccompiler import UnixCCompiler
|
||||||
from distutils.file_util import write_file
|
from distutils.file_util import write_file
|
||||||
|
|
||||||
class CygwinCCompiler (UnixCCompiler):
|
class CygwinCCompiler (UnixCCompiler):
|
||||||
|
|
||||||
compiler_type = 'cygwin'
|
compiler_type = 'cygwin'
|
||||||
gcc_version = None
|
obj_extension = ".o"
|
||||||
dllwrap_version = None
|
static_lib_extension = ".a"
|
||||||
ld_version = None
|
shared_lib_extension = ".dll"
|
||||||
|
static_lib_format = "lib%s%s"
|
||||||
|
shared_lib_format = "%s%s"
|
||||||
|
exe_extension = ".exe"
|
||||||
|
|
||||||
def __init__ (self,
|
def __init__ (self,
|
||||||
verbose=0,
|
verbose=0,
|
||||||
|
|
@ -62,14 +65,16 @@ class CygwinCCompiler (UnixCCompiler):
|
||||||
|
|
||||||
UnixCCompiler.__init__ (self, verbose, dry_run, force)
|
UnixCCompiler.__init__ (self, verbose, dry_run, force)
|
||||||
|
|
||||||
if check_config_h()<=0:
|
check_result = check_config_h()
|
||||||
|
self.debug_print("Python's GCC status: %s" % check_result)
|
||||||
|
if check_result[:2] <> "OK":
|
||||||
self.warn(
|
self.warn(
|
||||||
"Python's config.h doesn't seem to support your compiler. "
|
"Python's config.h doesn't seem to support your compiler. "
|
||||||
"Compiling may fail because of undefined preprocessor macros.")
|
"Compiling may fail because of undefined preprocessor macros.")
|
||||||
|
|
||||||
(self.gcc_version, self.ld_version, self.dllwrap_version) = \
|
(self.gcc_version, self.ld_version, self.dllwrap_version) = \
|
||||||
get_versions()
|
get_versions()
|
||||||
sys.stderr.write(self.compiler_type + ": gcc %s, ld %s, dllwrap %s\n" %
|
self.debug_print(self.compiler_type + ": gcc %s, ld %s, dllwrap %s\n" %
|
||||||
(self.gcc_version,
|
(self.gcc_version,
|
||||||
self.ld_version,
|
self.ld_version,
|
||||||
self.dllwrap_version) )
|
self.dllwrap_version) )
|
||||||
|
|
@ -117,9 +122,9 @@ class CygwinCCompiler (UnixCCompiler):
|
||||||
extra_postargs=None,
|
extra_postargs=None,
|
||||||
build_temp=None):
|
build_temp=None):
|
||||||
|
|
||||||
# use separate copies, so can modify the lists
|
# use separate copies, so we can modify the lists
|
||||||
extra_preargs = list(extra_preargs or [])
|
extra_preargs = copy.copy(extra_preargs or [])
|
||||||
libraries = list(libraries or [])
|
libraries = copy.copy(libraries or [])
|
||||||
|
|
||||||
# Additional libraries
|
# Additional libraries
|
||||||
libraries.extend(self.dll_libraries)
|
libraries.extend(self.dll_libraries)
|
||||||
|
|
@ -241,11 +246,11 @@ def check_config_h():
|
||||||
compiling probably doesn't work.
|
compiling probably doesn't work.
|
||||||
"""
|
"""
|
||||||
# return values
|
# return values
|
||||||
# 2: OK, python was compiled with GCC
|
# "OK, python was compiled with GCC"
|
||||||
# 1: OK, python's config.h mentions __GCC__
|
# "OK, python's config.h mentions __GCC__"
|
||||||
# 0: uncertain, because we couldn't check it
|
# "uncertain, because we couldn't check it"
|
||||||
# -1: probably not OK, because we didn't found it in config.h
|
# "not OK, because we didn't found __GCC__ in config.h"
|
||||||
# You could check check_config_h()>0 => OK
|
# You could check check_config_h()[:2] == "OK"
|
||||||
|
|
||||||
from distutils import sysconfig
|
from distutils import sysconfig
|
||||||
import string,sys
|
import string,sys
|
||||||
|
|
@ -254,7 +259,7 @@ def check_config_h():
|
||||||
if -1 == string.find(sys.version,"GCC"):
|
if -1 == string.find(sys.version,"GCC"):
|
||||||
pass # go to the next test
|
pass # go to the next test
|
||||||
else:
|
else:
|
||||||
return 2
|
return "OK, python was compiled with GCC"
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# It would probably better to read single lines to search.
|
# It would probably better to read single lines to search.
|
||||||
|
|
@ -265,14 +270,14 @@ def check_config_h():
|
||||||
|
|
||||||
# is somewhere a #ifdef __GNUC__ or something similar
|
# is somewhere a #ifdef __GNUC__ or something similar
|
||||||
if -1 == string.find(s,"__GNUC__"):
|
if -1 == string.find(s,"__GNUC__"):
|
||||||
return -1
|
return "not OK, because we didn't found __GCC__ in config.h"
|
||||||
else:
|
else:
|
||||||
return 1
|
return "OK, python's config.h mentions __GCC__"
|
||||||
except IOError:
|
except IOError:
|
||||||
# if we can't read this file, we cannot say it is wrong
|
# if we can't read this file, we cannot say it is wrong
|
||||||
# the compiler will complain later about this file as missing
|
# the compiler will complain later about this file as missing
|
||||||
pass
|
pass
|
||||||
return 0
|
return "uncertain, because we couldn't check it"
|
||||||
|
|
||||||
def get_versions():
|
def get_versions():
|
||||||
""" Try to find out the versions of gcc, ld and dllwrap.
|
""" Try to find out the versions of gcc, ld and dllwrap.
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue