/* * Copyright (c) 2016 Fraunhofer IGD * * All rights reserved. This program and the accompanying materials are made * available under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the License, * or (at your option) any later version. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution. If not, see <http://www.gnu.org/licenses/>. * * Contributors: * Fraunhofer IGD <http://www.igd.fraunhofer.de/> */ package de.fhg.igd.mapviewer.concurrency; import java.util.List; /** * Job that allows handling partial results using a {@link Callback} * * @param <T> the partial result type * @author Simon Templer */ public abstract class ContinuousJob<T> extends AbstractContinuousJob<T> { private final Callback<List<T>> callback; /** * Constructor * * @param name the job name * @param callback the call-back for partial results */ public ContinuousJob(String name, Callback<List<T>> callback) { super(name); this.callback = callback; } /** * @see AbstractContinuousJob#error(Throwable) */ @Override protected void error(Throwable e) { callback.failed(e); } /** * @see AbstractContinuousJob#process(List) */ @Override protected void process(List<T> currentResults) { callback.done(currentResults); } }