PITimer slot optimize
This commit is contained in:
@@ -122,13 +122,13 @@ PITimer::PITimer(): PIObject() {
|
|||||||
|
|
||||||
PITimer::PITimer(std::function<void(int)> func) {
|
PITimer::PITimer(std::function<void(int)> func) {
|
||||||
initFirst();
|
initFirst();
|
||||||
ret_func = func;
|
ret_func_delim = std::move(func);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
PITimer::PITimer(std::function<void()> func) {
|
PITimer::PITimer(std::function<void()> func) {
|
||||||
initFirst();
|
initFirst();
|
||||||
ret_func = [func](int) { func(); };
|
ret_func = std::move(func);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -224,7 +224,8 @@ void PITimer::adjustTimes() {
|
|||||||
void PITimer::execTick() {
|
void PITimer::execTick() {
|
||||||
if (!isRunning()) return;
|
if (!isRunning()) return;
|
||||||
if (lockRun) lock();
|
if (lockRun) lock();
|
||||||
if (ret_func) ret_func(1);
|
if (ret_func) ret_func();
|
||||||
|
if (ret_func_delim) ret_func_delim(1);
|
||||||
tick(1);
|
tick(1);
|
||||||
tickEvent(1);
|
tickEvent(1);
|
||||||
if (callEvents) maybeCallQueuedEvents();
|
if (callEvents) maybeCallQueuedEvents();
|
||||||
@@ -233,8 +234,8 @@ void PITimer::execTick() {
|
|||||||
i.tick = 0;
|
i.tick = 0;
|
||||||
if (i.func)
|
if (i.func)
|
||||||
i.func(i.delim);
|
i.func(i.delim);
|
||||||
else if (ret_func)
|
else if (ret_func_delim)
|
||||||
ret_func(i.delim);
|
ret_func_delim(i.delim);
|
||||||
tick(i.delim);
|
tick(i.delim);
|
||||||
tickEvent(i.delim);
|
tickEvent(i.delim);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -126,13 +126,11 @@ public:
|
|||||||
|
|
||||||
//! \~english Sets a tick callback that ignores the delimiter value.
|
//! \~english Sets a tick callback that ignores the delimiter value.
|
||||||
//! \~russian Устанавливает обратный вызов тика, игнорирующий значение делителя.
|
//! \~russian Устанавливает обратный вызов тика, игнорирующий значение делителя.
|
||||||
void setSlot(std::function<void()> func) {
|
void setSlot(std::function<void()> func) { ret_func = std::move(func); }
|
||||||
ret_func = [func](int) { func(); };
|
|
||||||
}
|
|
||||||
|
|
||||||
//! \~english Sets a tick callback that receives the current delimiter value.
|
//! \~english Sets a tick callback that receives the current delimiter value.
|
||||||
//! \~russian Устанавливает обратный вызов тика, принимающий текущее значение делителя.
|
//! \~russian Устанавливает обратный вызов тика, принимающий текущее значение делителя.
|
||||||
void setSlot(std::function<void(int)> func) { ret_func = func; }
|
void setSlot(std::function<void(int)> func) { ret_func_delim = std::move(func); }
|
||||||
|
|
||||||
//! \~english Enables locking of the internal mutex around tick processing.
|
//! \~english Enables locking of the internal mutex around tick processing.
|
||||||
//! \~russian Включает блокировку внутреннего мьютекса вокруг обработки тиков.
|
//! \~russian Включает блокировку внутреннего мьютекса вокруг обработки тиков.
|
||||||
@@ -245,7 +243,8 @@ protected:
|
|||||||
PIMutex mutex_;
|
PIMutex mutex_;
|
||||||
PISystemTime m_interval, m_interval_x5;
|
PISystemTime m_interval, m_interval_x5;
|
||||||
PISystemTime m_time_next;
|
PISystemTime m_time_next;
|
||||||
std::function<void(int)> ret_func = nullptr;
|
std::function<void()> ret_func = nullptr;
|
||||||
|
std::function<void(int)> ret_func_delim = nullptr;
|
||||||
PIVector<Delimiter> delims;
|
PIVector<Delimiter> delims;
|
||||||
PIConditionVariable event;
|
PIConditionVariable event;
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user