Remove raw new/delete from Recon (#1203)

This commit is contained in:
Kyle Reed 2023-06-28 10:14:30 -07:00 committed by GitHub
parent 5c1f5a7d2e
commit 3d59de55f8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 19 additions and 17 deletions

View File

@ -30,8 +30,6 @@ using portapack::memory::map::backup_ram;
namespace ui { namespace ui {
static RecordView* record_view = NULL;
void ReconView::set_loop_config(bool v) { void ReconView::set_loop_config(bool v) {
continuous = v; continuous = v;
button_loop_config.set_style(v ? &Styles::green : &Styles::white); button_loop_config.set_style(v ? &Styles::green : &Styles::white);
@ -365,7 +363,6 @@ void ReconView::focus() {
ReconView::~ReconView() { ReconView::~ReconView() {
recon_stop_recording(); recon_stop_recording();
delete record_view;
recon_save_config_to_sd(); recon_save_config_to_sd();
if (field_mode.selected_index_value() != SPEC_MODULATION) if (field_mode.selected_index_value() != SPEC_MODULATION)
audio::output::stop(); audio::output::stop();
@ -377,7 +374,9 @@ ReconView::~ReconView() {
ReconView::ReconView(NavigationView& nav) ReconView::ReconView(NavigationView& nav)
: nav_{nav} { : nav_{nav} {
chrono_start = chTimeNow(); chrono_start = chTimeNow();
record_view = new RecordView({0, 0, 30 * 8, 1 * 16}, u"AUTO_AUDIO_", u"AUDIO", RecordView::FileType::WAV, 4096, 4); record_view = std::make_unique<RecordView>(Rect{0, 0, 30 * 8, 1 * 16},
u"AUTO_AUDIO_", u"AUDIO",
RecordView::FileType::WAV, 4096, 4);
add_children({&labels, add_children({&labels,
&field_lna, &field_lna,
&field_vga, &field_vga,
@ -414,7 +413,7 @@ ReconView::ReconView(NavigationView& nav)
&button_restart, &button_restart,
&button_mic_app, &button_mic_app,
&button_remove, &button_remove,
record_view}); record_view.get()});
record_view->hidden(true); record_view->hidden(true);
record_view->set_filename_date_frequency(true); record_view->set_filename_date_frequency(true);
@ -1339,25 +1338,26 @@ size_t ReconView::change_mode(freqman_index_t new_mod) {
field_mode.on_change = [this](size_t, OptionsField::value_t) {}; field_mode.on_change = [this](size_t, OptionsField::value_t) {};
field_bw.on_change = [this](size_t, OptionsField::value_t) {}; field_bw.on_change = [this](size_t, OptionsField::value_t) {};
recon_stop_recording(); recon_stop_recording();
if (new_mod != SPEC_MODULATION) { remove_child(record_view.get());
remove_children({record_view});
delete record_view;
record_view = new RecordView({0, 0, 30 * 8, 1 * 16}, u"AUTO_AUDIO_", u"AUDIO", RecordView::FileType::WAV, 4096, 4);
record_view->set_filename_date_frequency(true);
add_children({record_view});
}
if (new_mod == SPEC_MODULATION) { if (new_mod == SPEC_MODULATION) {
audio::output::stop(); audio::output::stop();
remove_children({record_view}); record_view = std::make_unique<RecordView>(Rect{0, 0, 30 * 8, 1 * 16},
delete record_view; u"AUTO_RAW_", u"CAPTURES",
record_view = new RecordView({0, 0, 30 * 8, 1 * 16}, u"AUTO_RAW_", u"CAPTURES", RecordView::FileType::RawS16, 16384, 3); RecordView::FileType::RawS16, 16384, 3);
record_view->set_filename_date_frequency(true); } else {
add_children({record_view}); record_view = std::make_unique<RecordView>(Rect{0, 0, 30 * 8, 1 * 16},
u"AUTO_AUDIO_", u"AUDIO",
RecordView::FileType::WAV, 4096, 4);
} }
record_view->hidden(true); record_view->hidden(true);
record_view->set_filename_date_frequency(true);
record_view->on_error = [this](std::string message) { record_view->on_error = [this](std::string message) {
nav_.display_modal("Error", message); nav_.display_modal("Error", message);
}; };
add_child(record_view.get());
receiver_model.disable(); receiver_model.disable();
baseband::shutdown(); baseband::shutdown();
size_t recording_sampling_rate = 0; size_t recording_sampling_rate = 0;

View File

@ -145,6 +145,8 @@ class ReconView : public View {
systime_t chrono_start{}; systime_t chrono_start{};
systime_t chrono_end{}; systime_t chrono_end{};
std::unique_ptr<RecordView> record_view{};
Labels labels{ Labels labels{
{{0 * 8, 0 * 16}, "LNA: VGA: AMP: VOL: ", Color::light_grey()}, {{0 * 8, 0 * 16}, "LNA: VGA: AMP: VOL: ", Color::light_grey()},
{{3 * 8, 8 * 16}, "START END", Color::light_grey()}, {{3 * 8, 8 * 16}, "START END", Color::light_grey()},