/**
* DataCleaner (community edition)
* Copyright (C) 2014 Neopost - Customer Information Management
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.datacleaner.result.renderer;
import javax.inject.Inject;
import org.datacleaner.api.AnalyzerResult;
import org.datacleaner.api.AnalyzerResultFuture;
import org.datacleaner.api.Renderer;
import org.datacleaner.api.RendererBean;
import org.datacleaner.api.RendererPrecedence;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* A renderer for analyzers returning {@link AnalyzerFutureResult}. Waits for the Future to
* finish processing and renders the wrapped {@link AnalyzerResult}.
*/
@RendererBean(TextRenderingFormat.class)
public class ToStringFutureTextRenderer implements Renderer<AnalyzerResultFuture<? extends AnalyzerResult>, String> {
Logger logger = LoggerFactory.getLogger(ToStringFutureTextRenderer.class);
@Inject
RendererFactory _rendererFactory;
@Override
public RendererPrecedence getPrecedence(final AnalyzerResultFuture<? extends AnalyzerResult> renderable) {
return RendererPrecedence.MEDIUM;
}
@Override
public String render(final AnalyzerResultFuture<? extends AnalyzerResult> renderable) {
final StringBuilder resultString = new StringBuilder();
try {
final AnalyzerResult result = renderable.get();
final Renderer<? super AnalyzerResult, ? extends CharSequence> renderer =
_rendererFactory.getRenderer(result, TextRenderingFormat.class);
if (renderer != null) {
logger.debug("renderer.render({})", result);
final CharSequence component = renderer.render(result);
resultString.append(component);
return resultString.toString();
} else {
final String message = "No renderer found for result type " + result.getClass().getName();
logger.error(message);
throw new IllegalStateException(message);
}
} catch (final RuntimeException error) {
final String message = "Unable to fetch result";
logger.error(message, error);
throw new IllegalStateException(message, error);
}
}
}