| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206 |
- #include "archive_favorites.h"
- #include "archive_browser.h"
- uint16_t archive_favorites_count(void* context) {
- furi_assert(context);
- FileWorker* file_worker = file_worker_alloc(true);
- string_t buffer;
- string_init(buffer);
- bool result = file_worker_open(file_worker, ARCHIVE_FAV_PATH, FSAM_READ, FSOM_OPEN_EXISTING);
- uint16_t lines = 0;
- if(result) {
- while(1) {
- if(!file_worker_read_until(file_worker, buffer, '\n')) {
- break;
- }
- if(!string_size(buffer)) {
- break;
- }
- ++lines;
- }
- }
- string_clear(buffer);
- file_worker_close(file_worker);
- file_worker_free(file_worker);
- return lines;
- }
- bool archive_favorites_read(void* context) {
- furi_assert(context);
- ArchiveBrowserView* browser = context;
- FileWorker* file_worker = file_worker_alloc(true);
- string_t buffer;
- FileInfo file_info;
- string_init(buffer);
- bool result = file_worker_open(file_worker, ARCHIVE_FAV_PATH, FSAM_READ, FSOM_OPEN_EXISTING);
- if(result) {
- while(1) {
- if(!file_worker_read_until(file_worker, buffer, '\n')) {
- break;
- }
- if(!string_size(buffer)) {
- break;
- }
- archive_add_item(browser, &file_info, string_get_cstr(buffer));
- string_reset(buffer);
- }
- }
- string_clear(buffer);
- file_worker_close(file_worker);
- file_worker_free(file_worker);
- return result;
- }
- bool archive_favorites_delete(const char* format, ...) {
- string_t buffer;
- string_t filename;
- va_list args;
- va_start(args, format);
- string_init_vprintf(filename, format, args);
- va_end(args);
- string_init(buffer);
- FileWorker* file_worker = file_worker_alloc(true);
- bool result = file_worker_open(file_worker, ARCHIVE_FAV_PATH, FSAM_READ, FSOM_OPEN_EXISTING);
- if(result) {
- while(1) {
- if(!file_worker_read_until(file_worker, buffer, '\n')) {
- break;
- }
- if(!string_size(buffer)) {
- break;
- }
- if(string_search(buffer, filename)) {
- archive_file_append(ARCHIVE_FAV_TEMP_PATH, "%s\n", string_get_cstr(buffer));
- }
- }
- }
- string_clear(buffer);
- string_clear(filename);
- file_worker_close(file_worker);
- file_worker_remove(file_worker, ARCHIVE_FAV_PATH);
- file_worker_rename(file_worker, ARCHIVE_FAV_TEMP_PATH, ARCHIVE_FAV_PATH);
- file_worker_free(file_worker);
- return result;
- }
- bool archive_is_favorite(const char* format, ...) {
- string_t buffer;
- string_t filename;
- va_list args;
- va_start(args, format);
- string_init_vprintf(filename, format, args);
- va_end(args);
- string_init(buffer);
- FileWorker* file_worker = file_worker_alloc(true);
- bool found = false;
- bool result = file_worker_open(file_worker, ARCHIVE_FAV_PATH, FSAM_READ, FSOM_OPEN_EXISTING);
- if(result) {
- while(1) {
- if(!file_worker_read_until(file_worker, buffer, '\n')) {
- break;
- }
- if(!string_size(buffer)) {
- break;
- }
- if(!string_search(buffer, filename)) {
- found = true;
- break;
- }
- }
- }
- string_clear(buffer);
- string_clear(filename);
- file_worker_close(file_worker);
- file_worker_free(file_worker);
- return found;
- }
- bool archive_favorites_rename(const char* file_path, const char* src, const char* dst) {
- furi_assert(file_path);
- furi_assert(src);
- furi_assert(dst);
- FileWorker* file_worker = file_worker_alloc(true);
- string_t path;
- string_t buffer;
- string_init(buffer);
- string_init(path);
- string_printf(path, "%s/%s", file_path, src);
- bool result = file_worker_open(file_worker, ARCHIVE_FAV_PATH, FSAM_READ, FSOM_OPEN_EXISTING);
- if(result) {
- while(1) {
- if(!file_worker_read_until(file_worker, buffer, '\n')) {
- break;
- }
- if(!string_size(buffer)) {
- break;
- }
- archive_file_append(
- ARCHIVE_FAV_TEMP_PATH,
- "%s\n",
- string_search(buffer, path) ? string_get_cstr(buffer) : dst);
- }
- }
- string_clear(buffer);
- string_clear(path);
- file_worker_close(file_worker);
- file_worker_remove(file_worker, ARCHIVE_FAV_PATH);
- file_worker_rename(file_worker, ARCHIVE_FAV_TEMP_PATH, ARCHIVE_FAV_PATH);
- file_worker_free(file_worker);
- return result;
- }
- void archive_add_to_favorites(const char* file_path) {
- furi_assert(file_path);
- archive_file_append(ARCHIVE_FAV_PATH, "%s\n", file_path);
- }
- void archive_favorites_save(void* context) {
- furi_assert(context);
- ArchiveBrowserView* browser = context;
- FileWorker* file_worker = file_worker_alloc(true);
- for(size_t i = 0; i < archive_file_array_size(browser); i++) {
- ArchiveFile_t* item = archive_get_file_at(browser, i);
- archive_file_append(ARCHIVE_FAV_TEMP_PATH, "%s\n", string_get_cstr(item->name));
- }
- file_worker_remove(file_worker, ARCHIVE_FAV_PATH);
- file_worker_rename(file_worker, ARCHIVE_FAV_TEMP_PATH, ARCHIVE_FAV_PATH);
- file_worker_free(file_worker);
- }
|