* FS-Api: removed datetime manipulation functions and most of the file flags * Filesystem: common proxy api * Filesystem: renamed to Storage. Work has begun on a glue layer. Added functions for reentrance. * Storage: sd mount and sd file open * Storage: sd file close * Storage: temporary test app * Storage: free filedata on close * Storage: sd file read and write * Storage: added internal storage (LittleFS) * Storage: renamed internal commands * Storage: seek, tell, truncate, size, sync, eof * Storage: error descriptions * Storage: directory management api (open, close, read, rewind) * Storage: common management api (stat, fs_stat, remove, rename, mkdir) * Dolphin app and Notifications app now use raw storage. * Storage: storage statuses renamed. Implemented sd card icon. * Storage: added raw sd-card api. * Storage settings: work started * Assets: use new icons approach * Storage settings: working storage settings * Storage: completely redesigned api, no longer sticking out FS_Api * Storage: more simplified api, getting error_id from file is hidden from user, pointer to api is hidden inside file * Storage: cli info and format commands * Storage-cli: file list * Storage: a simpler and more reliable api * FatFS: slightly lighter and faster config. Also disabled reentrancy and file locking functions. They moved to a storage service. * Storage-cli: accommodate to the new cli api. * Storage: filesystem api is separated into internal and common api. * Cli: added the ability to print the list of free heap blocks * Storage: uses a list instead of an array to store the StorageFile. Rewrote api calls to use semaphores instead of thread flags. * Storage settings: added the ability to benchmark the SD card. * Gui module file select: uses new storage api * Apps: removed deprecated sd_card_test application * Args lib: support for enquoted arguments * Dialogs: a new gui app for simple non-asynchronous apps * Dialogs: view holder for easy single view work * File worker: use new storage api * IButton and lfrrfid apps: save keys to any storage * Apps: fix ibutton and lfrfid stack, remove sd_card_test. * SD filesystem: app removed * File worker: fixed api pointer type * Subghz: loading assets using the new storage api * NFC: use the new storage api * Dialogs: the better api for the message element * Archive: use new storage api * Irda: changed assest path, changed app path * FileWorker: removed unused file_buf_cnt * Storage: copying and renaming files now works between storages * Storage cli: read, copy, remove, rename commands * Archive: removed commented code * Storage cli: write command * Applications: add SRV_STORAGE and SRV_DIALOGS * Internal-storage: removed * Storage: improved api * Storage app: changed api pointer from StorageApp to Storage * Storage: better file_id handling * Storage: more consistent errors * Loader: support for NULL icons * Storage: do nothing with the lfs file or directory if it is not open * Storage: fix typo * Storage: minor float usage cleanup, rename some symbols. * Storage: compact doxygen comments. Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			128 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			128 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#pragma once
 | 
						|
 | 
						|
#include "archive.h"
 | 
						|
#include <stdint.h>
 | 
						|
#include <furi.h>
 | 
						|
#include <gui/gui_i.h>
 | 
						|
#include <gui/view_dispatcher.h>
 | 
						|
#include <gui/modules/text_input.h>
 | 
						|
#include <loader/loader.h>
 | 
						|
 | 
						|
#include <m-string.h>
 | 
						|
#include <m-array.h>
 | 
						|
#include <storage/storage.h>
 | 
						|
#include "archive_views.h"
 | 
						|
#include "applications.h"
 | 
						|
 | 
						|
#define MAX_DEPTH 32
 | 
						|
#define MAX_FILES 100 //temp
 | 
						|
#define MAX_FILE_SIZE 128
 | 
						|
 | 
						|
typedef enum {
 | 
						|
    ArchiveViewMain,
 | 
						|
    ArchiveViewTextInput,
 | 
						|
    ArchiveViewTotal,
 | 
						|
} ArchiveViewEnum;
 | 
						|
 | 
						|
static const char* flipper_app_name[] = {
 | 
						|
    [ArchiveFileTypeIButton] = "iButton",
 | 
						|
    [ArchiveFileTypeNFC] = "NFC",
 | 
						|
    [ArchiveFileTypeSubOne] = "Sub-1 GHz",
 | 
						|
    [ArchiveFileTypeLFRFID] = "125 kHz RFID",
 | 
						|
    [ArchiveFileTypeIrda] = "Infrared",
 | 
						|
};
 | 
						|
 | 
						|
