Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
 /*
  * Copyright 2010-2013 Ning, Inc.
  *
  * Ning licenses this file to you 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.
 */
package com.ning.billing.commons.concurrent;
class WrappedCallable<T> implements Callable<T> {
    private final Logger log;
    private final Callable<T> callable;
    private WrappedCallable(final Logger logfinal Callable<T> callable) {
        this. = log;
        this. = callable;
    }
    public static <T> Callable<T> wrap(final Logger logfinal Callable<T> callable) {
        return callable instanceof WrappedCallable ? callable : new WrappedCallable<T>(logcallable);
    }
    @Override
    public T call() throws Exception {
        final Thread currentThread = Thread.currentThread();
        try {
            return .call();
        } catch (Exception e) {
            // since callables are expected to sometimes throw exceptions, log this at DEBUG instead of ERROR
            .debug(currentThread + " ended with an exception"e);
            throw e;
        } catch (Error e) {
            .error(currentThread + " ended with an exception"e);
            throw e;
        } finally {
            .debug("{} finished executing"currentThread);
        }
    }
New to GrepCode? Check out our FAQ X