990a065bd0
* IR app move to FFF * [FL-2164] Hide unimplemented submenus * Fix brute force fail * Fix FFF endless reading * Reformat TV bruteforce lib to FFF * fixes & cleanup * Infrared: switch to constexpr. Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
98 lines
2.5 KiB
C++
98 lines
2.5 KiB
C++
|
|
#include "helpers/irda_parser.h"
|
|
#include "irda_app_brute_force.h"
|
|
#include "irda_app_signal.h"
|
|
#include <memory>
|
|
#include <m-string.h>
|
|
#include <furi.h>
|
|
#include <file_worker_cpp.h>
|
|
|
|
void IrdaAppBruteForce::add_record(int index, const char* name) {
|
|
records[name].index = index;
|
|
records[name].amount = 0;
|
|
}
|
|
|
|
bool IrdaAppBruteForce::calculate_messages() {
|
|
bool result = false;
|
|
|
|
Storage* storage = static_cast<Storage*>(furi_record_open("storage"));
|
|
FlipperFile* ff = flipper_file_alloc(storage);
|
|
result = flipper_file_open_existing(ff, universal_db_filename);
|
|
|
|
if(result) {
|
|
IrdaAppSignal signal;
|
|
|
|
string_t signal_name;
|
|
string_init(signal_name);
|
|
while(flipper_file_read_string(ff, "name", signal_name)) {
|
|
auto element = records.find(string_get_cstr(signal_name));
|
|
if(element != records.cend()) {
|
|
++element->second.amount;
|
|
}
|
|
}
|
|
string_clear(signal_name);
|
|
}
|
|
|
|
flipper_file_close(ff);
|
|
flipper_file_free(ff);
|
|
furi_record_close("storage");
|
|
return result;
|
|
}
|
|
|
|
void IrdaAppBruteForce::stop_bruteforce() {
|
|
furi_assert((current_record.size()));
|
|
|
|
if(current_record.size()) {
|
|
furi_assert(ff);
|
|
current_record.clear();
|
|
flipper_file_close(ff);
|
|
flipper_file_free(ff);
|
|
furi_record_close("storage");
|
|
}
|
|
}
|
|
|
|
bool IrdaAppBruteForce::send_next_bruteforce(void) {
|
|
furi_assert(current_record.size());
|
|
furi_assert(ff);
|
|
|
|
IrdaAppSignal signal;
|
|
std::string signal_name;
|
|
bool result = false;
|
|
do {
|
|
result = irda_parser_read_signal(ff, signal, signal_name);
|
|
} while(result && current_record.compare(signal_name));
|
|
|
|
if(result) {
|
|
signal.transmit();
|
|
}
|
|
return result;
|
|
}
|
|
|
|
bool IrdaAppBruteForce::start_bruteforce(int index, int& record_amount) {
|
|
bool result = false;
|
|
record_amount = 0;
|
|
|
|
for(const auto& it : records) {
|
|
if(it.second.index == index) {
|
|
record_amount = it.second.amount;
|
|
if(record_amount) {
|
|
current_record = it.first;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
if(record_amount) {
|
|
Storage* storage = static_cast<Storage*>(furi_record_open("storage"));
|
|
ff = flipper_file_alloc(storage);
|
|
result = flipper_file_open_existing(ff, universal_db_filename);
|
|
if(!result) {
|
|
flipper_file_close(ff);
|
|
flipper_file_free(ff);
|
|
furi_record_close("storage");
|
|
}
|
|
}
|
|
|
|
return result;
|
|
}
|