org.gradle.api.internalconfigurations.ConfigurationInternal 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 5.6 API redistribution.
/*
* Copyright 2011 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.artifacts.configurations;
import org.gradle.api.Action;
import org.gradle.api.artifacts.Configuration;
import org.gradle.api.artifacts.ExcludeRule;
import org.gradle.api.internal.artifacts.ResolveContext;
import org.gradle.api.internal.artifacts.transform.ExtraExecutionGraphDependenciesResolverFactory;
import org.gradle.api.internal.attributes.AttributeContainerInternal;
import org.gradle.util.Path;
import java.util.Set;
public interface ConfigurationInternal extends ResolveContext, Configuration, DependencyMetaDataProvider {
enum InternalState {
UNRESOLVED,
BUILD_DEPENDENCIES_RESOLVED,
GRAPH_RESOLVED,
ARTIFACTS_RESOLVED}
@Override
ResolutionStrategyInternal getResolutionStrategy();
@Override
AttributeContainerInternal getAttributes();
String getPath();
Path getIdentityPath();
/**
* Runs any registered dependency actions for this Configuration, and any parent Configuration.
* Actions may mutate the dependency set for this configuration.
* After execution, all actions are de-registered, so execution will only occur once.
*/
void runDependencyActions();
void markAsObserved(InternalState requestedState);
void addMutationValidator(MutationValidator validator);
void removeMutationValidator(MutationValidator validator);
/**
* Converts this configuration to an {@link OutgoingVariant} view. The view may not necessarily be immutable.
*/
OutgoingVariant convertToOutgoingVariant();
/**
* Registers an action to execute before locking for further mutation.
*/
void beforeLocking(Action action);
void preventFromFurtherMutation();
/**
* Gets the complete set of exclude rules including those contributed by
* superconfigurations.
*/
Set getAllExcludeRules();
ExtraExecutionGraphDependenciesResolverFactory getDependenciesResolver();
}