# The full contents of the wx.build.config module used to be located
# here in setup.py. They were split into a separate module so it will
# be installed with wxPython and can then be used by the build scripts
-# of other extension modules that wich to be wxPython compatible. The
-# split is still fairly new and hasn't been tested by building
+# of other extension modules that wish to be wxPython compatible.
+# The split is still fairly new and hasn't been tested by building
# third-party extensions yet, so expect some things to still shift
# back and forth, and also more stuff in config.py will get converted
# to functions, etc.
# To fully support external builds, we need to have a build options
# file that is created whenever a new wxPython build is performed.
-# We happen to be doing that in this script, so make sure to remove
-# the build_options.py file, so that config.py will recreate it.
+# We happen to be doing that here in this script, so make sure to
+# remove the build_options.py file, so that config.py will recreate it.
-if os.path.exists("build_options.py"):
- os.remove("build_options.py")
+for bo_name in ["build_options.py", "build_options.pyc"]:
+ if os.path.exists(bo_name):
+ os.remove(bo_name)
sys.setup_is_main = __name__ == "__main__" # an icky hack!
from config import *
CLEANUP.append('wx/__version__.py')
+#----------------------------------------------------------------------
+# Write the SWIG version to a header file
+#----------------------------------------------------------------------
+
+if USE_SWIG:
+ try:
+ SVER = swig_version()
+ open('include/wx/wxPython/swigver.h', 'w').write('''\
+// This file was generated by setup.py
+
+#define wxPy_SWIG_VERSION "SWIG-%s"
+''' % SVER)
+ msg('Using SWIG-' + SVER)
+ except:
+ msg('\nUnable to get SWIG version number\n')
+
+
+
#----------------------------------------------------------------------
# patch distutils if it can't cope with the "classifiers" or
# "download_url" keywords
'src/_validator.i',
'src/_window.i',
'src/_control.i',
+ 'src/_swigtype.i',
],
True)
'src/_icon.i',
'src/_pen.i',
'src/_palette.i',
+ 'src/_renderer.i',
],
True)
ext = Extension('_gdi_', ['src/drawlist.cpp'] + swig_sources,
'src/_cshelp.i',
'src/_dragimg.i',
'src/_datectrl.i',
+ 'src/_hyperlink.i',
+ 'src/_picker.i',
],
True)
ext = Extension('_controls_', swig_sources,
'src/_display.i',
'src/_clipbrd.i',
'src/_stdpaths.i',
+ 'src/_power.i',
],
True)
ext = Extension('_misc_', swig_sources,
mediaLibs = libs[:]
-if not MONOLITHIC and os.name == 'nt':
- mediaLibs.append(makeLibName('media')[0])
+if not MONOLITHIC:
+ mediaLibs += makeLibName('media')
swig_sources = run_swig(['media.i'], 'src', GENDIR, PKGDIR,
USE_SWIG, swig_force, swig_args, swig_deps)
ext = Extension('_media', swig_sources,
define_macros = defines,
library_dirs = libdirs,
- libraries = libs,
+ libraries = libs + makeLibName('xrc'),
extra_compile_args = cflags,
extra_link_args = lflags,
wxpExtensions.append(ext)
+
+swig_sources = run_swig(['richtext.i'], 'src', GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+ext = Extension('_richtext', swig_sources,
+ include_dirs = includes,
+ define_macros = defines,
+ library_dirs = libdirs,
+ libraries = libs + makeLibName('richtext'),
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ **depends
+ )
+wxpExtensions.append(ext)
+
+
+
+
+
#----------------------------------------------------------------------
# Define the GLCanvas extension module
#----------------------------------------------------------------------
gl_libs = []
if os.name == 'posix':
gl_config = os.popen(WX_CONFIG + ' --libs gl', 'r').read()[:-1]
- gl_lflags = gl_config.split() + lflags
+ gl_lflags = gl_config.split()
gl_libs = libs
+
else:
gl_libs = libs + ['opengl32', 'glu32'] + makeLibName('gl')
gl_lflags = lflags
swig_args + ['-I'+STC_H, '-I'+location],
[opj(STC_H, 'stc.h'),
opj(location, "_stc_utf8_methods.py"),
+ opj(location, "_stc_docstrings.i"),
+ opj(location, "_stc_gendocs.i"),
] + swig_deps)
ext = Extension('_stc',
wxpExtensions.append(ext)
-
-#----------------------------------------------------------------------
-# Define the IEWIN extension module (experimental)
-#----------------------------------------------------------------------
-
-if BUILD_IEWIN:
- msg('Preparing IEWIN...')
- location = 'contrib/iewin'
-
- swig_files = ['iewin.i', ]
-
- swig_sources = run_swig(swig_files, location, '', PKGDIR,
- USE_SWIG, swig_force, swig_args, swig_deps)
-
-
- ext = Extension('_iewin', ['%s/IEHtmlWin.cpp' % location,
- '%s/wxactivex.cpp' % location,
- ] + swig_sources,
-
- include_dirs = includes + CONTRIBS_INC,
- define_macros = defines,
-
- library_dirs = libdirs,
- libraries = libs,
-
- extra_compile_args = cflags,
- extra_link_args = lflags,
- )
-
- wxpExtensions.append(ext)
-
-
#----------------------------------------------------------------------
# Define the ACTIVEX extension module (experimental)
#----------------------------------------------------------------------
if INSTALL_MULTIVERSION:
- EXTRA_PATH = getExtraPath(addOpts=EP_ADD_OPTS)
+ EXTRA_PATH = getExtraPath(addOpts=EP_ADD_OPTS, shortVer=not EP_FULL_VER)
open("src/wx.pth", "w").write(EXTRA_PATH)
CLEANUP.append("src/wx.pth")
else:
'wx',
'wx.build',
'wx.lib',
+ 'wx.lib.analogclock',
+ 'wx.lib.analogclock.lib_setup',
'wx.lib.colourchooser',
'wx.lib.editor',
'wx.lib.floatcanvas',