diff options
author | RĂ©mi Verschelde <remi@verschelde.fr> | 2022-07-17 15:43:56 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-07-17 15:43:56 +0200 |
commit | 3ae61590e1ca3d4df078f4aa728856586e828bc2 (patch) | |
tree | 8c2b6b5bed2872ad1ee6c99571f69f4929b15413 /SConstruct | |
parent | 87ca6a67ffb490201a07dc2f4dc15e79f4f11e43 (diff) | |
parent | ea211225754ba3fc1c2afb290bf26bd714125b24 (diff) |
Merge pull request #63087 from akien-mga/scons-num_jobs-default-max
Diffstat (limited to 'SConstruct')
-rw-r--r-- | SConstruct | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/SConstruct b/SConstruct index 50cb43b218..0eba93e4ff 100644 --- a/SConstruct +++ b/SConstruct @@ -399,6 +399,24 @@ if selected_platform in platform_list: env = env_base.Clone() + # Default num_jobs to local cpu count if not user specified. + # SCons has a peculiarity where user-specified options won't be overridden + # by SetOption, so we can rely on this to know if we should use our default. + initial_num_jobs = env.GetOption("num_jobs") + altered_num_jobs = initial_num_jobs + 1 + env.SetOption("num_jobs", altered_num_jobs) + if env.GetOption("num_jobs") == altered_num_jobs: + cpu_count = os.cpu_count() + if cpu_count is None: + print("Couldn't auto-detect CPU count to configure build parallelism. Specify it with the -j argument.") + else: + safer_cpu_count = cpu_count if cpu_count <= 4 else cpu_count - 1 + print( + "Auto-detected %d CPU cores available for build parallelism. Using %d cores by default. You can override it with the -j argument." + % (cpu_count, safer_cpu_count) + ) + env.SetOption("num_jobs", safer_cpu_count) + if env["compiledb"]: # Generating the compilation DB (`compile_commands.json`) requires SCons 4.0.0 or later. from SCons import __version__ as scons_raw_version |