mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-10 11:48:54 +00:00
224d0aefe4
* First part of multitarget porting * Delete firmware/targets/f7/Inc directory * Delete firmware/targets/f7/Src directory * gpio: cli fixes; about: using version from HAL * sdk: path fixes * gui: include fixes * applications: more include fixes * gpio: ported to new apis * hal: introduced furi_hal_target_hw.h; libs: added one_wire * hal: f18 target * github: also build f18 by default * typo fix * fbt: removed extra checks on app list * api: explicitly bundling select mlib headers with sdk * hal: f18: changed INPUT_DEBOUNCE_TICKS to match f7 * cleaned up commented out code * docs: added info on hw targets * docs: targets: formatting fixes * f18: fixed link error * f18: fixed API version to match f7 * docs: hardware: minor wording fixes * faploader: added fw target check * docs: typo fixes * github: not building komi target by default * fbt: support for `targets` field for built-in apps * github: reworked build flow to exclude app_set; fbt: removed komi-specific appset; added additional target buildset check * github: fixed build; nfc: fixed pvs warnings * attempt to fix target id * f7, f18: removed certain HAL function from public API * apps: debug: enabled bt_debug_app for f18 * Targets: backport input pins configuration routine from F7 to F18 Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
54 lines
1.5 KiB
C
54 lines
1.5 KiB
C
#include "validators.h"
|
|
#include <storage/storage.h>
|
|
#include <furi.h>
|
|
|
|
struct ValidatorIsFile {
|
|
char* app_path_folder;
|
|
const char* app_extension;
|
|
char* current_name;
|
|
};
|
|
|
|
bool validator_is_file_callback(const char* text, FuriString* error, void* context) {
|
|
furi_assert(context);
|
|
ValidatorIsFile* instance = context;
|
|
|
|
if(instance->current_name != NULL) {
|
|
if(strcmp(instance->current_name, text) == 0) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
FuriString* path = furi_string_alloc_printf(
|
|
"%s/%s%s", instance->app_path_folder, text, instance->app_extension);
|
|
Storage* storage = furi_record_open(RECORD_STORAGE);
|
|
const bool ret = storage_common_stat(storage, furi_string_get_cstr(path), NULL) != FSE_OK;
|
|
if(!ret) {
|
|
furi_string_printf(error, "This name\nexists!\nChoose\nanother one.");
|
|
}
|
|
furi_string_free(path);
|
|
furi_record_close(RECORD_STORAGE);
|
|
|
|
return ret;
|
|
}
|
|
|
|
ValidatorIsFile* validator_is_file_alloc_init(
|
|
const char* app_path_folder,
|
|
const char* app_extension,
|
|
const char* current_name) {
|
|
ValidatorIsFile* instance = malloc(sizeof(ValidatorIsFile));
|
|
|
|
instance->app_path_folder = strdup(app_path_folder);
|
|
instance->app_extension = app_extension;
|
|
if(current_name != NULL) {
|
|
instance->current_name = strdup(current_name);
|
|
}
|
|
|
|
return instance;
|
|
}
|
|
|
|
void validator_is_file_free(ValidatorIsFile* instance) {
|
|
furi_assert(instance);
|
|
free(instance->app_path_folder);
|
|
free(instance->current_name);
|
|
free(instance);
|
|
}
|