Add flag for checking if task was initialized #1

Open
CommanderRedYT wants to merge 2 commits from CommanderRedYT/patch-1 into main
2 changed files with 4 additions and 3 deletions

View File

@ -21,9 +21,9 @@ SchedulerTask::SchedulerTask(const char *name, void (&setupCallback)(), void (&l
void SchedulerTask::loop() void SchedulerTask::loop()
{ {
if (m_lastUpdate && espchrono::ago(*m_lastUpdate) < m_loopInterval) if (!m_wasInitialized || (m_lastUpdate && espchrono::ago(*m_lastUpdate) < m_loopInterval))
return; return;
ESP_LOGV(TAG, "start %s", m_name); ESP_LOGV(TAG, "start %s", m_name);
if (m_intervalImportant) if (m_intervalImportant)

View File

@ -23,7 +23,7 @@ public:
const std::chrono::milliseconds &maxElapsed() const { return m_maxElapsed; } const std::chrono::milliseconds &maxElapsed() const { return m_maxElapsed; }
int callCount() const { return m_callCount; } int callCount() const { return m_callCount; }
void setup() const { m_setupCallback(); } void setup() const { m_setupCallback(); m_wasInitialized = true; }
void loop(); void loop();
void pushStats(bool printTask); void pushStats(bool printTask);
@ -47,5 +47,6 @@ private:
std::chrono::milliseconds m_totalElapsedTemp; std::chrono::milliseconds m_totalElapsedTemp;
std::chrono::milliseconds m_maxElapsedTemp; std::chrono::milliseconds m_maxElapsedTemp;
int m_callCountTemp{}; int m_callCountTemp{};
bool m_wasInitialized{};
}; };
} // namespace espcpputils } // namespace espcpputils