|  | /* | 
|  | *  Copyright 2004 The WebRTC Project Authors. All rights reserved. | 
|  | * | 
|  | *  Use of this source code is governed by a BSD-style license | 
|  | *  that can be found in the LICENSE file in the root of the source | 
|  | *  tree. An additional intellectual property rights grant can be found | 
|  | *  in the file PATENTS.  All contributing project authors may | 
|  | *  be found in the AUTHORS file in the root of the source tree. | 
|  | */ | 
|  |  | 
|  | #ifndef WEBRTC_BASE_WORKER_H_ | 
|  | #define WEBRTC_BASE_WORKER_H_ | 
|  |  | 
|  | #include "webrtc/base/constructormagic.h" | 
|  | #include "webrtc/base/messagehandler.h" | 
|  |  | 
|  | namespace rtc { | 
|  |  | 
|  | class Thread; | 
|  |  | 
|  | // A worker is an object that performs some specific long-lived task in an | 
|  | // event-driven manner. | 
|  | // The only method that should be considered thread-safe is HaveWork(), which | 
|  | // allows you to signal the availability of work from any thread. All other | 
|  | // methods are thread-hostile. Specifically: | 
|  | // StartWork()/StopWork() should not be called concurrently with themselves or | 
|  | // each other, and it is an error to call them while the worker is running on | 
|  | // a different thread. | 
|  | // The destructor may not be called if the worker is currently running | 
|  | // (regardless of the thread), but you can call StopWork() in a subclass's | 
|  | // destructor. | 
|  | class Worker : private MessageHandler { | 
|  | public: | 
|  | Worker(); | 
|  |  | 
|  | // Destroys this Worker, but it must have already been stopped via StopWork(). | 
|  | ~Worker() override; | 
|  |  | 
|  | // Attaches the worker to the current thread and begins processing work if not | 
|  | // already doing so. | 
|  | bool StartWork(); | 
|  | // Stops processing work if currently doing so and detaches from the current | 
|  | // thread. | 
|  | bool StopWork(); | 
|  |  | 
|  | protected: | 
|  | // Signal that work is available to be done. May only be called within the | 
|  | // lifetime of a OnStart()/OnStop() pair. | 
|  | void HaveWork(); | 
|  |  | 
|  | // These must be implemented by a subclass. | 
|  | // Called on the worker thread to start working. | 
|  | virtual void OnStart() = 0; | 
|  | // Called on the worker thread when work has been signalled via HaveWork(). | 
|  | virtual void OnHaveWork() = 0; | 
|  | // Called on the worker thread to stop working. Upon return, any pending | 
|  | // OnHaveWork() calls are cancelled. | 
|  | virtual void OnStop() = 0; | 
|  |  | 
|  | private: | 
|  | // Inherited from MessageHandler. | 
|  | void OnMessage(Message* msg) override; | 
|  |  | 
|  | // The thread that is currently doing the work. | 
|  | Thread *worker_thread_; | 
|  |  | 
|  | DISALLOW_COPY_AND_ASSIGN(Worker); | 
|  | }; | 
|  |  | 
|  | }  // namespace rtc | 
|  |  | 
|  | #endif  // WEBRTC_BASE_WORKER_H_ |