org.gradle.api.NamedDomainObjectContainer Maven / Gradle / Ivy
Show all versions of gradle-api Show documentation
/*
* Copyright 2009 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;
import groovy.lang.Closure;
import org.gradle.api.provider.Provider;
import org.gradle.util.Configurable;
/**
* A named domain object container is a specialization of {@link NamedDomainObjectSet} that adds the ability to create
* instances of the element type.
*
* Implementations may use different strategies for creating new object instances.
*
* Note that a container is an implementation of {@link java.util.SortedSet}, which means that the container is guaranteed
* to only contain elements with unique names within this container. Furthermore, items are ordered by their name.
*
* You can create an instance of this type using the factory method {@link org.gradle.api.model.ObjectFactory#domainObjectContainer(Class)}.
*
* @param The type of objects in this container.
*/
public interface NamedDomainObjectContainer extends NamedDomainObjectSet, Configurable> {
/**
* Creates a new item with the given name, adding it to this container.
*
* @param name The name to assign to the created object
* @return The created object. Never null.
* @throws InvalidUserDataException if an object with the given name already exists in this container.
*/
T create(String name) throws InvalidUserDataException;
/**
* Looks for an item with the given name, creating and adding it to this container if it does not exist.
*
* @param name The name to find or assign to the created object
* @return The found or created object. Never null.
*/
T maybeCreate(String name);
/**
* Creates a new item with the given name, adding it to this container, then configuring it with the given closure.
*
* @param name The name to assign to the created object
* @param configureClosure The closure to configure the created object with
* @return The created object. Never null.
* @throws InvalidUserDataException if an object with the given name already exists in this container.
*/
T create(String name, Closure configureClosure) throws InvalidUserDataException;
/**
* Creates a new item with the given name, adding it to this container, then configuring it with the given action.
*
* @param name The name to assign to the created object
* @param configureAction The action to configure the created object with
* @return The created object. Never null.
* @throws InvalidUserDataException if an object with the given name already exists in this container.
*/
T create(String name, Action super T> configureAction) throws InvalidUserDataException;
/**
* Allows the container to be configured, creating missing objects as they are referenced.
*
* TODO: example usage
*
* @param configureClosure The closure to configure this container with
* @return This.
*/
@Override
NamedDomainObjectContainer configure(Closure configureClosure);
/**
* Defines a new object, which will be created and configured when it is required. An object is 'required' when the object is located using query methods such as {@link NamedDomainObjectCollection#getByName(java.lang.String)} or when {@link Provider#get()} is called on the return value of this method.
*
* It is generally more efficient to use this method instead of {@link #create(java.lang.String, org.gradle.api.Action)} or {@link #create(java.lang.String)}, as those methods will eagerly create and configure the object, regardless of whether that object is required for the current build or not. This method, on the other hand, will defer creation and configuration until required.
*
* @param name The name of the object.
* @param configurationAction The action to run to configure the object. This action runs when the object is required.
* @return A {@link Provider} that whose value will be the object, when queried.
* @throws InvalidUserDataException If a object with the given name already exists in this project.
* @since 4.10
*/
NamedDomainObjectProvider register(String name, Action super T> configurationAction) throws InvalidUserDataException;
/**
* Defines a new object, which will be created when it is required. A object is 'required' when the object is located using query methods such as {@link NamedDomainObjectCollection#getByName(java.lang.String)} or when {@link Provider#get()} is called on the return value of this method.
*
* It is generally more efficient to use this method instead of {@link #create(java.lang.String)}, as that method will eagerly create the object, regardless of whether that object is required for the current build or not. This method, on the other hand, will defer creation until required.
*
* @param name The name of the object.
* @return A {@link Provider} that whose value will be the object, when queried.
* @throws InvalidUserDataException If a object with the given name already exists in this project.
* @since 4.10
*/
NamedDomainObjectProvider register(String name) throws InvalidUserDataException;
}