/*
* This file is part of aion-unique <aion-unique.org>.
*
* aion-unique is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* aion-unique 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with aion-unique. If not, see <http://www.gnu.org/licenses/>.
*/
package com.aionemu.commons.utils.concurrent;
import java.util.concurrent.TimeUnit;
import org.apache.log4j.Logger;
import javolution.text.TextBuilder;
/**
* @author NB4L1
*/
public class ExecuteWrapper implements Runnable
{
private static final Logger log = Logger.getLogger(ExecuteWrapper.class);
private final Runnable runnable;
public ExecuteWrapper(Runnable runnable)
{
this.runnable = runnable;
}
@Override
public final void run()
{
ExecuteWrapper.execute(runnable, getMaximumRuntimeInMillisecWithoutWarning());
}
protected long getMaximumRuntimeInMillisecWithoutWarning()
{
return Long.MAX_VALUE;
}
public static void execute(Runnable runnable)
{
execute(runnable, Long.MAX_VALUE);
}
public static void execute(Runnable runnable, long maximumRuntimeInMillisecWithoutWarning)
{
long begin = System.nanoTime();
try
{
runnable.run();
}
catch(RuntimeException e)
{
log.warn("Exception in a Runnable execution:", e);
}
finally
{
long runtimeInNanosec = System.nanoTime() - begin;
Class<? extends Runnable> clazz = runnable.getClass();
RunnableStatsManager.handleStats(clazz, runtimeInNanosec);
long runtimeInMillisec = TimeUnit.NANOSECONDS.toMillis(runtimeInNanosec);
if(runtimeInMillisec > maximumRuntimeInMillisecWithoutWarning)
{
TextBuilder tb = TextBuilder.newInstance();
tb.append(clazz);
tb.append(" - execution time: ");
tb.append(runtimeInMillisec);
tb.append("msec");
log.warn(tb);
TextBuilder.recycle(tb);
}
}
}
}