View Javadoc

1   /*
2    * $Id: WorkExecutor.java 19191 2010-08-25 21:05:23Z tcarlson $
3    * --------------------------------------------------------------------------------------
4    * Copyright (c) MuleSoft, Inc.  All rights reserved.  http://www.mulesoft.com
5    *
6    * The software in this package is published under the terms of the CPAL v1.0
7    * license, a copy of which has been included with this distribution in the
8    * LICENSE.txt file.
9    */
10  
11  /**
12   *
13   * Copyright 2004 The Apache Software Foundation
14   *
15   *  Licensed under the Apache License, Version 2.0 (the "License");
16   *  you may not use this file except in compliance with the License.
17   *  You may obtain a copy of the License at
18   *
19   *     http://www.apache.org/licenses/LICENSE-2.0
20   *
21   *  Unless required by applicable law or agreed to in writing, software
22   *  distributed under the License is distributed on an "AS IS" BASIS,
23   *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
24   *  See the License for the specific language governing permissions and
25   *  limitations under the License.
26   */
27  
28  package org.mule.api.work;
29  
30  import org.mule.work.WorkerContext;
31  
32  import javax.resource.spi.work.WorkException;
33  
34  import edu.emory.mathcs.backport.java.util.concurrent.Executor;
35  
36  /**
37   * <code>WorkExecutor</code> TODO
38   */
39  public interface WorkExecutor
40  {
41  
42      /**
43       * This method must be implemented by sub-classes in order to provide the
44       * relevant synchronization policy. It is called by the executeWork template
45       * method.
46       * 
47       * @param work Work to be executed.
48       * @throws javax.resource.spi.work.WorkException Indicates that the work has
49       *             failed.
50       * @throws InterruptedException Indicates that the thread in charge of the
51       *             execution of the specified work has been interrupted.
52       */
53      void doExecute(WorkerContext work, Executor executor) throws WorkException, InterruptedException;
54  
55  }