# Licence: wxWindows license
#----------------------------------------------------------------------
-import sys
+import sys, os
# The full contents of the wx.build.config module used to be located
# config .py in the same place as setup.py, and then copy it to
# wx/build as needed below.
+# 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.
+
+if os.path.exists("build_options.py"):
+ os.remove("build_options.py")
+
sys.setup_is_main = __name__ == "__main__" # an icky hack!
from config import *
#----------------------------------------------------------------------
copy_file('config.py', 'wx/build', update=1, verbose=1)
+copy_file('build_options.py', 'wx/build', update=1, verbose=1)
CLEANUP.append('wx/build/config.py')
+CLEANUP.append('wx/build/build_options.py')
#----------------------------------------------------------------------
# Update the version file
CLEANUP.append('wx/__version__.py')
+#----------------------------------------------------------------------
+# patch distutils if it can't cope with the "classifiers" or
+# "download_url" keywords
+#----------------------------------------------------------------------
+
+if sys.version < '2.2.3':
+ from distutils.dist import DistributionMetadata
+ DistributionMetadata.classifiers = None
+ DistributionMetadata.download_url = None
+ depends = {}
+else:
+ depends = {'depends' : depends}
+
+
#----------------------------------------------------------------------
# Define the CORE extension module
#----------------------------------------------------------------------
ext = Extension('_core_', ['src/helpers.cpp',
- 'src/libpy.c',
] + rc_file + swig_sources,
include_dirs = includes,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
'src/_pycontrol.i',
'src/_cshelp.i',
'src/_dragimg.i',
+ 'src/_datectrl.i',
],
True)
ext = Extension('_controls_', swig_sources,
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
'src/_dnd.i',
'src/_display.i',
'src/_clipbrd.i',
+ 'src/_stdpaths.i',
],
True)
ext = Extension('_misc_', swig_sources,
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
+ )
+wxpExtensions.append(ext)
+
+
+mediaLibs = libs[:]
+if not MONOLITHIC and os.name == 'nt':
+ mediaLibs.append(makeLibName('media')[0])
+swig_sources = run_swig(['media.i'], 'src', GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+ext = Extension('_media', swig_sources,
+ include_dirs = includes,
+ define_macros = defines,
+ library_dirs = libdirs,
+ libraries = mediaLibs,
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ **depends
+ )
+wxpExtensions.append(ext)
+
+
+swig_sources = run_swig(['webkit.i'], 'src', GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+ext = Extension('_webkit', swig_sources,
+ include_dirs = includes,
+ define_macros = defines,
+ library_dirs = libdirs,
+ libraries = libs,
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ **depends
)
wxpExtensions.append(ext)
libraries = libs,
extra_compile_args = cflags,
extra_link_args = lflags,
- depends = depends
+ **depends
)
wxpExtensions.append(ext)
wxpExtensions.append(ext)
+#----------------------------------------------------------------------
+# Define the ANIMATE extension module
+#----------------------------------------------------------------------
+
+if BUILD_ANIMATE:
+ msg('Preparing ANIMATE...')
+ location = 'contrib/animate'
+
+ swig_sources = run_swig(['animate.i'], location, GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+
+ ext = Extension('_animate',
+ swig_sources,
+
+ include_dirs = includes + CONTRIBS_INC,
+ define_macros = defines,
+
+ library_dirs = libdirs,
+ libraries = libs + makeLibName('animate'),
+
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
+
+ wxpExtensions.append(ext)
+
+
#----------------------------------------------------------------------
# Define the DLLWIDGET extension module
-#----------------------------------------------------------------------
-# patch distutils if it can't cope with the "classifiers" or
-# "download_url" keywords
-#----------------------------------------------------------------------
-
-if sys.version < '2.2.3':
- from distutils.dist import DistributionMetadata
- DistributionMetadata.classifiers = None
- DistributionMetadata.download_url = None
-
#----------------------------------------------------------------------
# Tools, scripts data files, etc.
opj('scripts/pyshell'),
opj('scripts/pywrap'),
opj('scripts/pywrap'),
+ opj('scripts/pywxrc'),
opj('scripts/xrced'),
]
- if INSTALL_WXRC:
- SCRIPTS += [opj('scripts/wxrc')]
if INSTALL_MULTIVERSION:
- EXTRA_PATH = getExtraPath()
+ EXTRA_PATH = getExtraPath(addOpts=EP_ADD_OPTS)
open("src/wx.pth", "w").write(EXTRA_PATH)
CLEANUP.append("src/wx.pth")
else: