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);
}