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

com.github.dm.jrt.channel.Channel Maven / Gradle / Ivy

There is a newer version: 5.9.0
Show newest version
/*
 * 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 com.github.dm.jrt.channel;

import org.jetbrains.annotations.Nullable;

/**
 * Interface defining the basic communication channel with the routine invocation.
 * 

* Channel instances are used to transfer data to and from the code executed inside the routine * invocation. *

* Created by davide-maestroni on 09/09/2014. */ public interface Channel { /** * Closes the channel and abort the transfer of data, thus aborting the routine invocation. *

* An instance of {@link com.github.dm.jrt.channel.AbortException AbortException} will be passed * as the abortion reason. *

* Note that, in case the channel was already closed, the call to this method has no effect. * * @return whether the channel status changed as a result of the call. */ boolean abort(); /** * Closes the channel and abort the transfer of data, thus aborting the routine invocation and * causing the specified throwable to be passed as the abortion reason.
* The throwable, unless it extends the base {@link com.github.dm.jrt.channel.RoutineException * RoutineException}, will be wrapped as the cause of an * {@link com.github.dm.jrt.channel.AbortException AbortException} instance. *

* Note that, in case the channel was already closed, the call to this method has no effect. * * @param reason the throwable object identifying the reason of the invocation abortion. * @return whether the channel status changed as a result of the call. */ boolean abort(@Nullable Throwable reason); /** * Checks if the channel is empty, that is, no data is stored in it. * * @return whether the channel is empty. */ boolean isEmpty(); /** * Checks if the channel is open, that is, more data are expected to be passed to it. * * @return whether the channel is open. */ boolean isOpen(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy