mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-12 20:58:49 +00:00
49dcf81743
* Do not load all signals at once (Draft) * Minor cleanup * Refactor remote renaming * Improve function signatures * Rename infrared_remote functions * Optimise signal loading * Implement adding signals to remote * Add read_name() method * Deprecate a function * Partially implement deleting signals (draft) * Use m-array instead of m-list for signal name directory * Use plain C strings instead of furi_string * Implement deleting signals * Implement deleting signals via generalised callback * Implement renaming signals * Rename some types * Some more renaming * Remove unused type * Implement inserting signals (internal use) * Improve InfraredMoveView * Send an event to move a signal * Remove unused type * Implement moving signals * Implement creating new remotes with one signal * Un-deprecate and rename a function * Add InfraredRemote API docs * Add InfraredSignal API docs * Better error messages * Show progress pop-up when moving buttons in a remote * Copy labels to the InfraredMoveView to avoid pointer invalidation * Improve file selection scene * Show progress pop-up when renaming buttons in a remote * Refactor a scene * Show progress when deleting a button from remote * Use a random name for temp files * Add docs to infrared_brute_force.h * Rename Infrared type to InfraredApp * Add docs to infrared_app_i.h * Deliver event data via a callback * Bundle event data together with event type * Change DataExchange behaviour * Adapt RPC debug app to new API * Remove rogue output * Add Doxygen comments to rpc_app.h * Simplify rpc_app.c code * Remove superflous parameter * Do not allocate protobuf messages on the stack * Fix GetError response * Support for button indices * Comment out shallow submodules * Fix F18 api * Fix logical error and add more debug output * fbt: testing unshallow for protobuf * github: lint&checks: unshallow prior to checks * Fix a TODO * github: do not unshallow the unshallowed * fbt: assets: only attempt to unshallow if cannot describe * Do not use the name when loading a signal by index (duh) * Simplify loading infrared signals by name * Sync with protobuf release * Infrared: use compact furi_crash macros Co-authored-by: hedger <hedger@nanode.su> Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
117 lines
4.8 KiB
C
117 lines
4.8 KiB
C
#include "../subghz_i.h"
|
|
|
|
typedef enum {
|
|
SubGhzRpcStateIdle,
|
|
SubGhzRpcStateLoaded,
|
|
SubGhzRpcStateTx,
|
|
} SubGhzRpcState;
|
|
|
|
void subghz_scene_rpc_on_enter(void* context) {
|
|
SubGhz* subghz = context;
|
|
Popup* popup = subghz->popup;
|
|
|
|
popup_set_header(popup, "Sub-GHz", 89, 42, AlignCenter, AlignBottom);
|
|
popup_set_text(popup, "RPC mode", 89, 44, AlignCenter, AlignTop);
|
|
|
|
popup_set_icon(popup, 0, 12, &I_RFIDDolphinSend_97x61);
|
|
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewIdPopup);
|
|
|
|
scene_manager_set_scene_state(subghz->scene_manager, SubGhzSceneRpc, SubGhzRpcStateIdle);
|
|
|
|
notification_message(subghz->notifications, &sequence_display_backlight_on);
|
|
}
|
|
|
|
bool subghz_scene_rpc_on_event(void* context, SceneManagerEvent event) {
|
|
SubGhz* subghz = context;
|
|
Popup* popup = subghz->popup;
|
|
bool consumed = false;
|
|
SubGhzRpcState state = scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneRpc);
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
consumed = true;
|
|
if(event.event == SubGhzCustomEventSceneExit) {
|
|
scene_manager_stop(subghz->scene_manager);
|
|
view_dispatcher_stop(subghz->view_dispatcher);
|
|
rpc_system_app_confirm(subghz->rpc_ctx, true);
|
|
} else if(event.event == SubGhzCustomEventSceneRpcSessionClose) {
|
|
scene_manager_stop(subghz->scene_manager);
|
|
view_dispatcher_stop(subghz->view_dispatcher);
|
|
} else if(event.event == SubGhzCustomEventSceneRpcButtonPress) {
|
|
bool result = false;
|
|
if(state == SubGhzRpcStateLoaded) {
|
|
switch(
|
|
subghz_txrx_tx_start(subghz->txrx, subghz_txrx_get_fff_data(subghz->txrx))) {
|
|
case SubGhzTxRxStartTxStateErrorOnlyRx:
|
|
rpc_system_app_set_error_code(subghz->rpc_ctx, SubGhzErrorTypeOnlyRX);
|
|
rpc_system_app_set_error_text(
|
|
subghz->rpc_ctx,
|
|
"Transmission on this frequency is restricted in your region");
|
|
break;
|
|
case SubGhzTxRxStartTxStateErrorParserOthers:
|
|
rpc_system_app_set_error_code(subghz->rpc_ctx, SubGhzErrorTypeParserOthers);
|
|
rpc_system_app_set_error_text(
|
|
subghz->rpc_ctx, "Error in protocol parameters description");
|
|
break;
|
|
|
|
default: //if(SubGhzTxRxStartTxStateOk)
|
|
result = true;
|
|
subghz_blink_start(subghz);
|
|
state = SubGhzRpcStateTx;
|
|
break;
|
|
}
|
|
}
|
|
rpc_system_app_confirm(subghz->rpc_ctx, result);
|
|
} else if(event.event == SubGhzCustomEventSceneRpcButtonRelease) {
|
|
bool result = false;
|
|
if(state == SubGhzRpcStateTx) {
|
|
subghz_txrx_stop(subghz->txrx);
|
|
subghz_blink_stop(subghz);
|
|
result = true;
|
|
}
|
|
state = SubGhzRpcStateIdle;
|
|
rpc_system_app_confirm(subghz->rpc_ctx, result);
|
|
} else if(event.event == SubGhzCustomEventSceneRpcLoad) {
|
|
bool result = false;
|
|
if(state == SubGhzRpcStateIdle) {
|
|
if(subghz_key_load(subghz, furi_string_get_cstr(subghz->file_path), false)) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneRpc, SubGhzRpcStateLoaded);
|
|
result = true;
|
|
FuriString* file_name;
|
|
file_name = furi_string_alloc();
|
|
path_extract_filename(subghz->file_path, file_name, true);
|
|
|
|
snprintf(
|
|
subghz->file_name_tmp,
|
|
SUBGHZ_MAX_LEN_NAME,
|
|
"loaded\n%s",
|
|
furi_string_get_cstr(file_name));
|
|
popup_set_text(popup, subghz->file_name_tmp, 89, 44, AlignCenter, AlignTop);
|
|
|
|
furi_string_free(file_name);
|
|
} else {
|
|
rpc_system_app_set_error_code(subghz->rpc_ctx, SubGhzErrorTypeParseFile);
|
|
rpc_system_app_set_error_text(subghz->rpc_ctx, "Cannot parse file");
|
|
}
|
|
}
|
|
rpc_system_app_confirm(subghz->rpc_ctx, result);
|
|
}
|
|
}
|
|
return consumed;
|
|
}
|
|
|
|
void subghz_scene_rpc_on_exit(void* context) {
|
|
SubGhz* subghz = context;
|
|
SubGhzRpcState state = scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneRpc);
|
|
if(state == SubGhzRpcStateTx) {
|
|
subghz_txrx_stop(subghz->txrx);
|
|
subghz_blink_stop(subghz);
|
|
}
|
|
|
|
Popup* popup = subghz->popup;
|
|
|
|
popup_set_header(popup, NULL, 0, 0, AlignCenter, AlignBottom);
|
|
popup_set_text(popup, NULL, 0, 0, AlignCenter, AlignTop);
|
|
popup_set_icon(popup, 0, 0, NULL);
|
|
}
|