 ad421a81bc
			
		
	
	
		ad421a81bc
		
			
		
	
	
	
	
		
			
			* 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;
 | |
| };
 |