| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 | 
							- /*=============================================================================
 
-   Library: CTK
 
-   Copyright (c) German Cancer Research Center,
 
-     Division of Medical and Biological Informatics
 
-   Licensed 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.
 
- =============================================================================*/
 
- #ifndef CTKEAASYNCDELIVERTASKS_P_H
 
- #define CTKEAASYNCDELIVERTASKS_P_H
 
- #include "ctkEADeliverTask_p.h"
 
- #include <dispatch/ctkEADefaultThreadPool_p.h>
 
- class ctkEARunnable;
 
- /**
 
-  * This class does the actual work of the asynchronous event dispatch.
 
-  */
 
- template<class SyncDeliverTasks, class HandlerTask>
 
- class ctkEAAsyncDeliverTasks : public ctkEADeliverTask<ctkEAAsyncDeliverTasks<SyncDeliverTasks,HandlerTask>, HandlerTask>
 
- {
 
- private:
 
-   /** The thread pool to use to spin-off new threads. */
 
-   ctkEADefaultThreadPool* pool;
 
-   /**
 
-    * The deliver task for actually delivering the events. This
 
-    * is the sync deliver tasks as this has all the code for timeout
 
-    * handling etc.
 
-    */
 
-   typedef ctkEADeliverTask<SyncDeliverTasks, HandlerTask> DeliverTask;
 
-   DeliverTask* deliver_task;
 
-   /** A map of running threads currently delivering async events. */
 
-   QHash<QThread*, ctkEARunnable*> running_threads;
 
-   QMutex running_threads_mutex;
 
- public:
 
-   /**
 
-    * The constructor of the class that will use the asynchronous.
 
-    *
 
-    * @param pool The thread pool used to spin-off new asynchronous event
 
-    *        dispatching threads in case of timeout or that the asynchronous event
 
-    *        dispatching thread is used to send a synchronous event
 
-    * @param deliverTask The deliver tasks for dispatching the event.
 
-    */
 
-   ctkEAAsyncDeliverTasks(ctkEADefaultThreadPool* pool, DeliverTask* deliverTask);
 
-   /**
 
-    * This does not block an unrelated thread used to send a synchronous event.
 
-    *
 
-    * @param tasks The event handler dispatch tasks to execute
 
-    *
 
-    * @see ctkEADeliverTask#execute(const QList<HandlerTask>&)
 
-    */
 
-   void execute(const QList<HandlerTask>& tasks);
 
- private:
 
-   class TaskExecuter;
 
- };
 
- #include "ctkEAAsyncDeliverTasks.tpp"
 
- #endif // CTKEAASYNCDELIVERTASKS_P_H
 
 
  |