summaryrefslogtreecommitdiffstats
path: root/SConstruct
diff options
context:
space:
mode:
authorSteven Knight <knight@baldmt.com>2007-02-11 05:02:05 (GMT)
committerSteven Knight <knight@baldmt.com>2007-02-11 05:02:05 (GMT)
commit895bf33464c921fecdee7ac5e770ce1009bd2c57 (patch)
tree107c065697f6b6bb61356d82f4876df7f0eb378c /SConstruct
parent79248be790aa3e46ee7b0a2dc080f211dcca9aa7 (diff)
downloadSCons-895bf33464c921fecdee7ac5e770ce1009bd2c57.zip
SCons-895bf33464c921fecdee7ac5e770ce1009bd2c57.tar.gz
SCons-895bf33464c921fecdee7ac5e770ce1009bd2c57.tar.bz2
Merged revisions 1784-1824 via svnmerge from
http://scons.tigris.org/svn/scons/branches/core ........ r1786 | stevenknight | 2007-01-25 15:29:15 -0600 (Thu, 25 Jan 2007) | 1 line 0.96.D555 - Doc string updates for TaskMaster to better describe the architecture. Get rid of some no-longer-used code. ........ r1787 | stevenknight | 2007-01-25 23:24:31 -0600 (Thu, 25 Jan 2007) | 1 line 0.96.D556 - Packaging changes to support building packages in an arbitrary directory. ........ r1788 | stevenknight | 2007-01-30 20:35:39 -0600 (Tue, 30 Jan 2007) | 1 line 0.96.D557 - Make the Scanner.Base class able to handle Scanner.Selector functionality (i.e., a dictionary to select other scanners) and prepare to deprecate Scanner.Selector and Scanner.Scanner() in the future. ........ r1789 | stevenknight | 2007-01-30 20:45:23 -0600 (Tue, 30 Jan 2007) | 1 line 0.96.D558 - Add support for a site-scons subdirectory. (Gary Oberbrunner) ........ r1790 | stevenknight | 2007-01-31 00:36:20 -0600 (Wed, 31 Jan 2007) | 1 line 0.96.D559 - Clean up various module imports and other pychecker-detected problems. ........ r1791 | stevenknight | 2007-01-31 11:51:04 -0600 (Wed, 31 Jan 2007) | 1 line 0.96.D560 - Fix detection of Java anonymous classes if a newline precedes the opening brace. (Leanid Nazdrynau) ........ r1792 | stevenknight | 2007-02-02 11:57:59 -0600 (Fri, 02 Feb 2007) | 1 line 0.96.D561 - Add a --bootstrap_src option to bootstrap.py; search the bootstrap.py directory by default. (Greg Noel) ........ r1793 | stevenknight | 2007-02-02 18:04:52 -0600 (Fri, 02 Feb 2007) | 1 line 0.96.D562 - Don't check the build/*/gentoo directories for copyright strings. ........ r1794 | stevenknight | 2007-02-02 18:12:43 -0600 (Fri, 02 Feb 2007) | 1 line 0.96.D563 - Fix pychecker clean-ups on later Python versions. ........ r1795 | stevenknight | 2007-02-02 18:38:47 -0600 (Fri, 02 Feb 2007) | 1 line 0.96.D564 - Add a NoCache() function to allow marking targets as not being suitable for propagating/ to (or retrieving from) CacheDir(). (Dave Vitek) ........ r1796 | stevenknight | 2007-02-02 20:08:33 -0600 (Fri, 02 Feb 2007) | 1 line 0.96.D565 - Add a --tree= option, to make the interface to dumping dependency graphs a little clearner, and give it a 'prune' option to avoid repeating the dependency walk for Nodes we've already visited. ........ r1797 | stevenknight | 2007-02-03 20:37:25 -0600 (Sat, 03 Feb 2007) | 1 line 0.96.D566 - Packaging fix: don't add '#' to the beginning of a build_dir name if it's already an absolute path. ........ r1798 | stevenknight | 2007-02-03 20:53:42 -0600 (Sat, 03 Feb 2007) | 1 line 0.96.D567 - Add backwards-compatibility for set() types, and restore the line that used them in the compatibility _subprocess.py module. ........ r1799 | stevenknight | 2007-02-05 10:30:28 -0600 (Mon, 05 Feb 2007) | 1 line 0.96.D568 - Capture outline and build configuration for a possible future Developer's Guide. ........ r1800 | stevenknight | 2007-02-05 11:03:37 -0600 (Mon, 05 Feb 2007) | 1 line 0.96.D569 - Exclude the new developer guide MANIFEST from Copyright string checks. ........ r1801 | stevenknight | 2007-02-05 11:16:04 -0600 (Mon, 05 Feb 2007) | 1 line 0.96.D570 - Track fix in upstream subprocess.py. (Ralf W. Grosse-Kunstleve) ........ r1802 | stevenknight | 2007-02-05 20:05:59 -0600 (Mon, 05 Feb 2007) | 1 line 0.96.D571 - Change the Windows installer to register scons.bat as an 'App Path', so the directory doesn't need to be added to %PATH%. ........ r1803 | stevenknight | 2007-02-05 21:33:01 -0600 (Mon, 05 Feb 2007) | 1 line 0.96.D572 - Prepare SConf for use with the subprocess module by refactoring the Unbuffered class. ........ r1804 | stevenknight | 2007-02-05 22:37:09 -0600 (Mon, 05 Feb 2007) | 1 line 0.96.D573 - Get rid of left-over Node.Node.{pre,post}_actions attributes. ........ r1805 | stevenknight | 2007-02-06 12:04:14 -0600 (Tue, 06 Feb 2007) | 1 line 0.96.D574 - Remove leftover print in the test/CacheDir/NoCache.py test. ........ r1806 | stevenknight | 2007-02-06 17:11:03 -0600 (Tue, 06 Feb 2007) | 1 line 0.96.D575 - Support the ability to evaluate a ${} construction variable to select the spawner function. ........ r1809 | stevenknight | 2007-02-07 00:30:10 -0600 (Wed, 07 Feb 2007) | 1 line 0.96.D576 - Documentation fixes and updates. ........ r1810 | stevenknight | 2007-02-07 15:51:20 -0600 (Wed, 07 Feb 2007) | 1 line 0.96.D577 - Don't expect a bootstrap.py runtest.py file to be generated when swig -noproxy is used. ........ r1811 | stevenknight | 2007-02-07 16:55:06 -0600 (Wed, 07 Feb 2007) | 1 line 0.96.D578 - Make --srcdir a synonym for -Y/--repository. ........ r1812 | stevenknight | 2007-02-07 23:46:22 -0600 (Wed, 07 Feb 2007) | 1 line 0.96.D579 - More doc updates: PathAccept, #include+Repository double-quote limitation. ........ r1817 | stevenknight | 2007-02-08 12:46:42 -0600 (Thu, 08 Feb 2007) | 1 line 0.96.D580 - Fix use of toolpath with BuildDir. ........ r1818 | stevenknight | 2007-02-08 12:59:23 -0600 (Thu, 08 Feb 2007) | 1 line 0.96.D581 - Enable build of the text version of the User's Guide. ........ r1819 | stevenknight | 2007-02-08 14:21:31 -0600 (Thu, 08 Feb 2007) | 1 line 0.96.D582 - Fix handling of Java inner classes with JARCHDIR. ........ r1820 | stevenknight | 2007-02-08 14:39:33 -0600 (Thu, 08 Feb 2007) | 1 line 0.96.D583 - Add linking with -lm to the dmd.py Tool smart linker. (Anonymous) ........ r1821 | stevenknight | 2007-02-08 17:26:29 -0600 (Thu, 08 Feb 2007) | 1 line 0.96.D584 - Fix ParseConfig() when *FLAGS variables have been replaced with strings. ........ r1822 | stevenknight | 2007-02-09 12:21:17 -0600 (Fri, 09 Feb 2007) | 1 line 0.96.D585 - Fix installation of file names beginning with #. (Dave Weber) ........ r1823 | stevenknight | 2007-02-09 14:14:47 -0600 (Fri, 09 Feb 2007) | 1 line 0.96.D586 - Post-review improvements to recent toolpath and MergeFlags() changes. (Gary Oberbrunner, Greg Noel) ........ r1824 | stevenknight | 2007-02-10 00:53:13 -0600 (Sat, 10 Feb 2007) | 1 line 0.96.D587 - Commonize flags initialization between the c and c++ Tools. ........
Diffstat (limited to 'SConstruct')
-rw-r--r--SConstruct99
1 files changed, 53 insertions, 46 deletions
diff --git a/SConstruct b/SConstruct
index 374cef0..76ec535 100644
--- a/SConstruct
+++ b/SConstruct
@@ -48,8 +48,6 @@ project = 'scons'
default_version = '0.96.94'
copyright = "Copyright (c) %s The SCons Foundation" % copyright_years
-Default('.')
-
SConsignFile()
#
@@ -155,7 +153,11 @@ for key in ['AEGIS_PROJECT', 'LOGNAME', 'PYTHONPATH']:
if os.environ.has_key(key):
ENV[key] = os.environ[key]
-cwd_build = os.path.join(os.getcwd(), "build")
+build_dir = ARGUMENTS.get('BUILDDIR', 'build')
+if not os.path.isabs(build_dir):
+ build_dir = os.path.normpath(os.path.join(os.getcwd(), build_dir))
+
+Default('.', build_dir)
packaging_flavors = [
'deb',
@@ -168,17 +170,17 @@ packaging_flavors = [
'local-zip',
]
-test_deb_dir = os.path.join(cwd_build, "test-deb")
-test_rpm_dir = os.path.join(cwd_build, "test-rpm")
-test_tar_gz_dir = os.path.join(cwd_build, "test-tar-gz")
-test_src_tar_gz_dir = os.path.join(cwd_build, "test-src-tar-gz")
-test_local_tar_gz_dir = os.path.join(cwd_build, "test-local-tar-gz")
-test_zip_dir = os.path.join(cwd_build, "test-zip")
-test_src_zip_dir = os.path.join(cwd_build, "test-src-zip")
-test_local_zip_dir = os.path.join(cwd_build, "test-local-zip")
+test_deb_dir = os.path.join(build_dir, "test-deb")
+test_rpm_dir = os.path.join(build_dir, "test-rpm")
+test_tar_gz_dir = os.path.join(build_dir, "test-tar-gz")
+test_src_tar_gz_dir = os.path.join(build_dir, "test-src-tar-gz")
+test_local_tar_gz_dir = os.path.join(build_dir, "test-local-tar-gz")
+test_zip_dir = os.path.join(build_dir, "test-zip")
+test_src_zip_dir = os.path.join(build_dir, "test-src-zip")
+test_local_zip_dir = os.path.join(build_dir, "test-local-zip")
-unpack_tar_gz_dir = os.path.join(cwd_build, "unpack-tar-gz")
-unpack_zip_dir = os.path.join(cwd_build, "unpack-zip")
+unpack_tar_gz_dir = os.path.join(build_dir, "unpack-tar-gz")
+unpack_zip_dir = os.path.join(build_dir, "unpack-zip")
if platform == "win32":
tar_hflag = ''
@@ -305,6 +307,7 @@ env = Environment(
ENV = ENV,
BUILD = build_id,
+ BUILDDIR = build_dir,
BUILDSYS = build_system,
COPYRIGHT = copyright,
DATE = date,
@@ -501,14 +504,15 @@ scons = {
'sconsign.1',
'scons-time.1',
'script/scons.bat',
+ 'script/scons-post-install.py',
'setup.cfg',
'setup.py',
],
'filemap' : {
- 'scons.1' : '../build/doc/man/scons.1',
- 'sconsign.1' : '../build/doc/man/sconsign.1',
- 'scons-time.1' : '../build/doc/man/scons-time.1',
+ 'scons.1' : '$BUILDDIR/doc/man/scons.1',
+ 'sconsign.1' : '$BUILDDIR/doc/man/sconsign.1',
+ 'scons-time.1' : '$BUILDDIR/doc/man/scons-time.1',
},
'buildermap' : {
@@ -525,7 +529,7 @@ scons = {
},
}
-scripts = ['scons', 'sconsign']
+scripts = ['scons', 'sconsign', 'scons-time']
src_deps = []
src_files = []
@@ -541,7 +545,7 @@ for p in [ scons ]:
if p.has_key('src_subdir'):
src = os.path.join(src, p['src_subdir'])
- build = os.path.join('build', pkg)
+ build = os.path.join(build_dir, pkg)
tar_gz = os.path.join(build, 'dist', "%s.tar.gz" % pkg_version)
platform_tar_gz = os.path.join(build,
@@ -629,8 +633,10 @@ for p in [ scons ]:
#
for b in src_files:
s = p['filemap'].get(b, b)
+ if not s[0] == '$' and not os.path.isabs(s):
+ s = os.path.join(src, s)
builder = p['buildermap'].get(b, env.SCons_revision)
- x = builder(os.path.join(build, b), os.path.join(src, s))
+ x = builder(os.path.join(build, b), s)
Local(x)
#
@@ -720,7 +726,7 @@ for p in [ scons ]:
#
# Generate portage files for submission to Gentoo Linux.
#
- gentoo = os.path.join('build', 'gentoo')
+ gentoo = os.path.join(build, 'gentoo')
ebuild = os.path.join(gentoo, 'scons-%s.ebuild' % version)
digest = os.path.join(gentoo, 'files', 'digest-scons-%s' % version)
env.Command(ebuild, os.path.join('gentoo', 'scons.ebuild.in'), SCons_revision)
@@ -791,10 +797,10 @@ for p in [ scons ]:
])
if rpmbuild:
- topdir = os.path.join(os.getcwd(), build, 'build',
+ topdir = os.path.join(build, 'build',
'bdist.' + platform, 'rpm')
- buildroot = os.path.join(os.getcwd(), 'build', 'rpm-buildroot')
+ buildroot = os.path.join(build_dir, 'rpm-buildroot')
BUILDdir = os.path.join(topdir, 'BUILD', pkg + '-' + version)
RPMSdir = os.path.join(topdir, 'RPMS', 'noarch')
@@ -846,7 +852,7 @@ for p in [ scons ]:
if dh_builddeb and fakeroot:
# Our Debian packaging builds directly into build/dist,
# so we don't need to add the .debs to install_targets.
- deb = os.path.join('build', 'dist', "%s_%s-1_all.deb" % (pkg, version))
+ deb = os.path.join(build_dir, 'dist', "%s_%s-1_all.deb" % (pkg, version))
for d in p['debian_deps']:
b = env.SCons_revision(os.path.join(build, d), d)
env.Depends(deb, b)
@@ -898,38 +904,38 @@ for p in [ scons ]:
#
s_l_v = '%s-local-%s' % (pkg, version)
- local = os.path.join('build', pkg + '-local')
- cwd_local = os.path.join(os.getcwd(), local)
- cwd_local_slv = os.path.join(os.getcwd(), local, s_l_v)
+ local = pkg + '-local'
+ build_dir_local = os.path.join(build_dir, local)
+ build_dir_local_slv = os.path.join(build_dir, local, s_l_v)
- local_tar_gz = os.path.join('build', 'dist', "%s.tar.gz" % s_l_v)
- local_zip = os.path.join('build', 'dist', "%s.zip" % s_l_v)
+ local_tar_gz = os.path.join(build_dir, 'dist', "%s.tar.gz" % s_l_v)
+ local_zip = os.path.join(build_dir, 'dist', "%s.zip" % s_l_v)
commands = [
- Delete(local),
+ Delete(build_dir_local),
'$PYTHON $PYTHONFLAGS $SETUP_PY install "--install-script=%s" "--install-lib=%s" --no-install-man --no-compile --standalone-lib --no-version-script' % \
- (cwd_local, cwd_local_slv),
+ (build_dir_local, build_dir_local_slv),
]
for script in scripts:
#commands.append("mv %s/%s %s/%s.py" % (local, script, local, script))
- local_script = os.path.join(local, script)
+ local_script = os.path.join(build_dir_local, script)
commands.append(Move(local_script + '.py', local_script))
rf = filter(lambda x: not x in scripts, raw_files)
rf = map(lambda x, slv=s_l_v: os.path.join(slv, x), rf)
for script in scripts:
rf.append("%s.py" % script)
- local_targets = map(lambda x, s=local: os.path.join(s, x), rf)
+ local_targets = map(lambda x, s=build_dir_local: os.path.join(s, x), rf)
env.Command(local_targets, build_src_files, commands)
- scons_LICENSE = os.path.join(local, 'scons-LICENSE')
+ scons_LICENSE = os.path.join(build_dir_local, 'scons-LICENSE')
l = env.SCons_revision(scons_LICENSE, 'LICENSE-local')
local_targets.append(l)
Local(l)
- scons_README = os.path.join(local, 'scons-README')
+ scons_README = os.path.join(build_dir_local, 'scons-README')
l = env.SCons_revision(scons_README, 'README-local')
local_targets.append(l)
Local(l)
@@ -937,7 +943,7 @@ for p in [ scons ]:
if gzip:
env.Command(local_tar_gz,
local_targets,
- "cd %s && tar czf $( ${TARGET.abspath} $) *" % local)
+ "cd %s && tar czf $( ${TARGET.abspath} $) *" % build_dir_local)
unpack_targets = map(lambda x, d=test_local_tar_gz_dir:
os.path.join(d, x),
@@ -950,7 +956,7 @@ for p in [ scons ]:
if zipit:
env.Command(local_zip, local_targets, zipit,
- CD = local, PSV = '.')
+ CD = build_dir_local, PSV = '.')
unpack_targets = map(lambda x, d=test_local_zip_dir:
os.path.join(d, x),
@@ -966,13 +972,13 @@ for p in [ scons ]:
# And, lastly, install the appropriate packages in the
# appropriate subdirectory.
#
- b_d_files = env.Install(os.path.join('build', 'dist'), install_targets)
+ b_d_files = env.Install(os.path.join(build_dir, 'dist'), install_targets)
Local(b_d_files)
#
#
#
-Export('env')
+Export('build_dir', 'env')
SConscript('QMTest/SConscript')
@@ -992,17 +998,18 @@ for file in files:
# Guarantee that real copies of these files always exist in
# build/. If there's a symlink there, then this is an Aegis
# build and we blow them away now so that they'll get "built" later.
- p = os.path.join('build', file)
+ p = os.path.join(build_dir, file)
if os.path.islink(p):
os.unlink(p)
- sp = '#' + p
- env.Command(sp, file, copy)
+ if not os.path.isabs(p):
+ p = '#' + p
+ sp = env.Command(p, file, copy)
Local(sp)
#
# Documentation.
#
-Export('env', 'whereis')
+Export('build_dir', 'env', 'whereis')
SConscript('doc/SConscript')
@@ -1040,12 +1047,12 @@ if change:
if sfiles:
ps = "%s-src" % project
psv = "%s-%s" % (ps, version)
- b_ps = os.path.join('build', ps)
- b_psv = os.path.join('build', psv)
+ b_ps = os.path.join(build_dir, ps)
+ b_psv = os.path.join(build_dir, psv)
b_psv_stamp = b_psv + '-stamp'
- src_tar_gz = os.path.join('build', 'dist', '%s.tar.gz' % psv)
- src_zip = os.path.join('build', 'dist', '%s.zip' % psv)
+ src_tar_gz = os.path.join(build_dir, 'dist', '%s.tar.gz' % psv)
+ src_zip = os.path.join(build_dir, 'dist', '%s.zip' % psv)
Local(src_tar_gz, src_zip)