static const char* known_ext[] = {
 | 
						|
    [ArchiveFileTypeIButton] = ".ibtn",
 | 
						|
    [ArchiveFileTypeNFC] = ".nfc",
 | 
						|
    [ArchiveFileTypeSubOne] = ".sub1",
 | 
						|
    [ArchiveFileTypeLFRFID] = ".rfid",
 | 
						|
    [ArchiveFileTypeIrda] = ".ir",
 | 
						|
};
 | 
						|
 | 
						|
static const char* tab_default_paths[] = {
 | 
						|
    [ArchiveTabFavorites] = "/any/favorites",
 | 
						|
    [ArchiveTabIButton] = "/any/ibutton",
 | 
						|
    [ArchiveTabNFC] = "/any/nfc",
 | 
						|
    [ArchiveTabSubOne] = "/any/subone",
 | 
						|
    [ArchiveTabLFRFID] = "/any/lfrfid",
 | 
						|
    [ArchiveTabIrda] = "/any/irda",
 | 
						|
    [ArchiveTabBrowser] = "/any",
 | 
						|
};
 | 
						|
 | 
						|
static inline const char* get_tab_ext(ArchiveTabEnum tab) {
 | 
						|
    switch(tab) {
 | 
						|
    case ArchiveTabIButton:
 | 
						|
        return known_ext[ArchiveFileTypeIButton];
 | 
						|
    case ArchiveTabNFC:
 | 
						|
        return known_ext[ArchiveFileTypeNFC];
 | 
						|
    case ArchiveTabSubOne:
 | 
						|
        return known_ext[ArchiveFileTypeSubOne];
 | 
						|
    case ArchiveTabLFRFID:
 | 
						|
        return known_ext[ArchiveFileTypeLFRFID];
 | 
						|
    case ArchiveTabIrda:
 | 
						|
        return known_ext[ArchiveFileTypeIrda];
 | 
						|
    default:
 | 
						|
        return "*";
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
static inline const char* get_default_path(ArchiveFileTypeEnum type) {
 | 
						|
    switch(type) {
 | 
						|
    case ArchiveFileTypeIButton:
 | 
						|
        return tab_default_paths[ArchiveTabIButton];
 | 
						|
    case ArchiveFileTypeNFC:
 | 
						|
        return tab_default_paths[ArchiveTabNFC];
 | 
						|
    case ArchiveFileTypeSubOne:
 | 
						|
        return tab_default_paths[ArchiveTabSubOne];
 | 
						|
    case ArchiveFileTypeLFRFID:
 | 
						|
        return tab_default_paths[ArchiveTabLFRFID];
 | 
						|
    case ArchiveFileTypeIrda:
 | 
						|
        return tab_default_paths[ArchiveTabIrda];
 | 
						|
    default:
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
static inline const char* get_favorites_path() {
 | 
						|
    return tab_default_paths[ArchiveTabFavorites];
 | 
						|
}
 | 
						|
 | 
						|
typedef enum {
 | 
						|
    EventTypeTick,
 | 
						|
    EventTypeKey,
 | 
						|
    EventTypeExit,
 | 
						|
} EventType;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
    union {
 | 
						|
        InputEvent input;
 | 
						|
    } value;
 | 
						|
    EventType type;
 | 
						|
} AppEvent;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
    ArchiveTabEnum tab_id;
 | 
						|
    string_t name;
 | 
						|
    string_t path;
 | 
						|
    char text_input_buffer[MAX_NAME_LEN];
 | 
						|
 | 
						|
    uint8_t depth;
 | 
						|
    uint16_t last_idx[MAX_DEPTH];
 | 
						|
 | 
						|
    bool menu;
 | 
						|
} ArchiveBrowser;
 | 
						|
 | 
						|
struct ArchiveApp {
 | 
						|
    osMessageQueueId_t event_queue;
 | 
						|
    FuriThread* app_thread;
 | 
						|
    Loader* loader;
 | 
						|
    Gui* gui;
 | 
						|
    ViewDispatcher* view_dispatcher;
 | 
						|
    View* view_archive_main;
 | 
						|
    TextInput* text_input;
 | 
						|
 | 
						|
    Storage* api;
 | 
						|
    ArchiveBrowser browser;
 | 
						|
};
 |