diff options
author | Steven Knight <knight@baldmt.com> | 2005-06-01 12:13:56 (GMT) |
---|---|---|
committer | Steven Knight <knight@baldmt.com> | 2005-06-01 12:13:56 (GMT) |
commit | 1d3c36ee983d5f26bbd9cf9733a8084eced1b2c4 (patch) | |
tree | 861f489ee66c3c257dbe27b7f8838b78b8ee1bc0 /src/engine/SCons/Script | |
parent | e21fab68f13999f4e0051ce75977f9c395940b6f (diff) | |
download | SCons-1d3c36ee983d5f26bbd9cf9733a8084eced1b2c4.zip SCons-1d3c36ee983d5f26bbd9cf9733a8084eced1b2c4.tar.gz SCons-1d3c36ee983d5f26bbd9cf9733a8084eced1b2c4.tar.bz2 |
Add a --debug=nomemoizer option to disable memoization.
Diffstat (limited to 'src/engine/SCons/Script')
-rw-r--r-- | src/engine/SCons/Script/Main.py | 3 | ||||
-rw-r--r-- | src/engine/SCons/Script/__init__.py | 30 |
2 files changed, 21 insertions, 12 deletions
diff --git a/src/engine/SCons/Script/Main.py b/src/engine/SCons/Script/Main.py index 7dcb987..73f6a6c 100644 --- a/src/engine/SCons/Script/Main.py +++ b/src/engine/SCons/Script/Main.py @@ -592,7 +592,8 @@ class OptParser(OptionParser): "build all Default() targets.") debug_options = ["count", "dtree", "explain", "findlibs", - "includes", "memoizer", "memory", "objects", + "includes", "memoizer", "memory", + "nomemoizer", "objects", "pdb", "presub", "stacktrace", "stree", "time", "tree"] diff --git a/src/engine/SCons/Script/__init__.py b/src/engine/SCons/Script/__init__.py index 4327ac2..734ce3f 100644 --- a/src/engine/SCons/Script/__init__.py +++ b/src/engine/SCons/Script/__init__.py @@ -44,22 +44,30 @@ import string import sys import UserList -# Special chicken-and-egg handling of the "--debug=memoizer" flags: +# Special chicken-and-egg handling of the "--debug=memoizer" +# and "--debug=nomemoizer" flags: +# # SCons.Memoize contains a metaclass implementation that affects how # the other classes are instantiated. The Memoizer handles optional # counting of the hits and misses by using a different, parallel set of # functions, so we don't slow down normal operation any more than we -# have to. But if we wait to enable the counting until we've parsed -# the command line options normally, it will be too late, because the -# Memoizer will have already analyzed the classes that it's Memoizing -# and bound the non-counting versions of the functions. So we have to -# use a special-case, up-front check for the "--debug=memoizer" flag -# and turn on Memoizer counting, if desired, before we import any of -# the other modules that use it. -sconsflags = string.split(os.environ.get('SCONSFLAGS', '')) -if "--debug=memoizer" in sys.argv + sconsflags: +# have to. We can also tell it disable memoization completely. +# +# If we wait to enable the counting or disable memoization completely +# until we've parsed the command line options normally, it will be too +# late, because the Memoizer will have already analyzed the classes +# that it's Memoizing and bound the (non-counting) versions of the +# functions. So we have to use a special-case, up-front check for +# the "--debug=memoizer" and "--debug=nomemoizer" flags and do what's +# appropriate before we import any of the other modules that use it. +_args = sys.argv + string.split(os.environ.get('SCONSFLAGS', '')) +if "--debug=memoizer" in _args: import SCons.Memoize SCons.Memoize.EnableCounting() +if "--debug=nomemoizer" in _args: + import SCons.Memoize + SCons.Memoize.DisableMemoization() +del _args import SCons.Action import SCons.Builder @@ -315,7 +323,7 @@ for name in GlobalDefaultEnvironmentFunctions + GlobalDefaultBuilders: # "SConscript" in this namespace is no longer a module, it's a global # function call--or more precisely, an object that implements a global # function call through the default Environment. Nevertheless, we can -# aintain backwards compatibility for SConscripts that were reaching in +# maintain backwards compatibility for SConscripts that were reaching in # this way by hanging some attributes off the "SConscript" object here. SConscript = _SConscript.DefaultEnvironmentCall('SConscript') |