org.wisdom.executors.ScheduledTask.java Source code

Java tutorial

Introduction

Here is the source code for org.wisdom.executors.ScheduledTask.java

Source

/*
 * #%L
 * Wisdom-Framework
 * %%
 * Copyright (C) 2013 - 2015 Wisdom Framework
 * %%
 * 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.
 * #L%
 */
package org.wisdom.executors;

import com.google.common.util.concurrent.JdkFutureAdapters;
import com.google.common.util.concurrent.ListeningExecutorService;
import org.wisdom.api.concurrent.ManagedScheduledFutureTask;

import java.util.concurrent.Callable;
import java.util.concurrent.Delayed;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;

/**
 * Implementation of scheduled task.
 * Be aware that scheduled tasks do not support execution context.
 */
public class ScheduledTask<V> extends Task<V> implements ManagedScheduledFutureTask<V>, ScheduledFuture<V> {

    private final boolean periodic;
    private ScheduledFuture scheduledFuture;

    public ScheduledTask(ListeningExecutorService executor, Callable<V> callable, long hungTime, boolean periodic,
            AbstractManagedExecutorService parent) {
        super(executor, callable, null, hungTime, parent);
        this.periodic = periodic;
    }

    protected ScheduledTask(ListeningExecutorService executor, Runnable runnable, V result, long hungTime,
            boolean periodic, AbstractManagedExecutorService parent) {
        super(executor, runnable, result, null, hungTime, parent);
        this.periodic = periodic;

    }

    protected ScheduledTask<V> submittedScheduledTask(ScheduledFuture delegate) {
        this.submissionDate = System.currentTimeMillis();
        this.scheduledFuture = delegate;
        this.future = JdkFutureAdapters.listenInPoolThread(delegate);
        return this;
    }

    /**
     * Returns {@code true} if this task is periodic. A periodic task may
     * re-run according to some schedule. A non-periodic task can be
     * run only once.
     *
     * @return {@code true} if this task is periodic
     */
    @Override
    public boolean isPeriodic() {
        return periodic;
    }

    /**
     * Returns the remaining delay associated with this object, in the
     * given time unit.
     *
     * @param unit the time unit
     * @return the remaining delay; zero or negative values indicate
     * that the delay has already elapsed
     */
    @Override
    public long getDelay(TimeUnit unit) {
        return scheduledFuture.getDelay(unit);
    }

    @Override
    public int compareTo(Delayed o) {
        return scheduledFuture.compareTo(o);
    }

    /**
     * Wraps the enhanced callable as a runnable.
     * @return the wrapped runnable.
     */
    public Runnable asRunnable() {
        return new Runnable() {
            @Override
            public void run() {
                try {
                    callable.call();
                } catch (Exception e) {
                    throw new RuntimeException(e);
                }
            }
        };
    }
}