All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.gradle.api.internal.tasks.SnapshotTaskInputsBuildOperationType Maven / Gradle / Ivy

There is a newer version: 8.6
Show newest version
/*
 * Copyright 2017 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.api.internal.tasks;

import org.gradle.internal.operations.BuildOperationType;
import org.gradle.internal.scan.UsedByScanPlugin;

import javax.annotation.Nullable;
import java.util.List;
import java.util.Map;
import java.util.Set;

/**
 * Represents the computation of the task artifact state and the task output caching state.
 * 

* This operation is executed only when the build cache is enabled or when the build scan plugin is applied. * Must occur as a child of {@link org.gradle.api.internal.tasks.execution.ExecuteTaskBuildOperationType}. * * @since 4.0 */ public final class SnapshotTaskInputsBuildOperationType implements BuildOperationType { @UsedByScanPlugin public interface Details { } /** * The hashes of the inputs. *

* If the inputs were not snapshotted, all fields are null. * This may occur if the task had no outputs. */ @UsedByScanPlugin public interface Result { /** * The overall hash value for the inputs. *

* Null if the overall key was not calculated because the inputs were invalid. */ @Nullable byte[] getHashBytes(); /** * The hash of the classloader that loaded the task implementation. *

* Null if the classloader is not managed by Gradle. */ @Nullable byte[] getClassLoaderHashBytes(); /** * The hashes of the classloader that loaded each of the task's actions. *

* May contain duplicates. * Order corresponds to execution order of the actions. * Never empty. * May contain nulls (non Gradle managed classloader) */ @Nullable List getActionClassLoaderHashesBytes(); /** * The class names of each of the task's actions. *

* May contain duplicates. * Order corresponds to execution order of the actions. * Never empty. */ @Nullable List getActionClassNames(); @Nullable Map getInputValueHashesBytes(); /** * The consuming visitor for file property inputs. *

* Properties are visited depth-first lexicographical. * Roots are visited in semantic order (i.e. the order in which they make up the file collection) * Files and directories are depth-first lexicographical. *

* For roots that are a file, they are also visited with {@link #file(VisitState)}. */ interface InputFilePropertyVisitor { /** * Called once per file property. *

* Only getProperty*() state methods may be called during. */ void preProperty(VisitState state); /** * Called for each root of the current property. *

* {@link VisitState#getName()} and {@link VisitState#getPath()} may be called during. */ void preRoot(VisitState state); /** * Called before entering a directory. *

* {@link VisitState#getName()} and {@link VisitState#getPath()} may be called during. */ void preDirectory(VisitState state); /** * Called when visiting a non-directory file. *

* {@link VisitState#getName()}, {@link VisitState#getPath()} and {@link VisitState#getHashBytes()} may be called during. */ void file(VisitState state); /** * Called when exiting a directory. */ void postDirectory(); /** * Called when exiting a root. */ void postRoot(); /** * Called when exiting a property. */ void postProperty(); } /** * Provides information about the current location in the visit. *

* Consumers should expect this to be mutable. * Calling any method on this outside of a method that received it has undefined behavior. */ interface VisitState { String getPropertyName(); byte[] getPropertyHashBytes(); String getPropertyNormalizationStrategyName(); String getPath(); String getName(); byte[] getHashBytes(); } /** * Traverses the input properties that are file types (e.g. File, FileCollection, FileTree, List of File). *

* If there are no input file properties, visitor will not be called at all. */ void visitInputFileProperties(InputFilePropertyVisitor visitor); /** * Names of input properties which have been loaded by non Gradle managed classloader. *

* Ordered by property name, lexicographically. * No null values. * Never empty. */ @Nullable Set getInputPropertiesLoadedByUnknownClassLoader(); /** * The names of the output properties. *

* No duplicate values. * Ordered lexicographically. * Never empty. */ @Nullable List getOutputPropertyNames(); } private SnapshotTaskInputsBuildOperationType() { } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy