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

org.gradle.api.DomainObjectCollection Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * 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 groovy.lang.DelegatesTo;
import org.gradle.api.provider.Provider;
import org.gradle.api.specs.Spec;

import java.util.Collection;

/**
 * 

A {@code DomainObjectCollection} is a specialised {@link Collection} that adds the ability to receive modification notifications and use live filtered sub collections.

* *

The filtered collections returned by the filtering methods, such as {@link #matching(Closure)}, return collections that are live. That is, they reflect * changes made to the source collection that they were created from. This is true for filtered collections made from filtered collections etc.

*

* You can also add actions that are executed as elements are added to the collection. Actions added to filtered collections will be fired if an addition/removal * occurs for the source collection that matches the filter.

*

* {@code DomainObjectCollection} instances are not thread-safe and undefined behavior may result from the invocation of any method on a collection that is being mutated by another * thread; this includes direct invocations, passing the collection to a method that might perform invocations, and using an existing iterator to examine the collection. *

* * @param The type of objects in this collection. */ public interface DomainObjectCollection extends Collection { /** * Adds an element to this collection, given a {@link Provider} that will provide the element when required. * * @param provider A {@link Provider} that can provide the element when required. * @since 4.8 */ void addLater(Provider provider); /** * Adds elements to this collection, given a {@link Provider} of {@link Iterable} that will provide the elements when required. * * @param provider A {@link Provider} of {@link Iterable} that can provide the elements when required. * @since 5.0 */ void addAllLater(Provider> provider); /** * Returns a collection containing the objects in this collection of the given type. The returned collection is * live, so that when matching objects are later added to this collection, they are also visible in the filtered * collection. * * @param type The type of objects to find. * @return The matching objects. Returns an empty collection if there are no such objects in this collection. */ DomainObjectCollection withType(Class type); /** * Returns a collection containing the objects in this collection of the given type. Equivalent to calling * {@code withType(type).all(configureAction)} * * @param type The type of objects to find. * @param configureAction The action to execute for each object in the resulting collection. * @return The matching objects. Returns an empty collection if there are no such objects in this collection. */ DomainObjectCollection withType(Class type, Action configureAction); /** * Returns a collection containing the objects in this collection of the given type. Equivalent to calling * {@code withType(type).all(configureClosure)}. * * @param type The type of objects to find. * @param configureClosure The closure to execute for each object in the resulting collection. * @return The matching objects. Returns an empty collection if there are no such objects in this collection. */ DomainObjectCollection withType(@DelegatesTo.Target Class type, @DelegatesTo(genericTypeIndex = 0) Closure configureClosure); /** * Returns a collection which contains the objects in this collection which meet the given specification. The * returned collection is live, so that when matching objects are added to this collection, they are also visible in * the filtered collection. * * @param spec The specification to use. * @return The collection of matching objects. Returns an empty collection if there are no such objects in this * collection. */ DomainObjectCollection matching(Spec spec); /** * Returns a collection which contains the objects in this collection which meet the given closure specification. The * returned collection is live, so that when matching objects are added to this collection, they are also visible in * the filtered collection. * * @param spec The specification to use. The closure gets a collection element as an argument. * @return The collection of matching objects. Returns an empty collection if there are no such objects in this * collection. */ DomainObjectCollection matching(Closure spec); /** * Adds an {@code Action} to be executed when an object is added to this collection. *

* Like {@link #all(Action)}, this method will cause all objects in this container to be realized. *

* @param action The action to be executed * @return the supplied action */ Action whenObjectAdded(Action action); /** * Adds a closure to be called when an object is added to this collection. The newly added object is passed to the * closure as the parameter. * * @param action The closure to be called * @see #whenObjectAdded(Action) */ void whenObjectAdded(Closure action); /** * Adds an {@code Action} to be executed when an object is removed from this collection. * * @param action The action to be executed * @return the supplied action */ Action whenObjectRemoved(Action action); /** * Adds a closure to be called when an object is removed from this collection. The removed object is passed to the * closure as the parameter. * * @param action The closure to be called */ void whenObjectRemoved(Closure action); /** * Executes the given action against all objects in this collection, and any objects subsequently added to this * collection. * * @param action The action to be executed */ void all(Action action); /** * Executes the given closure against all objects in this collection, and any objects subsequently added to this collection. The object is passed to the closure as the closure * delegate. Alternatively, it is also passed as a parameter. * * @param action The action to be executed */ void all(Closure action); /** * Configures each element in this collection using the given action, as each element is required. Actions are run in the order added. * * @param action A {@link Action} that can configure the element when required. * @since 4.9 */ void configureEach(Action action); // note: this is here to override the default Groovy Collection.findAll { } method. /** * Returns a collection which contains the objects in this collection which meet the given closure specification. * * @param spec The specification to use. The closure gets a collection element as an argument. * @return The collection of matching objects. Returns an empty collection if there are no such objects in this * collection. */ Collection findAll(Closure spec); }