diff options
author | Alexander Bokovoy <ab@samba.org> | 2012-04-03 11:22:15 +0300 |
---|---|---|
committer | Andreas Schneider <asn@samba.org> | 2012-04-12 12:06:43 +0200 |
commit | dda0531aae70e78e815fda8c594213369e76a847 (patch) | |
tree | 00922abc42fe8446c3cefe3e9fa1fda20fbd0e74 /buildtools/wafadmin | |
parent | 1f1e4275b5fafbad1b5719f5efba7ee66f6d3037 (diff) | |
download | samba-dda0531aae70e78e815fda8c594213369e76a847.tar.gz samba-dda0531aae70e78e815fda8c594213369e76a847.tar.bz2 samba-dda0531aae70e78e815fda8c594213369e76a847.zip |
WAF: Add support for stopping processing before end of wscript{_*}
WAF scripts are written in Python and Python has no simple way
to stop program execution other than using exceptions.
This change adds WscriptCheckSkipped exception and its handling in
core WAF code. When any of wscript{_*} throws WscriptCheckSkipped
exception, WAF simply continues to process next wscript in queue
rather than breaking build.
WscriptCheckSkipped exception can be used to perform early bail out
of configuration/build target checks if certain dependency is not available
when the default checks are way more numerous than a check for this
particular dependency. This is to avoid 'if ...' indenting for large
blocks of existing code which also muddens git history for nothing.
Signed-off-by: Andreas Schneider <asn@samba.org>
Diffstat (limited to 'buildtools/wafadmin')
-rw-r--r-- | buildtools/wafadmin/Utils.py | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/buildtools/wafadmin/Utils.py b/buildtools/wafadmin/Utils.py index 41dad570eb..080d928214 100644 --- a/buildtools/wafadmin/Utils.py +++ b/buildtools/wafadmin/Utils.py @@ -111,6 +111,9 @@ class WscriptError(WafError): return (frame[0], frame[1]) return (None, None) +class WscriptCheckSkipped(WscriptError): + pass + indicator = is_win32 and '\x1b[A\x1b[K%s%s%s\r' or '\x1b[K%s%s%s\r' try: @@ -645,6 +648,8 @@ class Context(object): try: try: exec(compile(txt, file_path, 'exec'), dc) + except WscriptCheckSkipped: + pass except Exception: exc_type, exc_value, tb = sys.exc_info() raise WscriptError("".join(traceback.format_exception(exc_type, exc_value, tb)), base) |