From 437d212fff30b4ec24f3cc24818ec3d2165bcca3 Mon Sep 17 00:00:00 2001 From: Willy-JL <49810075+Willy-JL@users.noreply.github.com> Date: Sat, 18 May 2024 11:15:54 +0100 Subject: [PATCH 1/3] Fix array out of bounds in create group when empty --- scenes/scene_action_create_group.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/scenes/scene_action_create_group.c b/scenes/scene_action_create_group.c index 279836b5079..7092f071b46 100644 --- a/scenes/scene_action_create_group.c +++ b/scenes/scene_action_create_group.c @@ -45,9 +45,14 @@ bool scene_action_create_group_on_event(void* context, SceneManagerEvent event) if(!strcmp(app->temp_cstr, "")) { return false; } - Item* item = ItemArray_get(app->items_view->items, app->selected_item); + FuriString* current_path = furi_string_alloc(); - path_extract_dirname(furi_string_get_cstr(item->path), current_path); + if(app->selected_item != EMPTY_ACTION_INDEX) { + Item* item = ItemArray_get(app->items_view->items, app->selected_item); + path_extract_dirname(furi_string_get_cstr(item->path), current_path); + } else { + furi_string_set(current_path, app->items_view->path); + } FuriString* new_group_path = furi_string_alloc(); furi_string_printf( From fbc80be9ef0b581805daaacfcf043d0abfaa7932 Mon Sep 17 00:00:00 2001 From: Willy-JL <49810075+Willy-JL@users.noreply.github.com> Date: Sat, 18 May 2024 11:17:16 +0100 Subject: [PATCH 2/3] Fix import here logic - "From" file for rename generated by get_file_to_import_alloc() was same as destination - Instead, it should return the selected filepath as is, and destination needs to be constructed - Fixed logging null pointer when user cancels the import - Import file starts at root of sd card - Added some logging --- scenes/scene_action_rename.c | 2 +- scenes/scene_action_settings.c | 39 ++++++++++++++-------------------- 2 files changed, 17 insertions(+), 24 deletions(-) diff --git a/scenes/scene_action_rename.c b/scenes/scene_action_rename.c index 58d1a111784..e0136c01d9b 100644 --- a/scenes/scene_action_rename.c +++ b/scenes/scene_action_rename.c @@ -66,7 +66,7 @@ bool scene_action_rename_on_event(void* context, SceneManagerEvent event) { FuriString* new_path = furi_string_alloc_printf( "%s/%s%s", furi_string_get_cstr(dir_name), app->temp_cstr, item->ext); - // FURI_LOG_I(TAG, "Rename: %s to %s", old_path, furi_string_get_cstr(new_path)); + FURI_LOG_I(TAG, "Rename: %s to %s", old_path, furi_string_get_cstr(new_path)); FS_Error fs_result = storage_common_rename(app->storage, old_path, furi_string_get_cstr(new_path)); if(fs_result == FSE_OK) { diff --git a/scenes/scene_action_settings.c b/scenes/scene_action_settings.c index c6c38eaf00a..1afa4129d6f 100644 --- a/scenes/scene_action_settings.c +++ b/scenes/scene_action_settings.c @@ -93,18 +93,10 @@ static bool scene_action_settings_import_file_browser_callback( // Ask user for file to import from elsewhere on the SD card FuriString* scene_action_get_file_to_import_alloc(App* app) { - FuriString* current_path = furi_string_alloc(); - if(app->selected_item != EMPTY_ACTION_INDEX) { - Item* item = ItemArray_get(app->items_view->items, app->selected_item); - path_extract_dirname(furi_string_get_cstr(item->path), current_path); - } else { - furi_string_set(current_path, app->items_view->path); - } - // Setup our file browser options DialogsFileBrowserOptions fb_options; dialog_file_browser_set_basic_options(&fb_options, "", NULL); - fb_options.base_path = furi_string_get_cstr(current_path); + fb_options.base_path = STORAGE_EXT_PATH_PREFIX; fb_options.skip_assets = true; furi_string_set_str(app->temp_str, fb_options.base_path); fb_options.item_loader_callback = scene_action_settings_import_file_browser_callback; @@ -112,18 +104,8 @@ FuriString* scene_action_get_file_to_import_alloc(App* app) { FuriString* full_path = NULL; if(dialog_file_browser_show(app->dialog, app->temp_str, app->temp_str, &fb_options)) { - // FURI_LOG_I(TAG, "Selected file is %s", furi_string_get_cstr(app->temp_str)); - FuriString* file_name = furi_string_alloc(); - path_extract_filename(app->temp_str, file_name, false); - // FURI_LOG_I(TAG, "Importing file %s", furi_string_get_cstr(file_name)); - full_path = furi_string_alloc_printf( - "%s/%s", furi_string_get_cstr(current_path), furi_string_get_cstr(file_name)); - // FURI_LOG_I(TAG, "New path is %s", furi_string_get_cstr(full_path)); - furi_string_free(file_name); - } else { - // FURI_LOG_I(TAG, "User cancelled"); + full_path = furi_string_alloc_set(app->temp_str); } - furi_string_free(current_path); return full_path; } @@ -241,8 +223,8 @@ bool scene_action_settings_on_event(void* context, SceneManagerEvent event) { consumed = true; // get the filename to import FuriString* import_file = scene_action_get_file_to_import_alloc(app); - FURI_LOG_I(TAG, "Importing %s", furi_string_get_cstr(import_file)); if(import_file) { + FURI_LOG_I(TAG, "Importing %s", furi_string_get_cstr(import_file)); // if it's a .ir file, switch to a scene that lets user pick the command from the file // only if there's more than one command in the file. then copy that relevant chunk // to the local directory @@ -274,12 +256,23 @@ bool scene_action_settings_on_event(void* context, SceneManagerEvent event) { furi_string_get_cstr(file_name)); // FURI_LOG_I(TAG, "New path is %s", furi_string_get_cstr(full_path)); + FURI_LOG_I( + TAG, + "Copy: %s to %s", + furi_string_get_cstr(import_file), + furi_string_get_cstr(full_path)); FS_Error fs_result = storage_common_copy( app->storage, furi_string_get_cstr(import_file), furi_string_get_cstr(full_path)); - if(fs_result == FSE_OK) { - } else { + if(fs_result != FSE_OK) { + FURI_LOG_E( + TAG, "Copy file failed! %s", filesystem_api_error_get_desc(fs_result)); + FuriString* error_msg = furi_string_alloc_printf( + "Copy failed!\nError: %s", filesystem_api_error_get_desc(fs_result)); + dialog_message_show_storage_error( + app->dialog, furi_string_get_cstr(error_msg)); + furi_string_free(error_msg); } furi_string_free(file_name); furi_string_free(full_path); From a00bc10f6acea7b13e68800d5717c6a2a4051bc9 Mon Sep 17 00:00:00 2001 From: Willy-JL <49810075+Willy-JL@users.noreply.github.com> Date: Wed, 29 May 2024 09:08:14 +0100 Subject: [PATCH 3/3] Fix subghz actions --- actions/action_subghz.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/actions/action_subghz.c b/actions/action_subghz.c index 76b4ea52c8e..1c05643db2c 100644 --- a/actions/action_subghz.c +++ b/actions/action_subghz.c @@ -222,10 +222,7 @@ void action_subghz_tx(void* context, const FuriString* action_path, FuriString* } } else { // if not RAW protocol FURI_LOG_I(TAG, "Protocol != RAW"); - bool repeat_exists = flipper_format_key_exist(fff_data_file, "Repeat"); - if(!repeat_exists) { - flipper_format_write_uint32(fff_data_file, "Repeat", &repeat, 1); - } + flipper_format_insert_or_update_uint32(fff_data_file, "Repeat", &repeat, 1); transmitter = subghz_transmitter_alloc_init(environment, furi_string_get_cstr(temp_str)); if(transmitter == NULL) { @@ -240,9 +237,6 @@ void action_subghz_tx(void* context, const FuriString* action_path, FuriString* is_init_protocol = false; } } - if(!repeat_exists) { - flipper_format_delete_key(fff_data_file, "Repeat"); - } } if(is_init_protocol) { @@ -250,7 +244,9 @@ void action_subghz_tx(void* context, const FuriString* action_path, FuriString* } else { subghz_devices_sleep(device); subghz_devices_end(device); - subghz_transmitter_free(transmitter); + if(transmitter != NULL) { + subghz_transmitter_free(transmitter); + } } } while(false);