mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-12-01 00:39:12 +00:00
0b806c2360
* Storage: count opened files * Storage: sd mount * Storage: prompt to mount SD card if not mounted * F18: update API * F18: update API version * Fix logger naming scheme * Storage: storage_files_count -> storage_open_files_count Co-authored-by: あく <alleteam@gmail.com>
40 lines
1.1 KiB
C
40 lines
1.1 KiB
C
#include <furi.h>
|
|
#include <storage/storage.h>
|
|
|
|
// Define log tag
|
|
#define TAG "ExampleAppsData"
|
|
|
|
// Application entry point
|
|
int32_t example_apps_data_main(void* p) {
|
|
// Mark argument as unused
|
|
UNUSED(p);
|
|
|
|
// Open storage
|
|
Storage* storage = furi_record_open(RECORD_STORAGE);
|
|
|
|
// Allocate file
|
|
File* file = storage_file_alloc(storage);
|
|
|
|
// Get the path to the current application data folder
|
|
// That is: /ext/apps_data/<app_name>
|
|
// And it will create folders in the path if they don't exist
|
|
// In this example it will create /ext/apps_data/example_apps_data
|
|
// And file will be /ext/apps_data/example_apps_data/test.txt
|
|
|
|
// Open file, write data and close it
|
|
if(!storage_file_open(file, APP_DATA_PATH("test.txt"), FSAM_WRITE, FSOM_CREATE_ALWAYS)) {
|
|
FURI_LOG_E(TAG, "Failed to open file");
|
|
}
|
|
if(!storage_file_write(file, "Hello World!", strlen("Hello World!"))) {
|
|
FURI_LOG_E(TAG, "Failed to write to file");
|
|
}
|
|
storage_file_close(file);
|
|
|
|
// Deallocate file
|
|
storage_file_free(file);
|
|
|
|
// Close storage
|
|
furi_record_close(RECORD_STORAGE);
|
|
|
|
return 0;
|
|
}
|