summaryrefslogtreecommitdiff
path: root/src/lua/file_iterator.cpp
diff options
context:
space:
mode:
authorailurux <ailuruxx@gmail.com>2024-05-06 12:36:16 +1000
committerailurux <ailuruxx@gmail.com>2024-05-06 12:36:16 +1000
commiteeb3f2d406a951b423b83f559fe749df0b4f745a (patch)
tree8c4174f5fefcfa7aceb5afea70f0064894126aa7 /src/lua/file_iterator.cpp
parentfb3d6a7b86991fe38da9a2741db8801785aa4c1b (diff)
downloadtangara-fw-eeb3f2d406a951b423b83f559fe749df0b4f745a.tar.gz
WIP: File browser, needs bug fixes
Diffstat (limited to 'src/lua/file_iterator.cpp')
-rw-r--r--src/lua/file_iterator.cpp31
1 files changed, 18 insertions, 13 deletions
diff --git a/src/lua/file_iterator.cpp b/src/lua/file_iterator.cpp
index 8de1a923..58b256b2 100644
--- a/src/lua/file_iterator.cpp
+++ b/src/lua/file_iterator.cpp
@@ -17,12 +17,13 @@ namespace database {
FileIterator::FileIterator(std::string filepath)
: original_path_(filepath),
- current_()
+ current_(),
+ offset_(-1)
{
auto lock = drivers::acquire_spi();
- const TCHAR* next_path = static_cast<const TCHAR*>(filepath.c_str());
- FRESULT res = f_opendir(&dir_, next_path);
+ const TCHAR* path = static_cast<const TCHAR*>(filepath.c_str());
+ FRESULT res = f_opendir(&dir_, path);
if (res != FR_OK) {
ESP_LOGE(kTag, "Error opening directory: %s", filepath.c_str());
}
@@ -42,36 +43,40 @@ auto FileIterator::next() -> void {
}
auto FileIterator::prev() -> void {
- iterate(true);
+ if (offset_ == 0) {
+ current_.reset();
+ return;
+ }
+ f_rewinddir(&dir_);
+ auto new_offset = offset_-1;
+ offset_ = -1;
+ for (int i = 0; i < new_offset; i++) {
+ iterate(false);
+ }
}
auto FileIterator::iterate(bool reverse) -> bool {
FILINFO info;
- if (reverse) {
- f_rewinddir(&dir_);
- }
{
auto lock = drivers::acquire_spi();
auto res = f_readdir(&dir_, &info);
if (res != FR_OK) {
- ESP_LOGI(kTag, "AAAAAAAAAAAAAAAAAAA");
- ESP_LOGI(kTag, "%d", res);
+ ESP_LOGE(kTag, "Error reading directory. Error: %d", res);
return false;
}
}
if (info.fname[0] == 0) {
// End of directory
+ // Set value to nil
current_.reset();
- ESP_LOGI(kTag, "End of dir");
-
} else {
// Update current value
- ESP_LOGI(kTag, "File: %s", info.fname);
+ offset_++;
current_ = FileEntry{
.isHidden = (info.fattrib & AM_HID) > 0,
.isDirectory = (info.fattrib & AM_DIR) > 0,
.isTrack = false, // TODO
- .filepath = original_path_ + info.fname,
+ .filepath = original_path_ + (original_path_.size()>0?"/":"") + info.fname,
};
}