Collage  1.7.0
High-performance C++ library for developing object-oriented distributed applications.
worker.h
1 
2 /* Copyright (c) 2011-2014, Stefan Eilemann <eile@eyescale.ch>
3  *
4  * This file is part of Collage <https://github.com/Eyescale/Collage>
5  *
6  * This library is free software; you can redistribute it and/or modify it under
7  * the terms of the GNU Lesser General Public License version 2.1 as published
8  * by the Free Software Foundation.
9  *
10  * This library is distributed in the hope that it will be useful, but WITHOUT
11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12  * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
13  * details.
14  *
15  * You should have received a copy of the GNU Lesser General Public License
16  * along with this library; if not, write to the Free Software Foundation, Inc.,
17  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18  */
19 
20 #ifndef CO_WORKER_H
21 #define CO_WORKER_H
22 
23 #include <co/api.h> // CO_API definition
24 #include <co/types.h>
25 #include <limits.h>
26 #include <lunchbox/thread.h> // base class
27 
28 #ifdef COLLAGE_SHARED
29 #define CO_WORKER_API CO_API
30 #else
31 #define CO_WORKER_API
32 #endif
33 
34 namespace co
35 {
37 template <class Q>
38 class WorkerThread : public lunchbox::Thread
39 {
40 public:
42  explicit WorkerThread(const size_t maxSize = ULONG_MAX)
43  : _commands(maxSize)
44  {
45  }
46 
48  virtual ~WorkerThread() {}
50  Q* getWorkerQueue() { return &_commands; }
51 protected:
53  CO_WORKER_API void run() override;
54 
56  virtual bool stopRunning() { return false; }
58  virtual bool notifyIdle() { return false; }
59 private:
61  Q _commands;
62 };
63 
64 typedef WorkerThread<CommandQueue> Worker; // instantiated in worker.cpp
65 }
66 #endif // CO_WORKER_H
Defines export visibility macros for library Collage.
CO_WORKER_API void run() override
Definition: worker.ipp:26
WorkerThread(const size_t maxSize=ULONG_MAX)
Construct a new worker thread.
Definition: worker.h:42
A worker thread processing items out of a CommandQueue.
Definition: types.h:72
Object-oriented network library.
Definition: barrier.h:27
virtual bool stopRunning()
Definition: worker.h:56
virtual bool notifyIdle()
Definition: worker.h:58
virtual ~WorkerThread()
Destruct the worker.
Definition: worker.h:48
Q * getWorkerQueue()
Definition: worker.h:50