diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/engine/SCons/Tool/aixc++.py | 26 | ||||
-rw-r--r-- | src/engine/SCons/Tool/sunc++.py | 26 | ||||
-rw-r--r-- | src/script/scons.bat | 2 | ||||
-rw-r--r-- | src/test_copyrights.py | 122 | ||||
-rw-r--r-- | src/test_setup.py (renamed from src/setupTests.py) | 3 |
5 files changed, 177 insertions, 2 deletions
diff --git a/src/engine/SCons/Tool/aixc++.py b/src/engine/SCons/Tool/aixc++.py index 5cb6639..dcc444a 100644 --- a/src/engine/SCons/Tool/aixc++.py +++ b/src/engine/SCons/Tool/aixc++.py @@ -7,7 +7,31 @@ It will usually be imported through the generic SCons.Tool.Tool() selection method. """ -__revision__ = "" + +# +# __COPYRIGHT__ +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" import os.path diff --git a/src/engine/SCons/Tool/sunc++.py b/src/engine/SCons/Tool/sunc++.py index 673949b..22d01db 100644 --- a/src/engine/SCons/Tool/sunc++.py +++ b/src/engine/SCons/Tool/sunc++.py @@ -7,7 +7,31 @@ It will usually be imported through the generic SCons.Tool.Tool() selection method. """ -__revision__ = "" + +# +# __COPYRIGHT__ +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" import os.path diff --git a/src/script/scons.bat b/src/script/scons.bat index 782d8c4..5cbfc2c 100644 --- a/src/script/scons.bat +++ b/src/script/scons.bat @@ -1,3 +1,5 @@ +REM __COPYRIGHT__ +REM __FILE__ __REVISION__ __DATE__ __DEVELOPER__ @echo off if "%OS%" == "Windows_NT" goto WinNT REM for 9x/Me you better not have more than 9 args diff --git a/src/test_copyrights.py b/src/test_copyrights.py new file mode 100644 index 0000000..f239f4d --- /dev/null +++ b/src/test_copyrights.py @@ -0,0 +1,122 @@ +#!/usr/bin/env python +# +# __COPYRIGHT__ +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" + +""" +Verify that we have proper Copyright notices on all the right files +in our distributions. + +Note that this is a packaging test, not a functional test, so the +name of this script doesn't end in *Tests.py. +""" + +import os +import os.path +import re +import string + +import TestSCons + +test = TestSCons.TestSCons() + +try: + cwd = os.environ['SCONS_CWD'] +except KeyError: + cwd = os.getcwd() + +class Collect: + expression = re.compile('Copyright.*The SCons Foundation') + def __init__(self, remove_list): + self.copyright = [] + self.no_copyright = [] + self.remove_list = remove_list + +def visit(collect, dirname, names): + for r in collect.remove_list: + try: + names.remove(r) + except ValueError: + pass + for name in map(lambda n, d=dirname: os.path.join(d, n), names): + if not os.path.isfile(name): + continue + if collect.expression.search(open(name, 'r').read()): + collect.copyright.append(name) + else: + collect.no_copyright.append(name) + +remove_list = [ + 'build', + 'debian', + 'dist', + 'Optik', + 'dblite.py', + 'Conftest.py', + 'os_spawnv_fix.diff', + 'setup.cfg', +] + +# XXX Remove '*-stamp' when we get rid of those. +scons = Collect(remove_list + ['MANIFEST', 'build-stamp', 'configure-stamp']) +# XXX Remove '.sconsign' when we start using SConsignFile() for SCons builds. +local = Collect(remove_list + ['.sconsign']) +# XXX Remove 'doc' when we take care of those Copyright statements. +src = Collect(remove_list + ['bin', 'doc', 'etc', 'gentoo', 'config', 'MANIFEST.in']) + +build_scons = os.path.join(cwd, 'build', 'scons') +build_local = os.path.join(cwd, 'build', 'scons-local') +build_src = os.path.join(cwd, 'build', 'scons-src') + +no_result = [] + +if os.path.exists(build_scons): + os.path.walk(build_scons, visit, scons) +else: + no_result.append(build_scons) + +if os.path.exists(build_local): + os.path.walk(build_local, visit, local) +else: + no_result.append(build_local) + +if os.path.exists(build_src): + os.path.walk(build_src, visit, src) +else: + no_result.append(build_src) + +no_copyright = scons.no_copyright + local.no_copyright + src.no_copyright + +if no_copyright: + print "Found the following files with no copyrights:" + print "\t" + string.join(no_copyright, "\n\t") + test.fail_test(1) + +if no_result: + print "Cannot check copyrights, the following have apparently not been built:" + print "\t" + string.join(no_result, "\n\t") + test.no_result(1) + +# All done. +test.pass_test() diff --git a/src/setupTests.py b/src/test_setup.py index 06688af..799be78 100644 --- a/src/setupTests.py +++ b/src/test_setup.py @@ -26,6 +26,9 @@ __revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" """ Test how the setup.py script installs SCons (specifically, its libraries). + +Note that this is an installation test, not a functional test, so the +name of this script doesn't end in *Tests.py. """ import os |