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

com.gh.bmd.jrt.routine.TemplateRoutine 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.gh.bmd.jrt.routine;

import com.gh.bmd.jrt.channel.OutputChannel;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;

/**
 * Empty abstract implementation of a routine.
 * 

* This class is useful to avoid the need of implementing some of the methods defined in the * interface. *

* Created by davide-maestroni on 10/17/14. * * @param the input data type. * @param the output data type. */ public abstract class TemplateRoutine implements Routine { @Nonnull public OutputChannel asyncCall() { return asyncInvoke().result(); } @Nonnull public OutputChannel asyncCall(@Nullable final INPUT input) { return asyncInvoke().pass(input).result(); } @Nonnull public OutputChannel asyncCall(@Nullable final INPUT... inputs) { return asyncInvoke().pass(inputs).result(); } @Nonnull public OutputChannel asyncCall(@Nullable final Iterable inputs) { return asyncInvoke().pass(inputs).result(); } @Nonnull public OutputChannel asyncCall(@Nullable final OutputChannel inputs) { return asyncInvoke().pass(inputs).result(); } @Nonnull public OutputChannel parallelCall() { return parallelInvoke().result(); } @Nonnull public OutputChannel parallelCall(@Nullable final INPUT input) { return parallelInvoke().pass(input).result(); } @Nonnull public OutputChannel parallelCall(@Nullable final INPUT... inputs) { return parallelInvoke().pass(inputs).result(); } @Nonnull public OutputChannel parallelCall(@Nullable final Iterable inputs) { return parallelInvoke().pass(inputs).result(); } @Nonnull public OutputChannel parallelCall( @Nullable final OutputChannel inputs) { return parallelInvoke().pass(inputs).result(); } public void purge() { } @Nonnull public OutputChannel syncCall() { return syncInvoke().result(); } @Nonnull public OutputChannel syncCall(@Nullable final INPUT input) { return syncInvoke().pass(input).result(); } @Nonnull public OutputChannel syncCall(@Nullable final INPUT... inputs) { return syncInvoke().pass(inputs).result(); } @Nonnull public OutputChannel syncCall(@Nullable final Iterable inputs) { return syncInvoke().pass(inputs).result(); } @Nonnull public OutputChannel syncCall(@Nullable final OutputChannel inputs) { return syncInvoke().pass(inputs).result(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy