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

com.oracle.tools.runtime.Application Maven / Gradle / Ivy

/*
 * File: Application.java
 *
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * The contents of this file are subject to the terms and conditions of 
 * the Common Development and Distribution License 1.0 (the "License").
 *
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the License by consulting the LICENSE.txt file
 * distributed with this file, or by consulting https://oss.oracle.com/licenses/CDDL
 *
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file LICENSE.txt.
 *
 * MODIFICATIONS:
 * If applicable, add the following below the License Header, with the fields
 * enclosed by brackets [] replaced by your own identifying information:
 * "Portions Copyright [year] [name of copyright owner]"
 */

package com.oracle.tools.runtime;

import com.oracle.tools.Option;
import com.oracle.tools.Options;

import com.oracle.tools.options.Timeout;

import com.oracle.tools.runtime.options.ApplicationClosingBehavior;

import java.io.Closeable;

import java.util.Properties;

/**
 * A platform and location independent mechanism to represent, access and
 * control a running application.
 * 

* Copyright (c) 2011. All Rights Reserved. Oracle Corporation.
* Oracle is a registered trademark of Oracle Corporation and/or its affiliates. * * @author Brian Oliver */ public interface Application extends Closeable { /** * Obtains the environment variables that were supplied to the * {@link Application} when it was realized. * * @return {@link Properties} of containing name value pairs, each one * representing an environment variable provided to the * {@link Application} when it was realized */ public Properties getEnvironmentVariables(); /** * Obtains the name of the {@link Application}. * * @return The name of the {@link Application} */ public String getName(); /** * Obtains the {@link Platform} that this {@link Application} * is running on. * * @return the {@link Platform} that this {@link Application} * is running on */ public Platform getPlatform(); /** * Attempts to close and terminate the running {@link Application}. *

* Upon returning it is safe to assume that the {@link Application} * is no longer running. All resources, including input and output streams * used by the {@link Application} are no longer available to be used. *

* To determine the exit value of the terminated application use {@link #exitValue()}. */ @Override public void close(); /** * Attempts to close and terminate the running {@link Application} using the * specified {@link Option}s. When no {@link Option}s are specified * a regular {@link #close} is performed. *

* Upon returning it is safe to assume that the {@link Application} * is no longer running. All resources, including input and output streams * used by the {@link Application} are no longer available to be used. *

* To determine the exit value of the terminated application use {@link #exitValue()}. * * @param options the {@link Option}s indicating how to close the application. * * @see ApplicationClosingBehavior */ public void close(Option... options); /** * Causes the calling {@link Thread} to block and wait until the * {@link Application} has terminated, either naturally or due to a call * to {@link #close()} by another {@link Thread}. *

* This method returns immediately if the {@link Application} has already * been terminated. * * @param options the {@link Option}s for waiting, including possible * {@link Timeout} * * @return the exit value of the {@link Application} * (by convention 0 indicates normal termination) * * @throws RuntimeException if it wasn't possible to wait for the * termination. */ public int waitFor(Option... options); /** * Obtains the exit value for the terminated {@link Application}. * * @return the exit value of the {@link Application} * * @throws IllegalThreadStateException if the {@link Application} has not * yet terminated */ public int exitValue(); /** * Obtain the identity for the {@link Application}. This is typically * the underlying process id (pid), but in some circumstances this may be * an environment specific identifier. eg: in a cloud/container/multi-tenant * environment this may not be an operating system pid. * * @return The unique identity or -1 if it can't be determined. */ public long getId(); /** * Obtains the default duration to used by the {@link Application} * for timeouts. * * @return a {@link Timeout} */ public Timeout getDefaultTimeout(); /** * Obtains the configured {@link Options} for the {@link Application}. *

* Changes to the {@link Options} may not be recognized * or used by the {@link Application} after it was realized. * * @return the {@link Options} */ public Options getOptions(); /** * Adds an {@link ApplicationListener} to the {@link Application}. * * @param listener the {@link ApplicationListener} */ public void addApplicationListener(ApplicationListener listener); /** * Removes an {@link ApplicationListener} from the {@link Application}. * * @param listener the {@link ApplicationListener} */ public void removeApplicationListener(ApplicationListener listener); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy