| // Copyright 2014 The Bazel Authors. All rights reserved. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| package com.google.devtools.build.lib.bazel; |
| |
| import com.google.common.collect.ImmutableList; |
| import com.google.common.collect.ImmutableMap; |
| import com.google.devtools.build.lib.analysis.BlazeVersionInfo; |
| import com.google.devtools.build.lib.authandtls.credentialhelper.CredentialModule; |
| import com.google.devtools.build.lib.runtime.BlazeModule; |
| import com.google.devtools.build.lib.runtime.BlazeRuntime; |
| import java.io.IOException; |
| import java.io.InputStream; |
| import java.util.Properties; |
| |
| /** |
| * The main class. |
| */ |
| public final class Bazel { |
| private static final String BUILD_DATA_PROPERTIES = "/build-data.properties"; |
| |
| /** |
| * The list of modules to load. Note that the order is important: In case multiple modules provide |
| * strategies for the same things, the last module wins and its strategy becomes the default. |
| * |
| * <p>Example: To make the "standalone" execution strategy the default for spawns, put it after |
| * all the other modules that provider spawn strategies (e.g. WorkerModule and SandboxModule). |
| */ |
| @SuppressWarnings("UnnecessarilyFullyQualified") // Class names fully qualified for clarity. |
| public static final ImmutableList<Class<? extends BlazeModule>> BAZEL_MODULES = |
| ImmutableList.of( |
| BazelStartupOptionsModule.class, |
| // This module is registered early so that profiles are as complete as possible. |
| com.google.devtools.build.lib.profiler.CommandProfilerModule.class, |
| // This module needs to be registered before any module providing a SpawnCache |
| // implementation. |
| com.google.devtools.build.lib.runtime.NoSpawnCacheModule.class, |
| // This module needs to be registered before any module that uses the credential cache. |
| CredentialModule.class, |
| com.google.devtools.build.lib.runtime.CommandLogModule.class, |
| com.google.devtools.build.lib.runtime.MemoryPressureModule.class, |
| com.google.devtools.build.lib.platform.SleepPreventionModule.class, |
| com.google.devtools.build.lib.platform.SystemSuspensionModule.class, |
| BazelFileSystemModule.class, |
| com.google.devtools.build.lib.runtime.mobileinstall.MobileInstallModule.class, |
| com.google.devtools.build.lib.bazel.BazelWorkspaceStatusModule.class, |
| com.google.devtools.build.lib.bazel.BazelDiffAwarenessModule.class, |
| com.google.devtools.build.lib.remote.RemoteModule.class, |
| com.google.devtools.build.lib.bazel.BazelRepositoryModule.class, |
| com.google.devtools.build.lib.bazel.repository.starlark.StarlarkRepositoryDebugModule |
| .class, |
| com.google.devtools.build.lib.bazel.debug.WorkspaceRuleModule.class, |
| com.google.devtools.build.lib.bazel.coverage.BazelCoverageReportModule.class, |
| com.google.devtools.build.lib.starlarkdebug.module.StarlarkDebuggerModule.class, |
| com.google.devtools.build.lib.bazel.repository.RepositoryResolvedModule.class, |
| com.google.devtools.build.lib.bazel.repository.CacheHitReportingModule.class, |
| com.google.devtools.build.lib.bazel.SpawnLogModule.class, |
| com.google.devtools.build.lib.bazel.bzlmod.BazelLockFileModule.class, |
| com.google.devtools.build.lib.outputfilter.OutputFilteringModule.class, |
| com.google.devtools.build.lib.worker.WorkerModule.class, |
| com.google.devtools.build.lib.runtime.CacheFileDigestsModule.class, |
| com.google.devtools.build.lib.standalone.StandaloneModule.class, |
| com.google.devtools.build.lib.sandbox.SandboxModule.class, |
| com.google.devtools.build.lib.runtime.BuildSummaryStatsModule.class, |
| com.google.devtools.build.lib.dynamic.DynamicExecutionModule.class, |
| com.google.devtools.build.lib.bazel.rules.BazelRulesModule.class, |
| com.google.devtools.build.lib.bazel.rules.BazelStrategyModule.class, |
| com.google.devtools.build.lib.network.NoOpConnectivityModule.class, |
| com.google.devtools.build.lib.buildeventservice.BazelBuildEventServiceModule.class, |
| com.google.devtools.build.lib.profiler.memory.AllocationTrackerModule.class, |
| com.google.devtools.build.lib.packages.metrics.PackageMetricsModule.class, |
| com.google.devtools.build.lib.runtime.ExecutionGraphModule.class, |
| BazelBuiltinCommandModule.class, |
| com.google.devtools.build.lib.includescanning.IncludeScanningModule.class, |
| com.google.devtools.build.lib.skyframe.SkymeldModule.class, |
| com.google.devtools.build.lib.skyframe.serialization.SerializationModule.class, |
| // This module needs to be registered after any module submitting tasks with its {@code |
| // submit} method. |
| com.google.devtools.build.lib.runtime.BlockWaitingModule.class, |
| // Modules that are involved in the collection of heap-related metrics of a build. They |
| // need to be |
| // last in the modules order, so when the GCs happen at the end of the build, we mitigate |
| // the risk |
| // that objects are still held onto by the other modules. This is a quick fix for |
| // b/247613138. |
| // TODO(b/253394502): remove this when we have a better solution. |
| com.google.devtools.build.lib.metrics.PostGCMemoryUseRecorder |
| .PostGCMemoryUseRecorderModule.class, |
| com.google.devtools.build.lib.metrics.PostGCMemoryUseRecorder.GcAfterBuildModule.class, |
| com.google.devtools.build.lib.metrics.MetricsModule.class); |
| |
| public static void main(String[] args) { |
| BlazeVersionInfo.setBuildInfo(tryGetBuildInfo()); |
| BlazeRuntime.main(BAZEL_MODULES, args); |
| } |
| |
| /** |
| * Builds the standard build info map from the loaded properties. The returned value is the list |
| * of "build.*" properties from the build-data.properties file. The final key is the original one |
| * striped, dot replaced with a space and with first letter capitalized. If the file fails to |
| * load the returned map is empty. |
| */ |
| private static ImmutableMap<String, String> tryGetBuildInfo() { |
| try (InputStream in = Bazel.class.getResourceAsStream(BUILD_DATA_PROPERTIES)) { |
| if (in == null) { |
| return ImmutableMap.of(); |
| } |
| Properties props = new Properties(); |
| props.load(in); |
| ImmutableMap.Builder<String, String> buildData = ImmutableMap.builder(); |
| for (Object key : props.keySet()) { |
| String stringKey = key.toString(); |
| if (stringKey.startsWith("build.")) { |
| // build.label -> Build label, build.timestamp.as.int -> Build timestamp as int |
| String buildDataKey = "B" + stringKey.substring(1).replace('.', ' '); |
| buildData.put(buildDataKey, props.getProperty(stringKey, "")); |
| } |
| } |
| return buildData.buildOrThrow(); |
| } catch (IOException ignored) { |
| return ImmutableMap.of(); |
| } |
| } |
| } |