[FL-1489] IRDA: move to FileWorker (#594)
* [FL-1489] IRDA: move to FileWorker, fixes * Use FileWorker * Use file_select to select remotes * Fix some crashes * Add RAW parsing restrictions * Remove excess scene (LearnDoneAfter) * Move all file system logic to standalone object
This commit is contained in:
@@ -1,4 +1,8 @@
|
||||
#include "irda-app-brute-force.hpp"
|
||||
#include "irda/irda-app-file-parser.hpp"
|
||||
#include "m-string.h"
|
||||
#include <file-worker-cpp.h>
|
||||
#include <memory>
|
||||
|
||||
void IrdaAppBruteForce::add_record(int index, const char* name) {
|
||||
records[name].index = index;
|
||||
@@ -7,43 +11,51 @@ void IrdaAppBruteForce::add_record(int index, const char* name) {
|
||||
|
||||
bool IrdaAppBruteForce::calculate_messages() {
|
||||
bool fs_res = false;
|
||||
fs_res = file_parser.get_fs_api().file.open(
|
||||
&file, universal_db_filename, FSAM_READ, FSOM_OPEN_EXISTING);
|
||||
furi_assert(!file_parser);
|
||||
|
||||
file_parser = std::make_unique<IrdaAppFileParser>();
|
||||
fs_res = file_parser->open_irda_file_read(universal_db_filename);
|
||||
if(!fs_res) {
|
||||
file_parser.get_sd_api().show_error(file_parser.get_sd_api().context, "Can't open file");
|
||||
file_parser.reset(nullptr);
|
||||
return false;
|
||||
}
|
||||
|
||||
file_parser.reset();
|
||||
while(1) {
|
||||
auto message = file_parser.read_signal(&file);
|
||||
if(!message) break;
|
||||
auto element = records.find(message->name);
|
||||
auto file_signal = file_parser->read_signal();
|
||||
if(!file_signal) break;
|
||||
|
||||
auto element = records.find(file_signal->name);
|
||||
if(element != records.cend()) {
|
||||
++element->second.amount;
|
||||
}
|
||||
}
|
||||
|
||||
file_parser.get_fs_api().file.close(&file);
|
||||
file_parser->close();
|
||||
file_parser.reset(nullptr);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void IrdaAppBruteForce::stop_bruteforce() {
|
||||
furi_assert((current_record.size()));
|
||||
|
||||
if(current_record.size()) {
|
||||
file_parser.get_fs_api().file.close(&file);
|
||||
furi_assert(file_parser);
|
||||
current_record.clear();
|
||||
file_parser->close();
|
||||
file_parser.reset(nullptr);
|
||||
}
|
||||
}
|
||||
|
||||
// TODO: [FL-1418] replace with timer-chained consequence of messages.
|
||||
bool IrdaAppBruteForce::send_next_bruteforce(void) {
|
||||
furi_assert(current_record.size());
|
||||
furi_assert(file_parser);
|
||||
|
||||
std::unique_ptr<IrdaAppFileParser::IrdaFileSignal> file_signal;
|
||||
|
||||
do {
|
||||
file_signal = file_parser.read_signal(&file);
|
||||
file_signal = file_parser->read_signal();
|
||||
} while(file_signal && current_record.compare(file_signal->name));
|
||||
|
||||
if(file_signal) {
|
||||
@@ -53,25 +65,26 @@ bool IrdaAppBruteForce::send_next_bruteforce(void) {
|
||||
}
|
||||
|
||||
bool IrdaAppBruteForce::start_bruteforce(int index, int& record_amount) {
|
||||
file_parser.reset();
|
||||
bool result = false;
|
||||
record_amount = 0;
|
||||
|
||||
for(const auto& it : records) {
|
||||
if(it.second.index == index) {
|
||||
record_amount = it.second.amount;
|
||||
current_record = it.first;
|
||||
if(record_amount) {
|
||||
current_record = it.first;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if(record_amount) {
|
||||
bool fs_res = file_parser.get_fs_api().file.open(
|
||||
&file, universal_db_filename, FSAM_READ, FSOM_OPEN_EXISTING);
|
||||
if(fs_res) {
|
||||
return true;
|
||||
} else {
|
||||
file_parser.get_sd_api().show_error(
|
||||
file_parser.get_sd_api().context, "Can't open file");
|
||||
file_parser = std::make_unique<IrdaAppFileParser>();
|
||||
result = file_parser->open_irda_file_read(universal_db_filename);
|
||||
if(!result) {
|
||||
(void)file_parser.reset(nullptr);
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
return result;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user