mirror of
https://github.com/ByteWelder/Tactility.git
synced 2026-02-19 03:13:14 +00:00
* SdCard HAL refactored (#135) - Refactor SdCard HAL - introduce Lockable * Screenshot and FatFS improvements (#136) - Fix screenshots on ESP32 - Improve Screenshot service - Convert Screenshot app to class-based instead of structs - Screenshot app now automatically updates when task is finished - Enable FatFS long filename support * Re-use common log messages (#138) For consistency and binary size reduction * Toolbar spinner should get margin to the right * More TactilityC features (#139) * Rewrote Loader - Simplified Loader by removing custom threa - Created DispatcherThread - Move auto-starting apps to Boot app - Fixed Dispatcher bug where it could get stuck not processing new messages * Hide AP settings if the AP is not saved * Missing from previous commit * Replace LV_EVENT_CLICKED with LV_EVENT_SHORT_CLICKED * Refactored files app and created InputDialog (#140) - Changed Files app so that it has a View and State - Files app now allows for long-pressing on files to perform actions - Files app now has rename and delete actions - Created InputDialog app - Improved AlertDialog app layout
88 lines
2.1 KiB
C++
88 lines
2.1 KiB
C++
#include "Mutex.h"
|
|
#include "Timer.h"
|
|
|
|
#include "service/ServiceContext.h"
|
|
#include "TactilityCore.h"
|
|
#include "TactilityHeadless.h"
|
|
#include "service/ServiceRegistry.h"
|
|
|
|
#include <cstdlib>
|
|
|
|
#define TAG "sdcard_service"
|
|
|
|
namespace tt::service::sdcard {
|
|
|
|
extern const ServiceManifest manifest;
|
|
|
|
struct ServiceData {
|
|
Mutex mutex;
|
|
std::unique_ptr<Timer> updateTimer;
|
|
hal::SdCard::State lastState = hal::SdCard::StateUnmounted;
|
|
|
|
bool lock(TickType_t timeout) const {
|
|
return mutex.acquire(timeout) == TtStatusOk;
|
|
}
|
|
|
|
void unlock() const {
|
|
tt_check(mutex.release() == TtStatusOk);
|
|
}
|
|
};
|
|
|
|
|
|
static void onUpdate(std::shared_ptr<void> context) {
|
|
auto sdcard = tt::hal::getConfiguration().sdcard;
|
|
if (sdcard == nullptr) {
|
|
return;
|
|
}
|
|
|
|
auto data = std::static_pointer_cast<ServiceData>(context);
|
|
|
|
if (!data->lock(50)) {
|
|
TT_LOG_W(TAG, LOG_MESSAGE_MUTEX_LOCK_FAILED);
|
|
return;
|
|
}
|
|
|
|
auto new_state = sdcard->getState();
|
|
|
|
if (new_state == hal::SdCard::StateError) {
|
|
TT_LOG_W(TAG, "Sdcard error - unmounting. Did you eject the card in an unsafe manner?");
|
|
sdcard->unmount();
|
|
}
|
|
|
|
if (new_state != data->lastState) {
|
|
data->lastState = new_state;
|
|
}
|
|
|
|
data->unlock();
|
|
}
|
|
|
|
static void onStart(ServiceContext& service) {
|
|
if (hal::getConfiguration().sdcard != nullptr) {
|
|
auto data = std::make_shared<ServiceData>();
|
|
service.setData(data);
|
|
|
|
data->updateTimer = std::make_unique<Timer>(Timer::TypePeriodic, onUpdate, data);
|
|
// We want to try and scan more often in case of startup or scan lock failure
|
|
data->updateTimer->start(1000);
|
|
} else {
|
|
TT_LOG_I(TAG, "task not started due to config");
|
|
}
|
|
}
|
|
|
|
static void onStop(ServiceContext& service) {
|
|
auto data = std::static_pointer_cast<ServiceData>(service.getData());
|
|
if (data->updateTimer != nullptr) {
|
|
// Stop thread
|
|
data->updateTimer->stop();
|
|
data->updateTimer = nullptr;
|
|
}
|
|
}
|
|
|
|
extern const ServiceManifest manifest = {
|
|
.id = "sdcard",
|
|
.onStart = onStart,
|
|
.onStop = onStop
|
|
};
|
|
|
|
} // namespace
|