# flags and values that affect this script
#----------------------------------------------------------------------
-VERSION = "2.3.0b1"
+VERSION = "2.3b2"
DESCRIPTION = "Cross platform GUI toolkit for Python"
AUTHOR = "Robin Dunn"
AUTHOR_EMAIL = "robin@alldunn.com"
WXPLAT = '__WXMSW__'
GENDIR = 'msw'
-
-
if debug:
FINAL = 0
HYBRID = 0
if HYBRID:
FINAL = 0
-
includes = ['src',
os.path.join(WXDIR, 'include'),
]
else:
wxdll = 'wx' + WXDLLVER + 'd'
- #print 'Linking with ', wxdll
libs = [wxdll, 'kernel32', 'user32', 'gdi32', 'comdlg32',
'winspool', 'winmm', 'shell32', 'oldnames', 'comctl32',
'ctl3d32', 'odbc32', 'ole32', 'oleaut32', 'uuid', 'rpcrt4',
'advapi32', 'wsock32']
- cflags = None
+ cflags = ['/GX-'] # workaround for internal compiler error in MSVC 5
lflags = None
if not FINAL and HYBRID:
- cflags = ['/Od', '/Z7']
- lflags = ['/DEBUG', ] ## '/PDB:NONE']
+ cflags = cflags + ['/Od', '/Z7']
+ lflags = ['/DEBUG', ]
elif os.name == 'posix':
print 'Preparing CORE...'
swig_force = force
-swig_args = ['-c++', '-shadow', '-python', '-keyword', '-dnone',
+swig_args = ['-c++', '-shadow', '-python', '-keyword', '-dnone', #'-dascii',
'-I./src', '-D'+WXPLAT]
+swig_deps = ['src/my_typemaps.i']
swig_files = [ 'wx.i', 'windows.i', 'windows2.i', 'windows3.i', 'events.i',
- 'misc.i', 'misc2.i', 'utils.i', 'gdi.i', 'mdi.i', 'controls.i',
+ 'misc.i', 'misc2.i', 'gdi.i', 'mdi.i', 'controls.i',
'controls2.i', 'cmndlgs.i', 'stattool.i', 'frames.i', 'image.i',
- 'printfw.i', 'sizers.i', 'clip_dnd.i', 'grid.i', 'html.i',
- 'htmlhelp.i', 'calendar.i', 'filesys.i', 'streams.i'
+ 'printfw.i', 'sizers.i', 'clip_dnd.i',
+ 'filesys.i', 'streams.i',
+ ##'grid.i', 'html.i', 'htmlhelp.i', 'calendar.i', 'utils.i',
]
swig_sources = run_swig(swig_files, 'src', GENDIR, PKGDIR,
- USE_SWIG, swig_force, swig_args)
+ USE_SWIG, swig_force, swig_args, swig_deps)
copy_file('src/__init__.py', PKGDIR, update=1, verbose=0)
copy_file('src/__version__.py', PKGDIR, update=1, verbose=0)
rc_file = []
-wxext = ext = Extension('wxc', ['src/helpers.cpp',
+ext = Extension('wxc', ['src/helpers.cpp',
'src/libpy.c',
] + rc_file + swig_sources,
extra_compile_args = cflags,
extra_link_args = lflags,
)
+wxpExtensions.append(ext)
+# Extension for the grid module
+swig_sources = run_swig(['grid.i'], 'src', GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+ext = Extension('gridc', swig_sources,
+ include_dirs = includes,
+ define_macros = defines,
+ library_dirs = libdirs,
+ libraries = libs,
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
+wxpExtensions.append(ext)
+
+
+# Extension for the html modules
+swig_sources = run_swig(['html.i', 'htmlhelp.i'], 'src', GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+ext = Extension('htmlc', swig_sources,
+ include_dirs = includes,
+ define_macros = defines,
+ library_dirs = libdirs,
+ libraries = libs,
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
+wxpExtensions.append(ext)
+
+
+# Extension for the utils module
+swig_sources = run_swig(['utils.i'], 'src', GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+ext = Extension('utilsc', swig_sources,
+ include_dirs = includes,
+ define_macros = defines,
+ library_dirs = libdirs,
+ libraries = libs,
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
+wxpExtensions.append(ext)
+
+
+# Extension for the calendar module
+swig_sources = run_swig(['calendar.i'], 'src', GENDIR, PKGDIR,
+ USE_SWIG, swig_force, swig_args, swig_deps)
+ext = Extension('calendarc', swig_sources,
+ include_dirs = includes,
+ define_macros = defines,
+ library_dirs = libdirs,
+ libraries = libs,
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
wxpExtensions.append(ext)
-if os.name == 'nt':
- libs = libs[:]
- if debug:
- libs.insert(0, 'wxc_d')
- else:
- libs.insert(0, 'wxc')
#----------------------------------------------------------------------
# Define the GLCanvas extension module
#----------------------------------------------------------------------
-if not BUILD_GLCANVAS:
- wxext.sources = wxext.sources + ['contrib/glcanvas/stub.cpp']
-else:
+if BUILD_GLCANVAS:
print 'Preparing GLCANVAS...'
location = 'contrib/glcanvas'
swig_files = ['glcanvas.i']
else:
gl_libs = ['wx_gtk_gl', 'GL', 'GLU']
- wxext.sources = wxext.sources + swig_sources
- wxext.libraries = wxext.libraries + gl_libs
+ ext = Extension('glcanvasc',
+ swig_sources,
+
+ include_dirs = includes,
+ define_macros = defines,
+
+ library_dirs = libdirs,
+ libraries = libs + gl_libs,
+
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
+
+ wxpExtensions.append(ext)
#----------------------------------------------------------------------
#----------------------------------------------------------------------
-if not BUILD_OGL:
- wxext.sources = wxext.sources + ['contrib/ogl/stub.cpp']
-else:
+if BUILD_OGL:
print 'Preparing OGL...'
location = 'contrib/ogl'
OGLLOC = location + '/contrib/src/ogl'
contrib_copy_tree(WXDIR + '/contrib/include/wx/ogl', OGLINC+'/wx/ogl')
contrib_copy_tree(WXDIR + '/contrib/src/ogl', OGLLOC)
- # add items to the core extension module definition
- wxext.sources = wxext.sources + [location + '/oglhelpers.cpp',
- '%s/basic.cpp' % OGLLOC,
- '%s/bmpshape.cpp' % OGLLOC,
- '%s/composit.cpp' % OGLLOC,
- '%s/divided.cpp' % OGLLOC,
- '%s/lines.cpp' % OGLLOC,
- '%s/misc.cpp' % OGLLOC,
- '%s/basic2.cpp' % OGLLOC,
- '%s/canvas.cpp' % OGLLOC,
- '%s/constrnt.cpp' % OGLLOC,
- '%s/drawn.cpp' % OGLLOC,
- '%s/mfutils.cpp' % OGLLOC,
- '%s/ogldiag.cpp' % OGLLOC,
- ] + swig_sources
-
- wxext.include_dirs = wxext.include_dirs + [OGLINC]
+ ext = Extension('oglc', ['%s/basic.cpp' % OGLLOC,
+ '%s/bmpshape.cpp' % OGLLOC,
+ '%s/composit.cpp' % OGLLOC,
+ '%s/divided.cpp' % OGLLOC,
+ '%s/lines.cpp' % OGLLOC,
+ '%s/misc.cpp' % OGLLOC,
+ '%s/basic2.cpp' % OGLLOC,
+ '%s/canvas.cpp' % OGLLOC,
+ '%s/constrnt.cpp' % OGLLOC,
+ '%s/drawn.cpp' % OGLLOC,
+ '%s/mfutils.cpp' % OGLLOC,
+ '%s/ogldiag.cpp' % OGLLOC,
+ ] + swig_sources,
+
+ include_dirs = [OGLINC] + includes,
+ define_macros = defines,
+
+ library_dirs = libdirs,
+ libraries = libs,
+
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
+
+ wxpExtensions.append(ext)
+
+
#----------------------------------------------------------------------
# Define the STC extension module
#----------------------------------------------------------------------
-
-if not BUILD_STC:
- wxext.sources = wxext.sources + ['contrib/stc/stub.cpp']
-else:
+if BUILD_STC:
print 'Preparing STC...'
location = 'contrib/stc'
STCLOC = location + '/contrib/src/stc'
copy_file(location+'/stc.py', PKGDIR, update=1, verbose=1)
# add some include dirs to the standard set
- stc_includes = [ '%s/scintilla/include' % STCLOC,
- '%s/scintilla/src' % STCLOC,
- STCINC ]
+ stc_includes = includes[:]
+ stc_includes.append('%s/scintilla/include' % STCLOC)
+ stc_includes.append('%s/scintilla/src' % STCLOC)
+ stc_includes.append(STCINC)
# and some macro definitions
- stc_defines = [ ('__WX__', None),
- ('SCI_LEXER', None) ]
+ stc_defines = defines[:]
+ stc_defines.append( ('__WX__', None) )
+ stc_defines.append( ('SCI_LEXER', None) )
- # add items to the core extension module definition
- wxext.sources = wxext.sources + [
- '%s/scintilla/src/AutoComplete.cxx' % STCLOC,
+ ext = Extension('stc_c',
+ ['%s/scintilla/src/AutoComplete.cxx' % STCLOC,
'%s/scintilla/src/CallTip.cxx' % STCLOC,
'%s/scintilla/src/CellBuffer.cxx' % STCLOC,
'%s/scintilla/src/ContractionState.cxx' % STCLOC,
'%s/PlatWX.cpp' % STCLOC,
'%s/ScintillaWX.cpp' % STCLOC,
'%s/stc.cpp' % STCLOC,
- ] + swig_sources
+ ] + swig_sources,
- wxext.include_dirs = wxext.include_dirs + stc_includes
- wxext.define_macros = wxext.define_macros + stc_defines
+ include_dirs = stc_includes,
+ define_macros = stc_defines,
+
+ library_dirs = libdirs,
+ libraries = libs,
+
+ extra_compile_args = cflags,
+ extra_link_args = lflags,
+ )
+
+ wxpExtensions.append(ext)
#----------------------------------------------------------------------
#----------------------------------------------------------------------
#----------------------------------------------------------------------
-
-# Originally I was building separate extension module .so's for the
-# CORE and the various contribs. Because of shared library issues I've
-# decided to combine things into one .so as implemented above, but as
-# I'm still not entirely convinced that this is the right thing to do
-# I will keep the old code around for a while, but commented out below.
-
-## if BUILD_GLCANVAS:
+## if not BUILD_GLCANVAS:
+## wxext.sources = wxext.sources + ['contrib/glcanvas/stub.cpp']
+## else:
## print 'Preparing GLCANVAS...'
## location = 'contrib/glcanvas'
## swig_files = ['glcanvas.i']
## swig_sources = run_swig(swig_files, location, GENDIR, PKGDIR,
-## USE_SWIG, swig_force, swig_args)
+## USE_SWIG, swig_force, swig_args, swig_deps)
## gl_libs = []
## if os.name == 'posix':
## else:
## gl_libs = ['wx_gtk_gl', 'GL', 'GLU']
-## ext = Extension('glcanvasc',
-## swig_sources,
-
-## include_dirs = includes,
-## define_macros = defines,
-
-## library_dirs = libdirs,
-## libraries = libs + gl_libs,
-
-## extra_compile_args = cflags,
-## extra_link_args = lflags,
-## )
-
-## wxpExtensions.append(ext)
+## wxext.sources = wxext.sources + swig_sources
+## wxext.libraries = wxext.libraries + gl_libs
-
-## if BUILD_OGL:
+## if not BUILD_OGL:
+## wxext.sources = wxext.sources + ['contrib/ogl/stub.cpp']
+## else:
## print 'Preparing OGL...'
## location = 'contrib/ogl'
## OGLLOC = location + '/contrib/src/ogl'
## 'oglcanvas.i']
## swig_sources = run_swig(swig_files, location, '', PKGDIR,
-## USE_SWIG, swig_force, swig_args)
+## USE_SWIG, swig_force, swig_args, swig_deps)
## # make sure local copy of contrib files are up to date
## if IN_CVS_TREE:
## contrib_copy_tree(WXDIR + '/contrib/include/wx/ogl', OGLINC+'/wx/ogl')
## contrib_copy_tree(WXDIR + '/contrib/src/ogl', OGLLOC)
-## ext = Extension('oglc', [location + '/oglhelpers.cpp',
-## '%s/basic.cpp' % OGLLOC,
-## '%s/bmpshape.cpp' % OGLLOC,
-## '%s/composit.cpp' % OGLLOC,
-## '%s/divided.cpp' % OGLLOC,
-## '%s/lines.cpp' % OGLLOC,
-## '%s/misc.cpp' % OGLLOC,
-## '%s/basic2.cpp' % OGLLOC,
-## '%s/canvas.cpp' % OGLLOC,
-## '%s/constrnt.cpp' % OGLLOC,
-## '%s/drawn.cpp' % OGLLOC,
-## '%s/mfutils.cpp' % OGLLOC,
-## '%s/ogldiag.cpp' % OGLLOC,
-## ] + swig_sources,
-
-## include_dirs = [OGLINC] + includes,
-## define_macros = defines,
+## # add items to the core extension module definition
+## wxext.sources = wxext.sources + [location + '/oglhelpers.cpp',
+## '%s/basic.cpp' % OGLLOC,
+## '%s/bmpshape.cpp' % OGLLOC,
+## '%s/composit.cpp' % OGLLOC,
+## '%s/divided.cpp' % OGLLOC,
+## '%s/lines.cpp' % OGLLOC,
+## '%s/misc.cpp' % OGLLOC,
+## '%s/basic2.cpp' % OGLLOC,
+## '%s/canvas.cpp' % OGLLOC,
+## '%s/constrnt.cpp' % OGLLOC,
+## '%s/drawn.cpp' % OGLLOC,
+## '%s/mfutils.cpp' % OGLLOC,
+## '%s/ogldiag.cpp' % OGLLOC,
+## ] + swig_sources
-## library_dirs = libdirs,
-## libraries = libs,
+## wxext.include_dirs = wxext.include_dirs + [OGLINC]
-## extra_compile_args = cflags,
-## extra_link_args = lflags,
-## )
-## wxpExtensions.append(ext)
-
-## if BUILD_STC:
+## if not BUILD_STC:
+## wxext.sources = wxext.sources + ['contrib/stc/stub.cpp']
+## else:
## print 'Preparing STC...'
## location = 'contrib/stc'
## STCLOC = location + '/contrib/src/stc'
## swig_sources = run_swig(swig_files, location, '', PKGDIR,
## USE_SWIG, swig_force,
## swig_args + ['-I'+STC_H, '-I'+location],
-## [STC_H+'/stc.h'])
+## swig_deps + [STC_H+'/stc.h'])
## # copy a project specific py module to the main package dir
## copy_file(location+'/stc.py', PKGDIR, update=1, verbose=1)
## # add some include dirs to the standard set
-## stc_includes = includes[:]
-## stc_includes.append('%s/scintilla/include' % STCLOC)
-## stc_includes.append('%s/scintilla/src' % STCLOC)
-## stc_includes.append(STCINC)
+## stc_includes = [ '%s/scintilla/include' % STCLOC,
+## '%s/scintilla/src' % STCLOC,
+## STCINC ]
## # and some macro definitions
-## stc_defines = defines[:]
-## stc_defines.append( ('__WX__', None) )
-## stc_defines.append( ('SCI_LEXER', None) )
+## stc_defines = [ ('__WX__', None),
+## ('SCI_LEXER', None) ]
-## ext = Extension('stc_c',
-## ['%s/scintilla/src/AutoComplete.cxx' % STCLOC,
+## # add items to the core extension module definition
+## wxext.sources = wxext.sources + [
+## '%s/scintilla/src/AutoComplete.cxx' % STCLOC,
## '%s/scintilla/src/CallTip.cxx' % STCLOC,
## '%s/scintilla/src/CellBuffer.cxx' % STCLOC,
## '%s/scintilla/src/ContractionState.cxx' % STCLOC,
## '%s/PlatWX.cpp' % STCLOC,
## '%s/ScintillaWX.cpp' % STCLOC,
## '%s/stc.cpp' % STCLOC,
-## ] + swig_sources,
-
-## include_dirs = stc_includes,
-## define_macros = stc_defines,
-
-## library_dirs = libdirs,
-## libraries = libs,
-
-## extra_compile_args = cflags,
-## extra_link_args = lflags,
-## )
-
-## wxpExtensions.append(ext)
-
+## ] + swig_sources
+## wxext.include_dirs = wxext.include_dirs + stc_includes
+## wxext.define_macros = wxext.define_macros + stc_defines