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

org.javabits.yar.guice.Concurrents Maven / Gradle / Ivy

package org.javabits.yar.guice;

import org.javabits.yar.Id;

import java.util.concurrent.Callable;
import java.util.concurrent.CancellationException;
import java.util.concurrent.ExecutionException;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 * Created with IntelliJ IDEA.
 * User: rogilles
 * Date: 10/22/13
 * Time: 3:48 PM
 * To change this template use File | Settings | File Templates.
 */
public final class Concurrents {
    private static final Logger LOG = Logger.getLogger(Concurrents.class.getName());

    private Concurrents() {
        throw new AssertionError("Not for you!");
    }

    public static void executeWithLog(Callable callable, Id id, String message) {
        try {
            callable.call();
        } catch (CancellationException e) {
            LOG.log(Level.SEVERE, String.format("%s canceled: %s", message, id), e);
        } catch (ExecutionException | RuntimeException e) {
            LOG.log(Level.SEVERE, String.format("%s error: %s", message, id), e);
        } catch (InterruptedException e) {
            LOG.log(Level.SEVERE, String.format("%s interrupted: %s", message, id), e);
            Thread.currentThread().interrupt();
        } catch (Exception e) {
            LOG.log(Level.SEVERE, String.format("%s exception: %s", message, id), e);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy