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

org.gradle.internal.component.model.ComponentArtifactMetadata 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.internal.component.model;

import org.gradle.api.artifacts.component.ComponentArtifactIdentifier;
import org.gradle.api.artifacts.component.ComponentIdentifier;
import org.gradle.api.tasks.TaskDependency;
import org.gradle.internal.component.external.model.DefaultModuleComponentArtifactMetadata;

import java.util.Optional;

/**
 * Meta-data for an artifact that belongs to some component.
 */
public interface ComponentArtifactMetadata {
    /**
     * Returns the identifier for this artifact.
     */
    ComponentArtifactIdentifier getId();

    /**
     * Returns the identifier for the component that this artifact belongs to.
     */
    ComponentIdentifier getComponentId();

    /**
     * Returns this artifact as an Ivy artifact. This method is here to allow the artifact to be exposed in a backward-compatible way.
     */
    IvyArtifactName getName();

    /**
     * Collects the build dependencies of this artifact, which are required to build this artifact
     */
    TaskDependency getBuildDependencies();

    /**
     * Allows metadata with non-standard packaging to add a "fallback" artifact, to be resolved only when resolution fails.
     *
     * Typical use-cases are:
     * 
    *
  1. Maven POM declares {@code pom} packaging, but actually the artifact is a {@code jar}.
  2. *
  3. Maven POM declares an atypical packaging which does not match the artifact's type/extension property. See hk2-jar example. *
* * In these cases, supplying the alternative artifact metadata is a way to allow a re-fetch a different artifact file for the same component. * *

Defaults to {@link Optional#empty()} * * @return an optional artifact metadata, which if present will be resolved if this artifact's resolution fails * @see DefaultModuleComponentArtifactMetadata#DefaultModuleComponentArtifactMetadata(org.gradle.api.artifacts.component.ModuleComponentIdentifier, org.gradle.internal.component.model.IvyArtifactName, org.gradle.internal.component.model.ComponentArtifactMetadata) */ default Optional getAlternativeArtifact() { return Optional.empty(); } default boolean isOptionalArtifact() { return false; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy