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

com.github.dm.jrt.operator.IntervalInvocationFactory Maven / Gradle / Ivy

/*
 * Copyright 2016 Davide Maestroni
 *
 * 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.operator;

import com.github.dm.jrt.core.channel.Channel;
import com.github.dm.jrt.core.common.Backoff;
import com.github.dm.jrt.core.invocation.Invocation;
import com.github.dm.jrt.core.invocation.InvocationFactory;
import com.github.dm.jrt.core.invocation.TemplateInvocation;
import com.github.dm.jrt.core.util.ConstantConditions;

import org.jetbrains.annotations.NotNull;

import java.util.concurrent.TimeUnit;

import static com.github.dm.jrt.core.util.Reflection.asArgs;

/**
 * Factory of invocation passing on data after an interval specified by a backoff policy.
 * 

* Created by davide-maestroni on 09/07/2016. * * @param the data type. */ class IntervalInvocationFactory extends InvocationFactory { private final Backoff mBackoff; /** * Constructor. * * @param backoff the interval backoff. */ IntervalInvocationFactory(@NotNull final Backoff backoff) { super(asArgs(ConstantConditions.notNull("backoff instance", backoff))); mBackoff = backoff; } @NotNull @Override public Invocation newInvocation() throws Exception { return new IntervalInvocation(mBackoff); } /** * Routine invocation passing on data after an interval specified by a backoff policy. * * @param the data type. */ private static class IntervalInvocation extends TemplateInvocation { private final Backoff mBackoff; private int mCount; private long mStartTime; /** * Constructor. * * @param backoff the interval backoff. */ private IntervalInvocation(@NotNull final Backoff backoff) { mBackoff = backoff; } @Override public void onInput(final DATA input, @NotNull final Channel result) { result.after( Math.max(0, mStartTime + mBackoff.getDelay(++mCount) - System.currentTimeMillis()), TimeUnit.MILLISECONDS).pass(input); } @Override public void onRestart() { mStartTime = System.currentTimeMillis(); mCount = 0; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy