org.gradle.internal.progress.BuildProgressLogger Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2010 the original author or authors.
*
* 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 org.gradle.internal.progress;
import com.google.common.annotations.VisibleForTesting;
import org.gradle.internal.logging.progress.ProgressLogger;
import org.gradle.internal.logging.progress.ProgressLoggerFactory;
public class BuildProgressLogger implements LoggerProvider {
public static final String INITIALIZATION_PHASE_DESCRIPTION = "INITIALIZATION PHASE";
public static final String INITIALIZATION_PHASE_SHORT_DESCRIPTION = "INITIALIZING";
public static final String CONFIGURATION_PHASE_DESCRIPTION = "CONFIGURATION PHASE";
public static final String CONFIGURATION_PHASE_SHORT_DESCRIPTION = "CONFIGURING";
public static final String EXECUTION_PHASE_DESCRIPTION = "EXECUTION PHASE";
public static final String EXECUTION_PHASE_SHORT_DESCRIPTION = "EXECUTING";
public static final int PROGRESS_BAR_WIDTH = 13;
public static final String PROGRESS_BAR_PREFIX = "<";
public static final char PROGRESS_BAR_COMPLETE_CHAR = '=';
public static final char PROGRESS_BAR_INCOMPLETE_CHAR = '-';
public static final String PROGRESS_BAR_SUFFIX = ">";
private final ProgressLoggerProvider loggerProvider;
private boolean taskGraphPopulated;
private ProgressLogger buildProgress;
private ProgressFormatter buildProgressFormatter;
public BuildProgressLogger(ProgressLoggerFactory progressLoggerFactory) {
this(new ProgressLoggerProvider(progressLoggerFactory, BuildProgressLogger.class));
}
BuildProgressLogger(ProgressLoggerProvider loggerProvider) {
this.loggerProvider = loggerProvider;
}
public void buildStarted() {
buildProgressFormatter = newProgressBar(INITIALIZATION_PHASE_SHORT_DESCRIPTION, 1);
buildProgress = loggerProvider.start(INITIALIZATION_PHASE_DESCRIPTION, buildProgressFormatter.getProgress());
}
public void settingsEvaluated() {
buildProgress.completed();
}
public void projectsLoaded(int totalProjects) {
buildProgressFormatter = newProgressBar(CONFIGURATION_PHASE_SHORT_DESCRIPTION, totalProjects);
buildProgress = loggerProvider.start(CONFIGURATION_PHASE_DESCRIPTION, buildProgressFormatter.getProgress());
}
public void beforeEvaluate(String projectPath) {}
public void afterEvaluate(String projectPath) {
if (!taskGraphPopulated) {
buildProgress.progress(buildProgressFormatter.incrementAndGetProgress());
}
}
public void graphPopulated(int totalTasks) {
taskGraphPopulated = true;
buildProgress.completed();
buildProgressFormatter = newProgressBar(EXECUTION_PHASE_SHORT_DESCRIPTION, totalTasks);
buildProgress = loggerProvider.start(EXECUTION_PHASE_DESCRIPTION, buildProgressFormatter.getProgress());
}
public void beforeExecute() {}
public void afterExecute() {
buildProgress.progress(buildProgressFormatter.incrementAndGetProgress());
}
public void buildFinished() {
buildProgress.completed();
buildProgress = null;
buildProgressFormatter = null;
}
public ProgressLogger getLogger() {
if (buildProgress == null) {
throw new IllegalStateException("Build logger is unavailable (it hasn't started or is already completed).");
}
return buildProgress;
}
@VisibleForTesting
public ProgressBar newProgressBar(String initialSuffix, int totalWorkItems) {
return new ProgressBar(PROGRESS_BAR_PREFIX,
PROGRESS_BAR_WIDTH,
PROGRESS_BAR_SUFFIX,
PROGRESS_BAR_COMPLETE_CHAR,
PROGRESS_BAR_INCOMPLETE_CHAR,
initialSuffix,
totalWorkItems);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy