Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
 /*
  * Copyright 2011 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.mogwee.executors;
class WrappedCallable<T> implements Callable<T>
    private final Logger log;
    private final Callable<T> callable;
    private WrappedCallable(Logger logCallable<T> callable)
    {
        this. = log;
        this. = callable;
    }
    public static <T> Callable<T> wrap(Logger logCallable<T> callable)
    {
        return callable instanceof WrappedCallable ? callable : new WrappedCallable<T>(logcallable);
    }
    @Override
    public T call() throws Exception
    {
        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
            .debugf(e"%s ended with an exception"currentThread);
            throw e;
        }
        catch (Error e) {
            .errorf(e"%s ended with an exception"currentThread);
            throw e;
        }
        finally {
            .debugf("%s finished executing"currentThread);
        }
    }
New to GrepCode? Check out our FAQ X