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

org.gradle.api.internal.collections.ElementSource Maven / Gradle / Ivy

/*
 * Copyright 2018 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.collections;

import org.gradle.api.Action;
import org.gradle.api.internal.MutationGuard;
import org.gradle.api.internal.provider.CollectionProviderInternal;
import org.gradle.api.internal.provider.ProviderInternal;

import java.util.Collection;
import java.util.Iterator;

/**
 * The heart of any domain object collection. This source is able to track eager and lazy (pending)
 * elements, and attempts to defer realization of pending elements until they are needed.
 */
public interface ElementSource extends Iterable {

    /**
     * Iterates over and realizes each of the elements of this source.
     */
    @Override
    Iterator iterator();

    /**
     * Iterates over only the realized elements (without flushing any pending elements)
     */
    Iterator iteratorNoFlush();

    /**
     * Returns true iff this source is empty.
     */
    boolean isEmpty();

    /**
     * Returns false if this source is not empty, or it is not fast to determine this.
     */
    boolean constantTimeIsEmpty();

    /**
     * Returns the number of elements in this source.
     * 

* This method may be expensive, as it may require realizing all pending elements. */ int size(); /** * Estimate the size of this source by returning a value which is greater or equal to the real size. * This method is intended to be used to size temporary collections and maps to avoid resizes. *

* For filtered collections, this should return the size of the source collection, in order to avoid * performing filtering just to determine the size of temporary collections. */ int estimatedSize(); boolean contains(Object element); boolean containsAll(Collection elements); boolean add(T element); /** * Sets a verifier that specifies whether there is a subscription for * elements of a given type. This is used to determine whether a * pending element should be realized upon addition to this source. */ void setSubscriptionVerifier(EventSubscriptionVerifier typeSubscriptions); void clear(); boolean remove(Object o); void realizePending(); void realizePending(Class type); boolean addPending(ProviderInternal provider); boolean removePending(ProviderInternal provider); boolean addPendingCollection(CollectionProviderInternal> provider); boolean removePendingCollection(CollectionProviderInternal> provider); void realizeExternal(ProviderInternal provider); /** * Adds an action to be executed when a value from a pending element is concretely added. * The provided action is only called when a pending value is realized and the value is not * already present in the concrete values of this source. */ void onPendingAdded(Action action); /** * Tracks whether lazy actions are currently being executed against this element source. */ MutationGuard getLazyBehaviorGuard(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy