* 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>
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			55 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);
 | 
						|
}
 |