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

org.gradle.apidsl.RepositoryHandler Maven / Gradle / Ivy

The 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.artifacts.dsl;

import groovy.lang.Closure;
import groovy.lang.DelegatesTo;
import org.gradle.api.Action;
import org.gradle.api.artifacts.ArtifactRepositoryContainer;
import org.gradle.api.artifacts.repositories.ArtifactRepository;
import org.gradle.api.artifacts.repositories.ExclusiveContentRepository;
import org.gradle.api.artifacts.repositories.FlatDirectoryArtifactRepository;
import org.gradle.api.artifacts.repositories.IvyArtifactRepository;
import org.gradle.api.artifacts.repositories.MavenArtifactRepository;
import org.gradle.declarative.dsl.model.annotations.Adding;
import org.gradle.internal.HasInternalProtocol;

import java.util.Map;

/**
 * A {@code RepositoryHandler} manages a set of repositories, allowing repositories to be defined and queried.
 */
@HasInternalProtocol
public interface RepositoryHandler extends ArtifactRepositoryContainer {

    /**
     * Adds a resolver that looks into a number of directories for artifacts. The artifacts are expected to be located in the
     * root of the specified directories. The resolver ignores any group/organization information specified in the
     * dependency section of your build script. If you only use this kind of resolver you might specify your
     * dependencies like ":junit:4.4" instead of "junit:junit:4.4".
     *
     * The following parameter are accepted as keys for the map:
     *
     * 
     * 
     * 
     *     
     * 
     *     
     * 
     *     
     * 
Shows property keys and associated values
KeyDescription of Associated Value
name(optional) The name of the repository. * The default is a Hash value of the rootdir paths. The name is used in the console output, * to point to information related to a particular repository. A name must be unique amongst a repository group.
dirsSpecifies a list of rootDirs where to look for dependencies. These are evaluated as per {@link org.gradle.api.Project#files(Object...)}
* *

Examples:

*
     * repositories {
     *     flatDir name: 'libs', dirs: "$projectDir/libs"
     *     flatDir dirs: ["$projectDir/libs1", "$projectDir/libs2"]
     * }
     * 
* * @param args The arguments used to configure the repository. * @return the added resolver * @throws org.gradle.api.InvalidUserDataException In the case neither rootDir nor rootDirs is specified of if both * are specified. */ FlatDirectoryArtifactRepository flatDir(Map args); /** * Adds and configures a repository which will look for dependencies in a number of local directories. * * @param configureClosure The closure to execute to configure the repository. * @return The repository. */ FlatDirectoryArtifactRepository flatDir(@DelegatesTo(FlatDirectoryArtifactRepository.class) Closure configureClosure); /** * Adds and configures a repository which will look for dependencies in a number of local directories. * * @param action The action to execute to configure the repository. * @return The repository. */ FlatDirectoryArtifactRepository flatDir(Action action); /** * Adds a repository which looks in Gradle Central Plugin Repository for dependencies. * * @return The Gradle Central Plugin Repository * @since 4.4 */ @Adding ArtifactRepository gradlePluginPortal(); /** * Adds a repository which looks in Gradle Central Plugin Repository for dependencies. * * @param action a configuration action * @return the added resolver * @since 5.4 */ ArtifactRepository gradlePluginPortal(Action action); /** * Adds a repository which looks in Bintray's JCenter repository for dependencies. *

* The URL used to access this repository is {@literal "https://jcenter.bintray.com/"}. * The behavior of this repository is otherwise the same as those added by {@link #maven(org.gradle.api.Action)}. *

* Examples: *

     * repositories {
     *   jcenter {
     *     artifactUrls = ["http://www.mycompany.com/artifacts1", "http://www.mycompany.com/artifacts2"]
     *   }
     *   jcenter {
     *     name = "nonDefaultName"
     *     artifactUrls = ["http://www.mycompany.com/artifacts1"]
     *   }
     * }
     * 
* * @param action a configuration action * @return the added repository * @deprecated JFrog announced JCenter's sunset in February 2021. Use {@link #mavenCentral()} instead. */ @Deprecated MavenArtifactRepository jcenter(Action action); /** * Adds a repository which looks in Bintray's JCenter repository for dependencies. *

* The URL used to access this repository is {@literal "https://jcenter.bintray.com/"}. * The behavior of this repository is otherwise the same as those added by {@link #maven(org.gradle.api.Action)}. *

* Examples: *

     * repositories {
     *     jcenter()
     * }
     * 
* * @return the added resolver * @see #jcenter(Action) * @deprecated JFrog announced JCenter's sunset in February 2021. Use {@link #mavenCentral()} instead. */ @Deprecated MavenArtifactRepository jcenter(); /** * Adds a repository which looks in the Maven central repository for dependencies. The URL used to access this repository is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#MAVEN_CENTRAL_URL}. * *

The following parameter are accepted as keys for the map: * *

* * * * * * * *
Shows property keys and associated values
KeyDescription of Associated Value
name(optional) The name of the repository. The default is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#DEFAULT_MAVEN_CENTRAL_REPO_NAME} is used as the name. A name * must be unique amongst a repository group. *
artifactUrlsA single jar repository or a collection of jar repositories containing additional artifacts not found in the Maven central repository. * But be aware that the POM must exist in Maven central. * The provided values are evaluated as per {@link org.gradle.api.Project#uri(Object)}.
* *

Examples:

*
     * repositories {
     *     mavenCentral artifactUrls: ["http://www.mycompany.com/artifacts1", "http://www.mycompany.com/artifacts2"]
     *     mavenCentral name: "nonDefaultName", artifactUrls: ["http://www.mycompany.com/artifacts1"]
     * }
     * 
* * @param args A list of urls of repositories to look for artifacts only. * @return the added repository */ MavenArtifactRepository mavenCentral(Map args); /** * Adds a repository which looks in the Maven central repository for dependencies. The URL used to access this repository is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#MAVEN_CENTRAL_URL}. The name of the repository is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#DEFAULT_MAVEN_CENTRAL_REPO_NAME}. * *

Examples:

*
     * repositories {
     *     mavenCentral()
     * }
     * 
* * @return the added resolver * @see #mavenCentral(java.util.Map) */ @Adding MavenArtifactRepository mavenCentral(); /** * Adds a repository which looks in the Maven central repository for dependencies. The URL used to access this repository is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#MAVEN_CENTRAL_URL}. The name of the repository is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#DEFAULT_MAVEN_CENTRAL_REPO_NAME}. * *

Examples:

*
     * repositories {
     *     mavenCentral()
     * }
     * 
* * @param action a configuration action * @return the added resolver * @since 5.3 */ MavenArtifactRepository mavenCentral(Action action); /** * Adds a repository which looks in the local Maven cache for dependencies. The name of the repository is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#DEFAULT_MAVEN_LOCAL_REPO_NAME}. * *

Examples:

*
     * repositories {
     *     mavenLocal()
     * }
     * 
*

* The location for the repository is determined as follows (in order of precedence): *

*
    *
  1. The value of system property 'maven.repo.local' if set;
  2. *
  3. The value of element <localRepository> of ~/.m2/settings.xml if this file exists and element is set;
  4. *
  5. The value of element <localRepository> of $M2_HOME/conf/settings.xml (where $M2_HOME is the value of the environment variable with that name) if this file exists and element is set;
  6. *
  7. The path ~/.m2/repository.
  8. *
* * @return the added resolver */ MavenArtifactRepository mavenLocal(); /** * Adds a repository which looks in the local Maven cache for dependencies. The name of the repository is * {@value org.gradle.api.artifacts.ArtifactRepositoryContainer#DEFAULT_MAVEN_LOCAL_REPO_NAME}. * *

Examples:

*
     * repositories {
     *     mavenLocal()
     * }
     * 
*

* The location for the repository is determined as follows (in order of precedence): *

*
    *
  1. The value of system property 'maven.repo.local' if set;
  2. *
  3. The value of element <localRepository> of ~/.m2/settings.xml if this file exists and element is set;
  4. *
  5. The value of element <localRepository> of $M2_HOME/conf/settings.xml (where $M2_HOME is the value of the environment variable with that name) if this file exists and element is set;
  6. *
  7. The path ~/.m2/repository.
  8. *
* * @param action a configuration action * @return the added resolver * @since 5.3 */ MavenArtifactRepository mavenLocal(Action action); /** * Adds a repository which looks in Google's Maven repository for dependencies. *

* The URL used to access this repository is {@literal "https://dl.google.com/dl/android/maven2/"}. *

* Examples: *

     * repositories {
     *     google()
     * }
     * 
* * @return the added resolver * @since 4.0 */ @Adding MavenArtifactRepository google(); /** * Adds a repository which looks in Google's Maven repository for dependencies. *

* The URL used to access this repository is {@literal "https://dl.google.com/dl/android/maven2/"}. *

* Examples: *

     * repositories {
     *     google()
     * }
     * 
* * @param action a configuration action * @return the added resolver * @since 5.3 */ MavenArtifactRepository google(Action action); /** * Adds and configures a Maven repository. Newly created instance of {@code MavenArtifactRepository} is passed as an argument to the closure. * * @param closure The closure to use to configure the repository. * @return The added repository. */ MavenArtifactRepository maven(@DelegatesTo(MavenArtifactRepository.class) Closure closure); /** * Adds and configures a Maven repository. * * @param action The action to use to configure the repository. * @return The added repository. */ MavenArtifactRepository maven(Action action); /** * Adds and configures an Ivy repository. Newly created instance of {@code IvyArtifactRepository} is passed as an argument to the closure. * * @param closure The closure to use to configure the repository. * @return The added repository. */ IvyArtifactRepository ivy(@DelegatesTo(IvyArtifactRepository.class) Closure closure); /** * Adds and configures an Ivy repository. * * @param action The action to use to configure the repository. * @return The added repository. */ IvyArtifactRepository ivy(Action action); /** * Declares exclusive content repositories. Exclusive content repositories are * repositories for which you can declare an inclusive content filter. Artifacts * matching the filter will then only be searched in the repositories which * exclusively match it. * * @param action the configuration of the repositories * * @since 6.2 */ void exclusiveContent(Action action); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy