1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-07-27 02:27:43 +00:00

Flood: Propagate errors when creating SettingsDialog

This commit is contained in:
implicitfield 2023-08-13 14:06:46 +03:00 committed by Tim Schumacher
parent 239293a8b4
commit 8434b3a0c6
3 changed files with 24 additions and 10 deletions

View file

@ -17,7 +17,15 @@
#include <LibGUI/Label.h>
#include <LibGUI/SpinBox.h>
SettingsDialog::SettingsDialog(GUI::Window* parent, size_t board_rows, size_t board_columns)
ErrorOr<NonnullRefPtr<SettingsDialog>> SettingsDialog::try_create(GUI::Window* parent, size_t board_rows, size_t board_columns)
{
auto settings_widget = GUI::Widget::construct();
TRY(settings_widget->load_from_gml(settings_dialog_gml));
auto settings_dialog = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) SettingsDialog(move(settings_widget), move(parent), move(board_rows), move(board_columns))));
return settings_dialog;
}
SettingsDialog::SettingsDialog(NonnullRefPtr<GUI::Widget> settings_widget, GUI::Window* parent, size_t board_rows, size_t board_columns)
: GUI::Dialog(parent)
, m_board_rows(board_rows)
, m_board_columns(board_columns)
@ -27,29 +35,28 @@ SettingsDialog::SettingsDialog(GUI::Window* parent, size_t board_rows, size_t bo
set_icon(parent->icon());
set_resizable(false);
auto main_widget = set_main_widget<GUI::Widget>().release_value_but_fixme_should_propagate_errors();
main_widget->load_from_gml(settings_dialog_gml).release_value_but_fixme_should_propagate_errors();
set_main_widget(settings_widget);
auto board_rows_spinbox = main_widget->find_descendant_of_type_named<GUI::SpinBox>("board_rows_spinbox");
auto board_rows_spinbox = settings_widget->find_descendant_of_type_named<GUI::SpinBox>("board_rows_spinbox");
board_rows_spinbox->set_value(m_board_rows);
board_rows_spinbox->on_change = [&](auto value) {
m_board_rows = value;
};
auto board_columns_spinbox = main_widget->find_descendant_of_type_named<GUI::SpinBox>("board_columns_spinbox");
auto board_columns_spinbox = settings_widget->find_descendant_of_type_named<GUI::SpinBox>("board_columns_spinbox");
board_columns_spinbox->set_value(m_board_columns);
board_columns_spinbox->on_change = [&](auto value) {
m_board_columns = value;
};
auto cancel_button = main_widget->find_descendant_of_type_named<GUI::Button>("cancel_button");
auto cancel_button = settings_widget->find_descendant_of_type_named<GUI::Button>("cancel_button");
cancel_button->on_click = [this](auto) {
done(ExecResult::Cancel);
};
auto ok_button = main_widget->find_descendant_of_type_named<GUI::Button>("ok_button");
auto ok_button = settings_widget->find_descendant_of_type_named<GUI::Button>("ok_button");
ok_button->on_click = [this](auto) {
done(ExecResult::OK);
};