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

org.gradle.apiComponentSelection Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2014 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.artifacts;

import org.gradle.api.artifacts.component.ModuleComponentIdentifier;
import org.gradle.internal.HasInternalProtocol;

import javax.annotation.Nullable;

/***
 * Represents a tuple of the component selector of a module and a candidate version
 * to be evaluated in a component selection rule.
 */
@HasInternalProtocol
public interface ComponentSelection {
    /**
     * Gets the candidate version of the module.
     *
     * @return the candidate version of the module
     */
    ModuleComponentIdentifier getCandidate();

    /**
     * Gets the metadata of the component.
     * 

* The metadata may not be available, in which case {@code null} is returned. * Unavailable metadata may be caused by a module published without associated metadata. * * @return the {@code ComponentMetadata} or {@code null} if not available * @since 5.0 */ @Nullable ComponentMetadata getMetadata(); /** * Used to access a specific descriptor format. *

* For an Ivy module, an {@link org.gradle.api.artifacts.ivy.IvyModuleDescriptor ivy module descriptor} can be requested and returned. *

* If the descriptor type requested does not exist for the module under selection, {@code null} is returned. * * @param descriptorClass the descriptor class * @param the descriptor type * * @return a descriptor fo the requested type, or {@code null} if there was none of the requested type. * * @see org.gradle.api.artifacts.ivy.IvyModuleDescriptor * @since 5.0 */ @Nullable T getDescriptor(Class descriptorClass); /** * Rejects the candidate for the resolution. * * @param reason The reason the candidate was rejected. */ void reject(String reason); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy