org.gradle.api.internal.FactoryNamedDomainObjectContainer 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.
The newest version!
/*
* 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;
import groovy.lang.Closure;
import org.gradle.api.Action;
import org.gradle.api.Named;
import org.gradle.api.NamedDomainObjectFactory;
import org.gradle.api.Namer;
import org.gradle.api.internal.collections.CollectionFilter;
import org.gradle.api.specs.Spec;
import org.gradle.internal.Cast;
import org.gradle.internal.reflect.Instantiator;
public class FactoryNamedDomainObjectContainer extends AbstractNamedDomainObjectContainer {
private final NamedDomainObjectFactory factory;
private final MutationGuard crossProjectConfiguratorMutationGuard;
// Many of these constructors are called by the nebula plugins
// https://github.com/nebula-plugins/nebula-project-plugin/blob/f0f587f7b7014b6202875dc499dae05b0fc32344/src/main/groovy/nebula/plugin/responsible/gradle/NamedContainerProperOrder.groovy#L12-L31
/**
* Creates a container that instantiates using the given factory.
*
* @param type The concrete type of element in the container (must implement {@link Named})
* @param instantiator The instantiator to use to create any other collections based on this one
* @param factory The factory responsible for creating new instances on demand
* @param collectionCallbackActionDecorator the decorator for collection callback action execution
*/
public FactoryNamedDomainObjectContainer(Class type, Instantiator instantiator, NamedDomainObjectFactory factory, CollectionCallbackActionDecorator collectionCallbackActionDecorator) {
this(type, instantiator, Named.Namer.forType(type), factory, MutationGuards.identity(), collectionCallbackActionDecorator);
}
/**
* Creates a container that instantiates using the given factory.
*
* @param type The concrete type of element in the container
* @param instantiator The instantiator to use to create any other collections based on this one
* @param namer The naming strategy to use
* @param factory The factory responsible for creating new instances on demand
*/
public FactoryNamedDomainObjectContainer(Class type, Instantiator instantiator, Namer super T> namer, NamedDomainObjectFactory factory, MutationGuard crossProjectConfiguratorMutationGuard, CollectionCallbackActionDecorator collectionCallbackActionDecorator) {
super(type, instantiator, namer, collectionCallbackActionDecorator);
this.factory = factory;
this.crossProjectConfiguratorMutationGuard = crossProjectConfiguratorMutationGuard;
}
/**
* Creates a container that instantiates using the given factory.
*
* @param type The concrete type of element in the container (must implement {@link Named})
* @param instantiator The instantiator to use to create any other collections based on this one
* @param factoryClosure The closure responsible for creating new instances on demand
*/
public FactoryNamedDomainObjectContainer(Class type, Instantiator instantiator, final Closure> factoryClosure, CollectionCallbackActionDecorator collectionCallbackActionDecorator) {
this(type, instantiator, Named.Namer.forType(type), factoryClosure, MutationGuards.identity(), collectionCallbackActionDecorator);
}
/**
* Creates a container that instantiates using the given factory.
*
* @param type The concrete type of element in the container
* @param instantiator The instantiator to use to create any other collections based on this one
* @param namer The naming strategy to use
* @param factoryClosure The factory responsible for creating new instances on demand
*/
public FactoryNamedDomainObjectContainer(Class type, Instantiator instantiator, Namer super T> namer, final Closure> factoryClosure, MutationGuard mutationGuard, CollectionCallbackActionDecorator collectionCallbackActionDecorator) {
this(type, instantiator, namer, new ClosureObjectFactory<>(type, factoryClosure), mutationGuard, collectionCallbackActionDecorator);
}
@Override
protected DefaultNamedDomainObjectSet filtered(CollectionFilter filter) {
return Cast.uncheckedNonnullCast(getInstantiator().newInstance(DefaultNamedDomainObjectSet.class, this, filter, getInstantiator(), getNamer(), crossProjectConfiguratorMutationGuard));
}
@Override
protected DefaultNamedDomainObjectSet filtered(Spec nameFilter, CollectionFilter elementFilter) {
return Cast.uncheckedNonnullCast(getInstantiator().newInstance(DefaultNamedDomainObjectSet.class, this, nameFilter, elementFilter, getInstantiator(), getNamer(), crossProjectConfiguratorMutationGuard));
}
@Override
protected Action super I> wrapLazyAction(Action super I> action) {
return crossProjectConfiguratorMutationGuard.wrapLazyAction(super.wrapLazyAction(action));
}
@Override
protected T doCreate(String name) {
return factory.create(name);
}
// For backwards compatibility with nebula plugins
// https://github.com/nebula-plugins/nebula-project-plugin/blob/f0f587f7b7014b6202875dc499dae05b0fc32344/src/main/groovy/nebula/plugin/responsible/gradle/NamedContainerProperOrder.groovy#L35
protected void assertCanAdd(String name) {
assertElementNotPresent(name);
}
private static class ClosureObjectFactory implements NamedDomainObjectFactory {
private final Class type;
private final Closure> factoryClosure;
public ClosureObjectFactory(Class type, Closure> factoryClosure) {
this.type = type;
this.factoryClosure = factoryClosure;
}
@Override
public T create(String name) {
return type.cast(factoryClosure.call(name));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy