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

org.gradle.api.jvm.ModularitySpec Maven / Gradle / Ivy

/*
 * Copyright 2020 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.jvm;

import org.gradle.api.provider.Property;
import org.gradle.api.tasks.Input;

/**
 * Description of the modularity of a classpath.
 * 

* A classpath is a list of JAR files, classes and resources folders passed to one of the JDK's commands like javac, java, or javadoc. * Since Java 9, these commands offer two different approaches to handle such a classpath: * *

    *
  • A traditional classpath by using the --classpath parameter. *
  • A modular classpath (module path) using the --module-path parameter. *
* * If the --module-path is used, the Java Platform Module System (JPMS) becomes active and the module descriptors (module-info.class) * files are used to limit visibility of packages between modules at compile and runtime. *

* Wherever a classpath (a list of files and folders) is configured in Gradle, it can be accompanied by a ModularClasspathHandling object * to describe how the entries of that list are to be passed to the --classpath and --module-path parameters. * * @since 6.4 */ public interface ModularitySpec { /** * Should a --module-path be inferred by analysing JARs and class folders on the classpath? *

* An entry is considered to be part of the module path if it meets one of the following conditions: *

    *
  • It is a jar that contains a 'module-info.class'. *
  • It is a class folder that contains a 'module-info.class'. *
  • It is a jar with a MANIFEST that contains an 'Automatic-Module-Name' entry. *
*/ @Input Property getInferModulePath(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy