Support autoninja -o/--offline to disable goma
It is sometimes helpful to do a full build of Chrome using goma while
online and then do incremental builds without goma while offline or with
poor network bandwidth. Turning off goma in gn args triggers a full
rebuild but the GOMA_DISABLED environment variable can be used to
disable goma without triggering a rebuild.
In order to make this feature easier to discover and use this change
adds support for -o/--offline to autoninja. autoninja -h will mention
this flag and autoninja.bat/autoninja.py handle it appropriately. This
means setting the environment variable in autoninja.bat, and using it
to adjust the -j value and stripping it out in autoninja.py.
The bash script that wraps autoninja.py on Linux and OSX did not need
updating because the Python script can emit 'GOMA_DISABLED=1 ninja ...'
and this is executed by bash.
This was produced during pair programming with jessemckenna@
Bug: b/172039612
Change-Id: Ifcfbc598ac20f23e5fe013e02979b5b8c2851b01
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/tools/depot_tools/+/2510818
Auto-Submit: Bruce Dawson <brucedawson@chromium.org>
Commit-Queue: Dirk Pranke <dpranke@google.com>
Reviewed-by: Dirk Pranke <dpranke@google.com>
diff --git a/autoninja.bat b/autoninja.bat
index 8b5904c..5dee6de 100755
--- a/autoninja.bat
+++ b/autoninja.bat
@@ -14,19 +14,30 @@
REM Windows. The trailing space is intentional.
if "%NINJA_SUMMARIZE_BUILD%" == "1" set NINJA_STATUS=[%%r processes, %%f/%%t @ %%o/s : %%es ]
+set scriptdir=%~dp0
+
+:loop
+IF NOT "%1"=="" (
+ @rem Tell goma to not do network compiles.
+ IF "%1"=="--offline" SET GOMA_DISABLED=1
+ IF "%1"=="-o" SET GOMA_DISABLED=1
+ SHIFT
+ GOTO :loop
+)
+
REM Execute whatever is printed by autoninja.py.
REM Also print it to reassure that the right settings are being used.
-FOR /f "usebackq tokens=*" %%a in (`vpython %~dp0autoninja.py "%*"`) do echo %%a & %%a
+FOR /f "usebackq tokens=*" %%a in (`vpython %scriptdir%autoninja.py "%*"`) do echo %%a & %%a
@if errorlevel 1 goto buildfailure
REM Use call to invoke vpython script here, because we use vpython via vpython.bat.
-@if "%NINJA_SUMMARIZE_BUILD%" == "1" call vpython.bat %~dp0post_build_ninja_summary.py %*
-@call vpython.bat %~dp0ninjalog_uploader_wrapper.py --cmdline %*
+@if "%NINJA_SUMMARIZE_BUILD%" == "1" call vpython.bat %scriptdir%post_build_ninja_summary.py %*
+@call vpython.bat %scriptdir%ninjalog_uploader_wrapper.py --cmdline %*
exit /b
:buildfailure
-@call vpython.bat %~dp0ninjalog_uploader_wrapper.py --cmdline %*
+@call vpython.bat %scriptdir%ninjalog_uploader_wrapper.py --cmdline %*
REM Return an error code of 1 so that if a developer types:
REM "autoninja chrome && chrome" then chrome won't run if the build fails.
diff --git a/autoninja.py b/autoninja.py
index 020acc5..a0f4996 100755
--- a/autoninja.py
+++ b/autoninja.py
@@ -30,6 +30,7 @@
# The -t tools are incompatible with -j
t_specified = False
j_specified = False
+offline = False
output_dir = '.'
input_args = sys.argv
# On Windows the autoninja.bat script passes along the arguments enclosed in
@@ -56,6 +57,15 @@
elif arg.startswith('-C'):
# Support -Cout/Default
output_dir = arg[2:]
+ elif arg == '-o' or arg == '--offline':
+ offline = True
+ elif arg == '-h':
+ print('autoninja: Use -o/--offline to temporary disable goma.',
+ file=sys.stderr)
+ print(file=sys.stderr)
+
+# Strip -o/--offline so ninja doesn't see them.
+input_args = [ arg for arg in input_args if arg != '-o' and arg != '--offline']
use_remote_build = False
@@ -92,7 +102,7 @@
# for each compile step. Checking this environment variable ensures that
# autoninja uses an appropriate -j value in this situation.
goma_disabled_env = os.environ.get('GOMA_DISABLED', '0').lower()
-if goma_disabled_env in ['true', 't', 'yes', 'y', '1']:
+if offline or goma_disabled_env in ['true', 't', 'yes', 'y', '1']:
use_remote_build = False
# Specify ninja.exe on Windows so that ninja.bat can call autoninja and not
@@ -150,4 +160,10 @@
if os.environ.get('NINJA_SUMMARIZE_BUILD', '0') == '1':
args += ['-d', 'stats']
-print(' '.join(args))
+if offline and not sys.platform.startswith('win'):
+ # Tell goma to do local compiles. On Windows this environment variable is set
+ # by the wrapper batch file.
+ print('GOMA_DISABLED=1 ' + ' '.join(args))
+else:
+ print(' '.join(args))
+