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

org.gradle.launcher.daemon.server.api.DaemonStateControl Maven / Gradle / Ivy

/*
 * Copyright 2012 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.launcher.daemon.server.api;

import org.gradle.initialization.BuildCancellationToken;

public interface DaemonStateControl {
    /**
     * 

Requests that the daemon stop, but wait until the daemon is idle. The stop will happen asynchronously, and this method does not block. * *

The daemon will stop accepting new work, so that subsequent calls to {@link #runCommand} will fail with {@link DaemonUnavailableException}. */ void requestStop(String reason); /** * Requests a forceful stops of the daemon. Does not wait until the daemon is idle to begin stopping. The stop will happen asynchronously, and this method does not block. * *

If any long running command is currently running, the blocked call to {@link #runCommand} will fail with {@link DaemonStoppedException}.

* *

The daemon will stop accepting new work, so that subsequent calls to {@link #runCommand} will failing with {@link DaemonUnavailableException}. */ void requestForcefulStop(String reason); /** * Returns the current state of the daemon * * @return The current state of the daemon */ State getState(); /** * Requests that a running build be canceled. Note that this method does NOT block until the operation has been cancelled. */ void requestCancel(); /** * Communicates a request for build cancellation. Note that this method blocks until the operation has been cancelled. * *

If any long running command is currently running, this method does block for certain time to give chance to perform cancellation, and if the command * doesn't finnish in a timely manner a request for forceful stop will be issued ({@link #requestForcefulStop(String reason)}.

*/ void cancelBuild(); /** * Returns a cancellation token used to communicate cancel requests to commands processed in this daemon. * * @return Created cancellation token associated with currently running command or an arbitrary instance if no command is running. */ BuildCancellationToken getCancellationToken(); /** * Runs the given long running command. No more than 1 command may be running at any given time. * * @param command The command to run * @param commandDisplayName The command's display name, used for logging and error messages. * * @throws DaemonUnavailableException When this daemon is unable to run the command, either because it is currently executing another command * or is currently stopping. * @throws DaemonStoppedException When this daemon started executing the command but was unable to complete it because the daemon is about to stop. * The caller should note that the command may still be running at the time the method returns but should consider the command as abandoned. */ void runCommand(Runnable command, String commandDisplayName) throws DaemonUnavailableException, DaemonStoppedException; enum State {Idle, Busy, Canceled, StopRequested, Stopped, Broken} }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy