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

org.gradle.process.JavaForkOptions Maven / Gradle / Ivy

/*
 * Copyright 2010 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.process;

import org.gradle.api.Action;
import org.gradle.api.file.FileCollection;
import org.gradle.api.tasks.Classpath;
import org.gradle.api.tasks.Input;
import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.Nested;
import org.gradle.api.tasks.Optional;
import org.gradle.internal.HasInternalProtocol;
import org.gradle.internal.instrumentation.api.annotations.ToBeReplacedByLazyProperty;

import javax.annotation.Nullable;
import java.util.List;
import java.util.Map;

/**
 * 

Specifies the options to use to fork a Java process.

*/ @HasInternalProtocol public interface JavaForkOptions extends ProcessForkOptions { /** * Returns the system properties which will be used for the process. * * @return The system properties. Returns an empty map when there are no system properties. */ @Input @ToBeReplacedByLazyProperty Map getSystemProperties(); /** * Sets the system properties to use for the process. * * @param properties The system properties. Must not be null. */ void setSystemProperties(Map properties); /** * Adds some system properties to use for the process. * * @param properties The system properties. Must not be null. * @return this */ JavaForkOptions systemProperties(Map properties); /** * Adds a system property to use for the process. * * @param name The name of the property * @param value The value for the property. May be null. * @return this */ JavaForkOptions systemProperty(String name, Object value); /** * Returns the default character encoding to use. * * @return The default character encoding. Returns null if the {@link java.nio.charset.Charset#defaultCharset() default character encoding of this JVM} should be used. */ @ToBeReplacedByLazyProperty @Nullable @Optional @Input String getDefaultCharacterEncoding(); /** * Sets the default character encoding to use. * * Note: Many JVM implementations support the setting of this attribute via system property on startup (namely, the {@code file.encoding} property). For JVMs * where this is the case, setting the {@code file.encoding} property via {@link #setSystemProperties(java.util.Map)} or similar will have no effect as * this value will be overridden by the value specified by {@link #getDefaultCharacterEncoding()}. * * @param defaultCharacterEncoding The default character encoding. Use null to use {@link java.nio.charset.Charset#defaultCharset() this JVM's default charset} */ void setDefaultCharacterEncoding(@Nullable String defaultCharacterEncoding); /** * Returns the minimum heap size for the process, if any. * * @return The minimum heap size. Returns null if the default minimum heap size should be used. */ @ToBeReplacedByLazyProperty @Nullable @Optional @Input String getMinHeapSize(); /** * Sets the minimum heap size for the process. * Supports the units megabytes (e.g. "512m") and gigabytes (e.g. "1g"). * * @param heapSize The minimum heap size. Use null for the default minimum heap size. */ void setMinHeapSize(@Nullable String heapSize); /** * Returns the maximum heap size for the process, if any. * * @return The maximum heap size. Returns null if the default maximum heap size should be used. */ @ToBeReplacedByLazyProperty @Nullable @Optional @Input String getMaxHeapSize(); /** * Sets the maximum heap size for the process. * Supports the units megabytes (e.g. "512m") and gigabytes (e.g. "1g"). * * @param heapSize The heap size. Use null for the default maximum heap size. */ void setMaxHeapSize(@Nullable String heapSize); /** * Returns the extra arguments to use to launch the JVM for the process. Does not include system properties and the * minimum/maximum heap size. * * @return The immutable list of arguments. Returns an empty list if there are no arguments. */ @ToBeReplacedByLazyProperty @Nullable @Optional @Input List getJvmArgs(); /** * Sets the extra arguments to use to launch the JVM for the process. System properties * and minimum/maximum heap size are updated. * * @param arguments The arguments. Must not be null. * @since 4.0 */ void setJvmArgs(@Nullable List arguments); /** * Sets the extra arguments to use to launch the JVM for the process. System properties * and minimum/maximum heap size are updated. * * @param arguments The arguments. Must not be null. */ void setJvmArgs(@Nullable Iterable arguments); /** * Adds some arguments to use to launch the JVM for the process. * * @param arguments The arguments. Must not be null. * @return this */ JavaForkOptions jvmArgs(Iterable arguments); /** * Adds some arguments to use to launch the JVM for the process. * * @param arguments The arguments. * @return this */ JavaForkOptions jvmArgs(Object... arguments); /** * Command line argument providers for the java process to fork. * * @since 4.6 */ @Nested @ToBeReplacedByLazyProperty List getJvmArgumentProviders(); /** * Returns the bootstrap classpath to use for the process. The default bootstrap classpath for the JVM is used when * this classpath is empty. * * @return The bootstrap classpath. Never returns null. */ @Classpath @ToBeReplacedByLazyProperty FileCollection getBootstrapClasspath(); /** * Sets the bootstrap classpath to use for the process. Set to an empty classpath to use the default bootstrap * classpath for the specified JVM. * * @param classpath The classpath. Must not be null. Can be empty. */ void setBootstrapClasspath(FileCollection classpath); /** * Adds the given values to the end of the bootstrap classpath for the process. * * @param classpath The classpath. * @return this */ JavaForkOptions bootstrapClasspath(Object... classpath); /** * Returns true if assertions are enabled for the process. * * @return true if assertions are enabled, false if disabled */ @Input @ToBeReplacedByLazyProperty boolean getEnableAssertions(); /** * Enable or disable assertions for the process. * * @param enabled true to enable assertions, false to disable. */ void setEnableAssertions(boolean enabled); /** * Determines whether debugging is enabled for the test process. When enabled — {@code debug = true} — the process * is started in a suspended state, listening on port 5005. You should disable parallel test execution when * debugging and you will need to reattach the debugger occasionally if you use a non-zero value for * {@link org.gradle.api.tasks.testing.Test#getForkEvery()}. *

* Since Gradle 5.6, you can configure the port and other Java debug properties via * {@link #debugOptions(Action)}. * * @return true when debugging is enabled, false to disable. */ @Input @ToBeReplacedByLazyProperty boolean getDebug(); /** * Enable or disable debugging for the process. When enabled, the process is started suspended and listening on port * 5005. *

* The debug properties (e.g. the port number) can be configured in {@link #debugOptions(Action)}. * * @param enabled true to enable debugging, false to disable. */ void setDebug(boolean enabled); /** * Returns the Java Debug Wire Protocol properties for the process. If enabled then the {@code -agentlib:jdwp=...} * will be appended to the JVM arguments with the configuration from the parameter. * * @since 5.6 */ @Nested JavaDebugOptions getDebugOptions(); /** * Configures Java Debug Wire Protocol properties for the process. If {@link #setDebug(boolean)} is enabled then * the {@code -agentlib:jdwp=...} will be appended to the JVM arguments with the configuration from the parameter. * * @param action the Java debug configuration * @since 5.6 */ void debugOptions(Action action); /** * Returns the full set of arguments to use to launch the JVM for the process. This includes arguments to define * system properties, the minimum/maximum heap size, and the bootstrap classpath. * * @return The immutable list of arguments. Returns an empty list if there are no arguments. */ @Internal @ToBeReplacedByLazyProperty List getAllJvmArgs(); /** * Sets the full set of arguments to use to launch the JVM for the process. Overwrites any previously set system * properties, minimum/maximum heap size, assertions, and bootstrap classpath. * * @param arguments The arguments. Must not be null. * @since 4.0 */ void setAllJvmArgs(List arguments); /** * Sets the full set of arguments to use to launch the JVM for the process. Overwrites any previously set system * properties, minimum/maximum heap size, assertions, and bootstrap classpath. * * @param arguments The arguments. Must not be null. */ void setAllJvmArgs(Iterable arguments); /** * Copies these options to the given options. * * @param options The target options. * @return this */ JavaForkOptions copyTo(JavaForkOptions options); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy