mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-12-12 04:34:43 +04:00
strlcpy doesn't zero the buffer and ensures null termination, just like snprintf strlcat is already used by mjs and it's a safe alternative to strcat, so it should be OK to expose to apps
137 lines
5.2 KiB
C
137 lines
5.2 KiB
C
#include "../infrared_app_i.h"
|
|
|
|
#include <string.h>
|
|
#include <toolbox/path.h>
|
|
|
|
static int32_t infrared_scene_edit_rename_task_callback(void* context) {
|
|
InfraredApp* infrared = context;
|
|
InfraredAppState* app_state = &infrared->app_state;
|
|
const InfraredEditTarget edit_target = app_state->edit_target;
|
|
|
|
InfraredErrorCode error = InfraredErrorCodeNone;
|
|
if(edit_target == InfraredEditTargetButton) {
|
|
furi_assert(app_state->current_button_index != InfraredButtonIndexNone);
|
|
error = infrared_remote_rename_signal(
|
|
infrared->remote, app_state->current_button_index, infrared->text_store[0]);
|
|
} else if(edit_target == InfraredEditTargetRemote) {
|
|
error = infrared_rename_current_remote(infrared, infrared->text_store[0]);
|
|
} else {
|
|
furi_crash();
|
|
}
|
|
|
|
view_dispatcher_send_custom_event(
|
|
infrared->view_dispatcher, InfraredCustomEventTypeTaskFinished);
|
|
|
|
return error;
|
|
}
|
|
|
|
void infrared_scene_edit_rename_on_enter(void* context) {
|
|
InfraredApp* infrared = context;
|
|
InfraredRemote* remote = infrared->remote;
|
|
TextInput* text_input = infrared->text_input;
|
|
size_t enter_name_length = 0;
|
|
|
|
const InfraredEditTarget edit_target = infrared->app_state.edit_target;
|
|
if(edit_target == InfraredEditTargetButton) {
|
|
text_input_set_header_text(text_input, "Name the button");
|
|
|
|
const int32_t current_button_index = infrared->app_state.current_button_index;
|
|
furi_check(current_button_index != InfraredButtonIndexNone);
|
|
|
|
enter_name_length = INFRARED_MAX_BUTTON_NAME_LENGTH;
|
|
strlcpy(
|
|
infrared->text_store[0],
|
|
infrared_remote_get_signal_name(remote, current_button_index),
|
|
enter_name_length);
|
|
|
|
} else if(edit_target == InfraredEditTargetRemote) {
|
|
text_input_set_header_text(text_input, "Name the remote");
|
|
enter_name_length = INFRARED_MAX_REMOTE_NAME_LENGTH;
|
|
strlcpy(infrared->text_store[0], infrared_remote_get_name(remote), enter_name_length);
|
|
|
|
FuriString* folder_path;
|
|
folder_path = furi_string_alloc();
|
|
|
|
if(furi_string_end_with(infrared->file_path, INFRARED_APP_EXTENSION)) {
|
|
path_extract_dirname(furi_string_get_cstr(infrared->file_path), folder_path);
|
|
}
|
|
|
|
ValidatorIsFile* validator_is_file = validator_is_file_alloc_init(
|
|
furi_string_get_cstr(folder_path),
|
|
INFRARED_APP_EXTENSION,
|
|
infrared_remote_get_name(remote));
|
|
text_input_set_validator(text_input, validator_is_file_callback, validator_is_file);
|
|
|
|
furi_string_free(folder_path);
|
|
} else {
|
|
furi_crash();
|
|
}
|
|
|
|
text_input_set_result_callback(
|
|
text_input,
|
|
infrared_text_input_callback,
|
|
context,
|
|
infrared->text_store[0],
|
|
enter_name_length,
|
|
false);
|
|
|
|
view_dispatcher_switch_to_view(infrared->view_dispatcher, InfraredViewTextInput);
|
|
}
|
|
|
|
bool infrared_scene_edit_rename_on_event(void* context, SceneManagerEvent event) {
|
|
InfraredApp* infrared = context;
|
|
SceneManager* scene_manager = infrared->scene_manager;
|
|
bool consumed = false;
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == InfraredCustomEventTypeTextEditDone) {
|
|
// Rename a button or a remote in a separate thread
|
|
infrared_blocking_task_start(infrared, infrared_scene_edit_rename_task_callback);
|
|
|
|
} else if(event.event == InfraredCustomEventTypeTaskFinished) {
|
|
const InfraredErrorCode task_error = infrared_blocking_task_finalize(infrared);
|
|
InfraredAppState* app_state = &infrared->app_state;
|
|
|
|
if(!INFRARED_ERROR_PRESENT(task_error)) {
|
|
scene_manager_next_scene(scene_manager, InfraredSceneEditRenameDone);
|
|
} else {
|
|
bool long_signal = INFRARED_ERROR_CHECK(
|
|
task_error, InfraredErrorCodeSignalRawUnableToReadTooLongData);
|
|
|
|
const char* format = "Failed to rename\n%s";
|
|
const char* target = infrared->app_state.edit_target == InfraredEditTargetButton ?
|
|
"button" :
|
|
"file";
|
|
if(long_signal) {
|
|
format = "Failed to rename\n\"%s\" is too long.\nTry to edit file from pc";
|
|
target = infrared_remote_get_signal_name(
|
|
infrared->remote, INFRARED_ERROR_GET_INDEX(task_error));
|
|
}
|
|
|
|
infrared_show_error_message(infrared, format, target);
|
|
|
|
const uint32_t possible_scenes[] = {InfraredSceneRemoteList, InfraredSceneRemote};
|
|
scene_manager_search_and_switch_to_previous_scene_one_of(
|
|
scene_manager, possible_scenes, COUNT_OF(possible_scenes));
|
|
}
|
|
|
|
app_state->current_button_index = InfraredButtonIndexNone;
|
|
}
|
|
consumed = true;
|
|
}
|
|
|
|
return consumed;
|
|
}
|
|
|
|
void infrared_scene_edit_rename_on_exit(void* context) {
|
|
InfraredApp* infrared = context;
|
|
TextInput* text_input = infrared->text_input;
|
|
|
|
ValidatorIsFile* validator_context = text_input_get_validator_callback_context(text_input);
|
|
if(validator_context) {
|
|
validator_is_file_free(validator_context);
|
|
}
|
|
|
|
text_input_reset(text_input);
|
|
}
|