diff --git a/mach b/mach index 9c39e5bffb558..c077d099c0438 100755 --- a/mach +++ b/mach @@ -45,4 +45,4 @@ except ImportError: # All of the code is in a module because EVERYTHING IS A LIBRARY. mach = mach.main.Mach(our_dir) -mach.run(sys.argv[1:]) +sys.exit(mach.run(sys.argv[1:])) diff --git a/python/mach/mach/main.py b/python/mach/mach/main.py index 2e947da2d926d..fc8a49f784ff9 100644 --- a/python/mach/mach/main.py +++ b/python/mach/mach/main.py @@ -122,7 +122,11 @@ def __init__(self, cwd): self.log_manager.register_structured_logger(self.logger) def run(self, argv): - """Runs mach with arguments provided from the command line.""" + """Runs mach with arguments provided from the command line. + + Returns the integer exit code that should be used. 0 means success. All + other values indicate failure. + """ # If no encoding is defined, we default to UTF-8 because without this # Python 2.7 will assume the default encoding of ASCII. This will blow @@ -143,7 +147,7 @@ def run(self, argv): if sys.stderr.encoding is None: sys.stderr = codecs.getwriter('utf-8')(sys.stderr) - self._run(argv) + return self._run(argv) finally: sys.stdin = orig_stdin sys.stdout = orig_stdout @@ -199,7 +203,14 @@ def _run(self, argv): else: raise Exception('Dispatch configuration error in module.') - fn(**stripped) + result = fn(**stripped) + + if not result: + result = 0 + + assert isinstance(result, int) + + return result def log(self, level, action, params, format_str): """Helper method to record a structured log event."""