import string, os.path, copy
+# list of files that should _not_ be generated even thought we could do it:
+DONT_GENERATE = [
+ '../../samples/Makefile.in',
+ '../../samples/samples.dsw',
+ '../../demos/demos.dsw',
+ '../../samples/html/html_samples.dsw',
+ '../../samples/opengl/opengl_samples.dsw',
+ '../../samples/mobile/mobile_samples.dsw',
+ '../../utils/utils.dsw',
+]
+
file = open('Makefile', 'wt')
file.write("""
# Generated by regenMakefile.py
SDEPS = config.bkl common.bkl common_samples.bkl
MDEPS = common.bkl config.bkl files.bkl monolithic.bkl multilib.bkl opengl.bkl wxwin.py
-DSWFLAGS = -DRUNTIME_LIBS=dynamic -DOFFICIAL_BUILD=0 -DUSE_HTML=1 \
- -DUSE_OPENGL=1 -DMONOLITHIC=0 -DUSE_GUI=1
+DSWFLAGS = -DRUNTIME_LIBS=dynamic -DOFFICIAL_BUILD=0 -DUSE_HTML=1 \\
+ -DUSE_OPENGL=1 -DUSE_ODBC=1 -DMONOLITHIC=0 -DUSE_GUI=1 \\
+ -DDEBUG_INFO=default -DDEBUG_FLAG=default -DMSLU=0
+
+COMPAT_TARGETS = ../../src/wxWindows.dsp
+
""")
lines = {}
else:
makedir = makedirs['all']
tfile = '%s/%s' % (makedir, make)
+
+ if tfile in DONT_GENERATE: return
+
linesCur.append('%s: %s' % (tfile, dep))
linesCur.append('\t$(BAKEFILE) -f%s -o$@ %s %s' % (format, a, bake))
linesCur.append('\ttouch $@')
add(bake, makedirs, 'makefile.vc', dep, 'msvc', args)
add(bake, makedirs, 'makefile.gcc', dep, 'mingw', args)
add(bake, makedirs, 'makefile.wat', dep, 'watcom', args)
-
- if 'msvc6prj' in args and args['msvc6prj'] != None:
- add(bake, makedirs,
- (bake[1+bake.rfind('/'):]).replace('.bkl','.dsw'),
- dep, 'msvc6prj', args)
+ add(bake, makedirs,
+ (bake[1+bake.rfind('/'):]).replace('.bkl','.dsw'),
+ dep, 'msvc6prj', args)
lines[bake] = linesCur
# -----------------------------------------------
# main makefile:
-addMakefile('wx.bkl', {'all':'..','autoconf':'../..'}, [ '$(MDEPS)' ],
+addMakefile('wx.bkl', {'all':'../msw','autoconf':'../..'}, [ '$(MDEPS)' ],
args={
'borland':'-DOPTIONS_FILE=config.bcc',
'msvc':'-DOPTIONS_FILE=config.vc',
addMakefile('../../samples/samples.bkl', {'all':'../../samples'},
args={
'autoconf':'-DAUTOCONF_MACROS_FILE=../../autoconf_inc.m4',
- 'borland':'-DOPTIONS_FILE=../build/config.bcc -DWRITE_OPTIONS_FILE=0',
- 'msvc':'-DOPTIONS_FILE=../build/config.vc -DWRITE_OPTIONS_FILE=0',
- 'mingw':'-DOPTIONS_FILE=../build/config.gcc -DWRITE_OPTIONS_FILE=0',
- 'watcom':'-DOPTIONS_FILE=../build/config.wat -DWRITE_OPTIONS_FILE=0',
- 'msvc6prj':None,
+ 'borland':'-DOPTIONS_FILE=../build/msw/config.bcc -DWRITE_OPTIONS_FILE=0',
+ 'msvc':'-DOPTIONS_FILE=../build/msw/config.vc -DWRITE_OPTIONS_FILE=0',
+ 'mingw':'-DOPTIONS_FILE=../build/msw/config.gcc -DWRITE_OPTIONS_FILE=0',
+ 'watcom':'-DOPTIONS_FILE=../build/msw/config.wat -DWRITE_OPTIONS_FILE=0',
+ })
+addMakefile('../../demos/demos.bkl', {'all':'../../demos'},
+ args={
+ 'autoconf':'-DAUTOCONF_MACROS_FILE=../../autoconf_inc.m4',
+ 'borland':'-DOPTIONS_FILE=../build/msw/config.bcc -DWRITE_OPTIONS_FILE=0',
+ 'msvc':'-DOPTIONS_FILE=../build/msw/config.vc -DWRITE_OPTIONS_FILE=0',
+ 'mingw':'-DOPTIONS_FILE=../build/msw/config.gcc -DWRITE_OPTIONS_FILE=0',
+ 'watcom':'-DOPTIONS_FILE=../build/msw/config.wat -DWRITE_OPTIONS_FILE=0',
+ })
+addMakefile('../../utils/utils.bkl', {'all':'../../utils'},
+ args={
+ 'autoconf':'-DAUTOCONF_MACROS_FILE=../../autoconf_inc.m4',
+ 'borland':'-DOPTIONS_FILE=../build/msw/config.bcc -DWRITE_OPTIONS_FILE=0',
+ 'msvc':'-DOPTIONS_FILE=../build/msw/config.vc -DWRITE_OPTIONS_FILE=0',
+ 'mingw':'-DOPTIONS_FILE=../build/msw/config.gcc -DWRITE_OPTIONS_FILE=0',
+ 'watcom':'-DOPTIONS_FILE=../build/msw/config.wat -DWRITE_OPTIONS_FILE=0',
})
if type==SAMPLES_DIR:
prefix = ''.join(['../' for i in range(0,depth)])
- dirflags = '-DWXTOPDIR=%s../' % prefix
- cfgbase = '%s../build/config.' % prefix
+ topdirflags = '-DWXTOPDIR=%s../' % prefix
+ srcdirflags = ''
+ cfgbase = '%s../build/msw/config.' % prefix
elif type==CONTRIB_DIR:
- dirflags = '-DSRCDIR=../../src/%s' % dirname.split('/')[-1]
- dirflags += ' -DWXTOPDIR=../../../'
- cfgbase = '../../../build/config.'
+ srcdirflags = '-DSRCDIR=../../src/%s' % dirname.split('/')[-1]
+ topdirflags = ' -DWXTOPDIR=../../../'
+ cfgbase = '../../../build/msw/config.'
args = {
- 'not_autoconf':dirflags,
+ 'all':topdirflags,
+ 'not_autoconf':srcdirflags,
'autoconf':'-DAUTOCONF_MACROS_FILE=../../autoconf_inc.m4',
'msvc':'-DOPTIONS_FILE='+cfgbase+'vc -DWRITE_OPTIONS_FILE=0',
'mingw':'-DOPTIONS_FILE='+cfgbase+'gcc -DWRITE_OPTIONS_FILE=0',
}
for bake in bakes:
- if bake.endswith('_samples.bkl'):
- args['msvc6prj'] = None
if type==CONTRIB_DIR:
acdir = '../../contrib/src/%s' % dirname.split('/')[-1]
ruledep = '$(CDEPS)'
os.path.walk(os.path.join('..','..','samples'),
onSubmakefile, SAMPLES_DIR)
+os.path.walk(os.path.join('..','..','demos'),
+ onSubmakefile, SAMPLES_DIR)
+os.path.walk(os.path.join('..','..','utils'),
+ onSubmakefile, SAMPLES_DIR)
os.path.walk(os.path.join('..','..','contrib','build'),
onSubmakefile, CONTRIB_DIR)
os.path.walk(os.path.join('..','..','contrib','samples'),
var = '%s_ALL' % f.upper()
file.write('%s = \\\n\t%s\n' % (var,' \\\n\t'.join(all[f])))
-file.write('all:')
+file.write('\nall: $(COMPAT_TARGETS)')
for f in allK:
file.write(' %s' % f)
file.write('\n\n')
file.write("""
clean:
\trm -f ../../autoconf_inc.m4
+\trm -f $(COMPAT_TARGETS)
%s
-library: ../../Makefile.in ../makefile.bcc ../makefile.vc ../makefile.wat ../makefile.gcc
+library: ../../Makefile.in\\
+ ../msw/makefile.bcc\\
+ ../msw/makefile.vc\\
+ ../msw/makefile.wat\\
+ ../msw/makefile.gcc\\
+ ../msw/wx.dsw\\
+ ../../src/wxWindows.dsp
../../autoconf_inc.m4: ../../Makefile.in
+../../src/wxWindows.dsp: monolithic.bkl files.bkl
+\t$(BAKEFILE) -Icompat -fwx24dsp -DUSE_GUI=1 -DWXUNIV=0 -o$@ wx.bkl
+\ttouch $@
+
Makefile: regenMakefile.py
\t./regenMakefile.py
\t@echo