org.gradle.internal.component.external.model.PreferJavaRuntimeVariant Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2017 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.external.model;
import com.google.common.collect.Sets;
import org.gradle.api.attributes.Attribute;
import org.gradle.api.attributes.LibraryElements;
import org.gradle.api.attributes.Usage;
import org.gradle.api.internal.attributes.DisambiguationRule;
import org.gradle.api.internal.attributes.EmptySchema;
import org.gradle.api.internal.attributes.MultipleCandidatesResult;
import org.gradle.api.internal.model.NamedObjectInstantiator;
import org.gradle.internal.Cast;
import java.util.Set;
/**
* When no consumer attributes are provided, prefer the Java runtime variant over the API variant.
*
* Gradle has long assumed that, by default, consumers of a maven repository require the _runtime_ variant
* of the published library.
* The following disambiguation rule encodes this assumption for the case where a java library is published
* with variants using Gradle module metadata. This will allow us to migrate to consuming the new module
* metadata format by default without breaking a bunch of consumers that depend on this assumption,
* declaring no preference for a particular variant.
*/
public class PreferJavaRuntimeVariant extends EmptySchema {
private static final Set> SUPPORTED_ATTRIBUTES = Sets.newHashSet(Usage.USAGE_ATTRIBUTE, LibraryElements.LIBRARY_ELEMENTS_ATTRIBUTE);
private final PreferRuntimeVariantUsageDisambiguationRule usageDisambiguationRule;
private final PreferJarVariantUsageDisambiguationRule formatDisambiguationRule;
public PreferJavaRuntimeVariant(NamedObjectInstantiator instantiator) {
Usage runtimeUsage = instantiator.named(Usage.class, Usage.JAVA_RUNTIME);
LibraryElements jarLibraryElements = instantiator.named(LibraryElements.class, LibraryElements.JAR);
usageDisambiguationRule = new PreferRuntimeVariantUsageDisambiguationRule(runtimeUsage);
formatDisambiguationRule = new PreferJarVariantUsageDisambiguationRule(jarLibraryElements);
}
@Override
public Set> getAttributes() {
return SUPPORTED_ATTRIBUTES;
}
@Override
public DisambiguationRule
© 2015 - 2025 Weber Informatics LLC | Privacy Policy