summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNathan Binkert <binkertn@umich.edu>2007-02-21 10:30:51 -0800
committerNathan Binkert <binkertn@umich.edu>2007-02-21 10:30:51 -0800
commita329631edbf18d01f5f84b57147bdd69f1e2e6b3 (patch)
tree798b597575627dc9a179b106a2a209ef663be06e
parent3fb3616be4bc68c15aa67df0b93d6b0f790acd16 (diff)
downloadgem5-a329631edbf18d01f5f84b57147bdd69f1e2e6b3.tar.xz
Automatically generate m5/internal/__init__.py and swig/init.cc
based on the swig modules that we have --HG-- extra : convert_revision : 2fd12db39d46608a62b9df36c2b36189f1d2bc30
-rw-r--r--src/python/SConscript35
1 files changed, 31 insertions, 4 deletions
diff --git a/src/python/SConscript b/src/python/SConscript
index 4dd614cfb..8c7e47909 100644
--- a/src/python/SConscript
+++ b/src/python/SConscript
@@ -99,12 +99,13 @@ pyzip_files.append('m5/info.py')
pyzip_files.append(join(env['ROOT'], 'util/pbs/jobfile.py'))
pyzip_files.append(join(env['ROOT'], 'src/base/traceflags.py'))
-def swig_it(basename):
- env.Command(['swig/%s_wrap.cc' % basename, 'm5/internal/%s.py' % basename],
- 'swig/%s.i' % basename,
+swig_modules = []
+def swig_it(module):
+ env.Command(['swig/%s_wrap.cc' % module, 'm5/internal/%s.py' % module],
+ 'swig/%s.i' % module,
'$SWIG $SWIGFLAGS -outdir ${TARGETS[1].dir} '
'-o ${TARGETS[0]} $SOURCES')
- pyzip_dep_files.append('m5/internal/%s.py' % basename)
+ swig_modules.append(module)
swig_it('main')
swig_it('debug')
@@ -113,6 +114,32 @@ swig_it('random')
swig_it('stats')
swig_it('trace')
+# Automatically generate m5/internals/__init__.py
+def MakeInternalsInit(target, source, env):
+ f = file(str(target[0]), 'w')
+ for m in swig_modules:
+ print >>f, 'import %s' % m
+ f.close()
+
+swig_py_files = [ 'm5/internal/%s.py' % m for m in swig_modules ]
+env.Command('m5/internal/__init__.py', swig_py_files, MakeInternalsInit)
+pyzip_dep_files.append('m5/internal/__init__.py')
+
+def MakeSwigInit(target, source, env):
+ f = file(str(target[0]), 'w')
+ print >>f, 'extern "C" {'
+ for m in swig_modules:
+ print >>f, ' void init_%s();' % m
+ print >>f, '}'
+ print >>f, 'void init_swig() {'
+ for m in swig_modules:
+ print >>f, ' init_%s();' % m
+ print >>f, '}'
+ f.close()
+
+swig_cc_files = [ 'swig/%s_wrap.cc' % m for m in swig_modules ]
+env.Command('swig/init.cc', swig_cc_files, MakeSwigInit)
+
# Action function to build the zip archive. Uses the PyZipFile module
# included in the standard Python library.
def buildPyZip(target, source, env):