ctkEAHandlerTasks_p.h 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*=============================================================================
  2. Library: CTK
  3. Copyright (c) German Cancer Research Center,
  4. Division of Medical and Biological Informatics
  5. Licensed under the Apache License, Version 2.0 (the "License");
  6. you may not use this file except in compliance with the License.
  7. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. =============================================================================*/
  15. #ifndef CTKEAHANDLERTASKS_P_H
  16. #define CTKEAHANDLERTASKS_P_H
  17. #include <QList>
  18. #include <service/event/ctkEvent.h>
  19. template<class HandlerTasks> class ctkEAHandlerTask;
  20. /**
  21. * The factory for event handler tasks. Implementations of this interface can be
  22. * used to create tasks that handle the delivery of events to event handlers.
  23. */
  24. template<class Impl>
  25. struct ctkEAHandlerTasks
  26. {
  27. /**
  28. * Create the handler tasks for the event. All matching event handlers must
  29. * be determined and delivery tasks for them returned.
  30. *
  31. * @param event The event for which' handlers delivery tasks must be created
  32. *
  33. * @return A delivery task for each handler that matches the given event
  34. */
  35. QList<ctkEAHandlerTask<Impl> > createHandlerTasks(const ctkEvent& event)
  36. {
  37. return static_cast<Impl*>(this)->createHandlerTasks(event);
  38. }
  39. virtual ~ctkEAHandlerTasks() {}
  40. };
  41. #endif // CTKEAHANDLERTASKS_P_H