00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #include "threadpool/timer.h"
00029
00030 BEGIN_TERIMBER_NAMESPACE
00031 #pragma pack(4)
00032
00033 timer::timer() :
00034 _ident(0),
00035 _interval(INFINITE),
00036 _multiplier(1),
00037 _trigger(1),
00038 _reactivate(false),
00039 _first(false),
00040 _callback(0)
00041 {
00042 }
00043
00044 timer::~timer()
00045 {
00046 deactivate();
00047 }
00048
00049 void
00050 timer::activate(timer_callback* callback, size_t ident, size_t interval, size_t multiplier, bool reactivate)
00051 {
00052 assert(callback);
00053
00054 deactivate();
00055
00056 mutex_keeper keeper(_mtx);
00057 _callback = callback;
00058 _ident = ident;
00059 _interval = interval;
00060 _reactivate = reactivate;
00061
00062 _multiplier = multiplier == 0 ? 1 : multiplier;
00063
00064 _trigger = _multiplier;
00065 _first = false;
00066
00067
00068 job_task task(this, 0, _interval, 0);
00069
00070 _thread.start();
00071
00072 _thread.assign_job(task);
00073 }
00074
00075 void
00076 timer::deactivate()
00077 {
00078 mutex_keeper keeper(_mtx);
00079
00080 _thread.cancel_job();
00081
00082 _thread.stop();
00083 }
00084
00085
00086 bool
00087 timer::v_has_job(size_t ident, void* user_data)
00088 {
00089 return !_trigger--;
00090 }
00091
00092
00093 void
00094 timer::v_do_job(size_t ident, void* user_data)
00095 {
00096
00097 if (!_first || _reactivate)
00098 _callback->notify(_ident, _interval, _multiplier);
00099
00100 if (!_first)
00101 _first = true;
00102
00103
00104 _trigger = _multiplier;
00105 }
00106
00107 #pragma pack()
00108 END_TERIMBER_NAMESPACE
00109