From 5d825b7a6891609dea4fc3a839c3437951d59541 Mon Sep 17 00:00:00 2001 From: Cole Faust Date: Wed, 26 Oct 2022 18:16:44 -0700 Subject: [PATCH] Speed up m command autocompletion Generate a all_modules.txt file on every build that can be used for autocompleting. Because this adds time to every non-incremental build, I profiled it by using `$(shell date +"%s.%3N")` before and after, and disovered it only adds about 0.01 seconds to the build. And of course it won't be rerun if there weren't build changes. Bug: 255867758 Test: Manually Change-Id: I1d3f1008611fd542884322b27b19ea2fa1d341fe --- core/tasks/module-info.mk | 6 ++++++ envsetup.sh | 10 ++++------ 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/core/tasks/module-info.mk b/core/tasks/module-info.mk index dbd1e847ea..e83d408577 100644 --- a/core/tasks/module-info.mk +++ b/core/tasks/module-info.mk @@ -41,3 +41,9 @@ droidcore-unbundled: $(MODULE_INFO_JSON) $(call dist-for-goals, general-tests, $(MODULE_INFO_JSON)) $(call dist-for-goals, droidcore-unbundled, $(MODULE_INFO_JSON)) + +# On every build, generate an all_modules.txt file to be used for autocompleting +# the m command. After timing this using $(shell date +"%s.%3N"), it only adds +# 0.01 seconds to the internal master build, and will only rerun on builds that +# rerun kati. +$(file >$(PRODUCT_OUT)/all_modules.txt,$(subst $(space),$(newline),$(ALL_MODULES))) diff --git a/envsetup.sh b/envsetup.sh index 3674a4a99e..4c1aeaac60 100644 --- a/envsetup.sh +++ b/envsetup.sh @@ -1551,12 +1551,10 @@ function verifymodinfo() { fi } -# List all modules for the current device, as cached in module-info.json. If any build change is -# made and it should be reflected in the output, you should run 'refreshmod' first. +# List all modules for the current device, as cached in all_modules.txt. If any build change is +# made and it should be reflected in the output, you should run `m nothing` first. function allmod() { - verifymodinfo || return 1 - - python3 -c "import json; print('\n'.join(sorted(json.load(open('$ANDROID_PRODUCT_OUT/module-info.json')).keys())))" + cat $ANDROID_PRODUCT_OUT/all_modules.txt 2>/dev/null } # Return the Bazel label of a Soong module if it is converted with bp2build. @@ -1735,7 +1733,7 @@ function installmod() { function _complete_android_module_names() { local word=${COMP_WORDS[COMP_CWORD]} - COMPREPLY=( $(QUIET_VERIFYMODINFO=true allmod | grep -E "^$word") ) + COMPREPLY=( $(allmod | grep -E "^$word") ) } # Print colored exit condition