ctkEAThreadFactoryUser_p.h 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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 CTKEATHREADFACTORYUSER_P_H
  16. #define CTKEATHREADFACTORYUSER_P_H
  17. #include <QMutex>
  18. #include "ctkEAThreadFactory_p.h"
  19. #include "ctkEAInterruptibleThread_p.h"
  20. /**
  21. * Base class for Executors and related classes that rely on thread factories.
  22. * Generally intended to be used as a mixin-style abstract class, but
  23. * can also be used stand-alone.
  24. */
  25. class ctkEAThreadFactoryUser
  26. {
  27. protected:
  28. mutable QMutex mutex;
  29. ctkEAThreadFactory* threadFactory;
  30. class DefaultThread : public ctkEAInterruptibleThread
  31. {
  32. public:
  33. DefaultThread(ctkEARunnable* command);
  34. void run();
  35. private:
  36. ctkEARunnable* command;
  37. bool deleteCmd;
  38. };
  39. class DefaultThreadFactory : public ctkEAThreadFactory
  40. {
  41. public:
  42. ctkEAInterruptibleThread* newThread(ctkEARunnable* command);
  43. };
  44. ctkEAThreadFactoryUser();
  45. ~ctkEAThreadFactoryUser();
  46. /**
  47. * Set the factory for creating new threads.
  48. * By default, new threads are created without any special priority,
  49. * threadgroup, or status parameters.
  50. * You can use a different factory
  51. * to change the kind of Thread class used or its construction
  52. * parameters.
  53. * @param factory the factory to use
  54. * @return the previous factory
  55. */
  56. ctkEAThreadFactory* setThreadFactory(ctkEAThreadFactory* factory);
  57. /**
  58. * Get the factory for creating new threads.
  59. */
  60. ctkEAThreadFactory* getThreadFactory();
  61. };
  62. #endif // CTKEATHREADFACTORYUSER_P_H