SYS_WX_CONFIG = None # When installing an in tree build, setup.py uses wx-config
# for two different purposes. First, to determine the prefix
- # where files will be installed, and secondly, to initialise
- # build_options.py with the correct options for it.
- # WX_CONFIG is used for the first task. SYS_WX_CONFIG may
- # be set independently, to the value that should appear in
- # build_options.py, if it is different to that. The default
- # is to use the value of WX_CONFIG.
+ # where files will be installed, and secondly, to initialise
+ # build_options.py with the correct options for it.
+ # WX_CONFIG is used for the first task. SYS_WX_CONFIG may
+ # be set independently, to the value that should appear in
+ # build_options.py, if it is different to that. The default
+ # is to use the value of WX_CONFIG.
WXPORT = 'gtk2' # On Linux/Unix there are several ports of wxWidgets available.
# Setting this value lets you select which will be used for
if USE_SWIG and not os.path.exists(os.path.join(dir, gendir)):
os.mkdir(os.path.join(dir, gendir))
- if USE_SWIG and not os.path.exists(os.path.join("docs", "xml-raw")):
- if not os.path.exists("docs"):
- os.mkdir("docs")
- os.mkdir(os.path.join("docs", "xml-raw"))
-
sources = []
if add_under: pre = '_'
i_file = os.path.join(dir, file)
py_file = os.path.join(dir, gendir, pre+basefile+'.py')
cpp_file = os.path.join(dir, gendir, pre+basefile+'_wrap.cpp')
- xml_file = os.path.join("docs", "xml-raw", basefile+pre+'_swig.xml')
if add_under:
interface = ['-interface', '_'+basefile+'_']
# Then run swig for real
cmd = [ swig_cmd ] + swig_args + interface + \
- ['-I'+dir, '-o', cpp_file, '-xmlout', xml_file, i_file]
+ ['-I'+dir, '-o', cpp_file, i_file]
msg(' '.join(cmd))
spawn(cmd)
return sources
+def swig_version():
+ # It may come on either stdout or stderr, depending on the
+ # version, so read both.
+ i, o, e = os.popen3(SWIG + ' -version', 't')
+ stext = o.read() + e.read()
+ import re
+ match = re.search(r'[0-9]+\.[0-9]+\.[0-9]+$', stext, re.MULTILINE)
+ if not match:
+ raise 'NotFound'
+ SVER = match.group(0)
+ return SVER
+
# Specializations of some distutils command classes
class wx_smart_install_data(distutils.command.install_data.install_data):
('WXUSINGDLL', '1'),
('SWIG_TYPE_TABLE', WXPYTHON_TYPE_TABLE),
+ ('SWIG_PYTHON_OUTPUT_TUPLE', None),
('WXP_USE_THREAD', '1'),
]
if not FINAL or HYBRID:
defines.append( ('__WXDEBUG__', None) )
+ if UNICODE:
+ defines.append( ('wxUSE_UNICODE', 1) )
+
libdirs = [ opj(WXDIR, 'lib', 'vc_dll') ]
if MONOLITHIC:
libs = makeLibName('')
WXDIR = '..'
includes = ['include', 'src']
defines = [('SWIG_TYPE_TABLE', WXPYTHON_TYPE_TABLE),
- ('HAVE_CONFIG_H', None),
+ ('SWIG_PYTHON_OUTPUT_TUPLE', None),
('WXP_USE_THREAD', '1'),
]
if UNDEF_NDEBUG:
swig_cmd = SWIG
swig_force = force
swig_args = ['-c++',
- '-Wall',
- '-nodefault',
-
+ #'-Wall',
'-python',
- '-keyword',
'-new_repr',
'-modern',
'-D'+WXPLAT,
] + i_files_includes
+
+if USE_SWIG:
+ SVER = swig_version()
+ if int(SVER[-2:]) >= 29:
+ swig_args += [ '-fastdispatch',
+ '-fvirtual',
+ '-fastinit',
+ '-fastunpack',
+ #'-outputtuple', Currently setting this with a -D define above
+ ]
if UNICODE:
swig_args.append('-DwxUSE_UNICODE')
# do a depth first iteration over what's left
for node in topnode:
doRename = False
- doPtr = False
addWX = False
revOnly = False
lastClassName = name = self.GetAttr(node, "name")
lastClassSymName = sym_name = self.GetAttr(node, "sym_name")
doRename = True
- doPtr = True
if sym_name != name:
name = sym_name
addWX = True
if addWX and not old.startswith('wx'):
old = 'wx'+old
pyFile.write("%s = wx.%s.%s\n" % (old, modname, new))
- if doPtr:
- pyFile.write("%sPtr = wx.%s.%sPtr\n" % (old, modname, new))
#---------------------------------------------------------------------------