2024-04-18 19:20:39 +00:00
|
|
|
#include "Throttle.h"
|
|
|
|
#include <Arduino.h>
|
|
|
|
|
|
|
|
/// @brief Execute a function throttled to a minimum interval
|
|
|
|
/// @param lastExecutionMs Pointer to the last execution time in milliseconds
|
|
|
|
/// @param minumumIntervalMs Minimum execution interval in milliseconds
|
|
|
|
/// @param throttleFunc Function to execute if the execution is not deferred
|
|
|
|
/// @param onDefer Default to NULL, execute the function if the execution is deferred
|
|
|
|
/// @return true if the function was executed, false if it was deferred
|
|
|
|
bool Throttle::execute(uint32_t *lastExecutionMs, uint32_t minumumIntervalMs, void (*throttleFunc)(void), void (*onDefer)(void))
|
|
|
|
{
|
|
|
|
if (*lastExecutionMs == 0) {
|
|
|
|
*lastExecutionMs = millis();
|
|
|
|
throttleFunc();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
uint32_t now = millis();
|
|
|
|
|
|
|
|
if ((now - *lastExecutionMs) >= minumumIntervalMs) {
|
|
|
|
throttleFunc();
|
|
|
|
*lastExecutionMs = now;
|
|
|
|
return true;
|
|
|
|
} else if (onDefer != NULL) {
|
|
|
|
onDefer();
|
|
|
|
}
|
|
|
|
return false;
|
2024-09-23 13:58:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// @brief Check if the last execution time is within the interval
|
|
|
|
/// @param lastExecutionMs The last execution time in milliseconds
|
|
|
|
/// @param timeSpanMs The interval in milliseconds of the timespan
|
|
|
|
bool Throttle::isWithinTimespanMs(uint32_t lastExecutionMs, uint32_t timeSpanMs)
|
|
|
|
{
|
|
|
|
return (millis() - lastExecutionMs) < timeSpanMs;
|
2024-04-18 19:20:39 +00:00
|
|
|
}
|