From 6cd4660ba8b714f9c4ae42409b98f86a24b1ce6d Mon Sep 17 00:00:00 2001 From: Sergio Date: Thu, 27 Jun 2024 14:22:48 +0200 Subject: [PATCH] Add speedup_options cache Checking which options are available is expensive, this way we only do it once (as the git available in path is not expected to change during execution) --- alibuild_helpers/git.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/alibuild_helpers/git.py b/alibuild_helpers/git.py index 5f12312e..3bd40ae2 100644 --- a/alibuild_helpers/git.py +++ b/alibuild_helpers/git.py @@ -13,12 +13,21 @@ } """Customised timeout for some commands.""" +# Don't recalculate this every time we need it. +_clone_speedup_cache = None def clone_speedup_options(): """Return a list of options supported by the system git which speed up cloning.""" - for filter_option in ("--filter=tree:0", "--filter=blob:none"): + valid_options = ("--filter=tree:0", "--filter=blob:none") + global _clone_speedup_cache + if _clone_speedup_cache is not None: + return _clone_speedup_cache + for filter_option in valid_options: _, out = getstatusoutput("LANG=C git clone " + filter_option) if "unknown option" not in out and "invalid filter-spec" not in out: + _clone_speedup_cache = [filter_option] return [filter_option] + debug("Git: no speedup_options filters supported. Tried using (%s)", ", ".join(valid_options)) + _clone_speedup_cache = [] return []