diff options
author | Andreas Kling <kling@serenityos.org> | 2020-03-04 20:53:51 +0100 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2020-03-04 21:04:06 +0100 |
commit | b29ff7b821ba4752a797d610c8f41d1a20f83d86 (patch) | |
tree | a1f848e7e7d3d7c97c05331cad8ea3f9037e5cb6 | |
parent | dfa69b82b4233494e65af53bdd620ab33e0c043a (diff) | |
download | serenity-b29ff7b821ba4752a797d610c8f41d1a20f83d86.zip |
LibGUI: Don't use Core::Object::add() to instantiate dialogs
Now that add() returns a WidgetType&, we can't rely on the parent of a
GUI::Dialog to still keep it alive after exec() returns. This happens
because exec() will call remove_from_parent() on itself before
returning.
And so we go back to the old idiom for creating a GUI::Dialog centered
above a specific window. Just call GUI::Dialog::construct(), passing
the "parent" window as the last parameter.
-rw-r--r-- | Applications/FileManager/PropertiesDialog.cpp | 4 | ||||
-rw-r--r-- | Applications/FileManager/PropertiesDialog.h | 2 | ||||
-rw-r--r-- | Applications/FileManager/main.cpp | 6 | ||||
-rw-r--r-- | Applications/HexEditor/HexEditorWidget.cpp | 8 | ||||
-rw-r--r-- | Applications/IRCClient/IRCAppWindow.cpp | 12 | ||||
-rw-r--r-- | DevTools/HackStudio/main.cpp | 6 | ||||
-rw-r--r-- | Libraries/LibGUI/AboutDialog.cpp | 4 | ||||
-rw-r--r-- | Libraries/LibGUI/AboutDialog.h | 6 | ||||
-rw-r--r-- | Libraries/LibGUI/ColorPicker.cpp | 4 | ||||
-rw-r--r-- | Libraries/LibGUI/ColorPicker.h | 2 | ||||
-rw-r--r-- | Libraries/LibGUI/Dialog.cpp | 4 | ||||
-rw-r--r-- | Libraries/LibGUI/Dialog.h | 2 | ||||
-rw-r--r-- | Libraries/LibGUI/FilePicker.cpp | 4 | ||||
-rw-r--r-- | Libraries/LibGUI/FilePicker.h | 2 | ||||
-rw-r--r-- | Libraries/LibGUI/InputBox.cpp | 4 | ||||
-rw-r--r-- | Libraries/LibGUI/InputBox.h | 2 | ||||
-rw-r--r-- | Libraries/LibGUI/MessageBox.cpp | 10 | ||||
-rw-r--r-- | Libraries/LibGUI/MessageBox.h | 4 |
18 files changed, 43 insertions, 43 deletions
diff --git a/Applications/FileManager/PropertiesDialog.cpp b/Applications/FileManager/PropertiesDialog.cpp index 3f3c09be4d..8101c52539 100644 --- a/Applications/FileManager/PropertiesDialog.cpp +++ b/Applications/FileManager/PropertiesDialog.cpp @@ -36,8 +36,8 @@ #include <stdio.h> #include <unistd.h> -PropertiesDialog::PropertiesDialog(GUI::FileSystemModel& model, String path, bool disable_rename, Core::Object* parent) - : Dialog(parent) +PropertiesDialog::PropertiesDialog(GUI::FileSystemModel& model, String path, bool disable_rename, Window* parent_window) + : Dialog(parent_window) , m_model(model) { auto file_path = FileSystemPath(path); diff --git a/Applications/FileManager/PropertiesDialog.h b/Applications/FileManager/PropertiesDialog.h index 08f2969894..69e23a820f 100644 --- a/Applications/FileManager/PropertiesDialog.h +++ b/Applications/FileManager/PropertiesDialog.h @@ -40,7 +40,7 @@ public: virtual ~PropertiesDialog() override; private: - PropertiesDialog(GUI::FileSystemModel&, String, bool disable_rename, Core::Object* parent = nullptr); + PropertiesDialog(GUI::FileSystemModel&, String, bool disable_rename, Window* parent = nullptr); struct PropertyValuePair { String property; diff --git a/Applications/FileManager/main.cpp b/Applications/FileManager/main.cpp index bc96ca6735..d035abef55 100644 --- a/Applications/FileManager/main.cpp +++ b/Applications/FileManager/main.cpp @@ -171,12 +171,12 @@ int main(int argc, char** argv) }); auto mkdir_action = GUI::Action::create("New directory...", { Mod_Ctrl | Mod_Shift, Key_N }, Gfx::Bitmap::load_from_file("/res/icons/16x16/mkdir.png"), [&](const GUI::Action&) { - auto& input_box = window->add<GUI::InputBox>("Enter name:", "New directory"); - if (input_box.exec() == GUI::InputBox::ExecOK && !input_box.text_value().is_empty()) { + auto input_box = GUI::InputBox::construct("Enter name:", "New directory", window); + if (input_box->exec() == GUI::InputBox::ExecOK && !input_box->text_value().is_empty()) { auto new_dir_path = canonicalized_path( String::format("%s/%s", directory_view.path().characters(), - input_box.text_value().characters())); + input_box->text_value().characters())); int rc = mkdir(new_dir_path.characters(), 0777); if (rc < 0) { GUI::MessageBox::show(String::format("mkdir(\"%s\") failed: %s", new_dir_path.characters(), strerror(errno)), "Error", GUI::MessageBox::Type::Error, GUI::MessageBox::InputType::OK, window); diff --git a/Applications/HexEditor/HexEditorWidget.cpp b/Applications/HexEditor/HexEditorWidget.cpp index a03da9a106..22c81bfde4 100644 --- a/Applications/HexEditor/HexEditorWidget.cpp +++ b/Applications/HexEditor/HexEditorWidget.cpp @@ -78,7 +78,7 @@ HexEditorWidget::HexEditorWidget() m_save_action->activate(); } - auto input_box = GUI::InputBox::construct("Enter new file size:", "New file size", this); + auto input_box = GUI::InputBox::construct("Enter new file size:", "New file size", window()); if (input_box->exec() == GUI::InputBox::ExecOK && !input_box->text_value().is_empty()) { auto valid = false; auto file_size = input_box->text_value().to_int(valid); @@ -154,7 +154,7 @@ HexEditorWidget::HexEditorWidget() } m_goto_decimal_offset_action = GUI::Action::create("Go To Offset (Decimal)...", { Mod_Ctrl | Mod_Shift, Key_G }, Gfx::Bitmap::load_from_file("/res/icons/16x16/go-forward.png"), [this](const GUI::Action&) { - auto input_box = GUI::InputBox::construct("Enter Decimal offset:", "Go To", this); + auto input_box = GUI::InputBox::construct("Enter Decimal offset:", "Go To", window()); if (input_box->exec() == GUI::InputBox::ExecOK && !input_box->text_value().is_empty()) { auto valid = false; auto new_offset = input_box->text_value().to_int(valid); @@ -165,7 +165,7 @@ HexEditorWidget::HexEditorWidget() }); m_goto_hex_offset_action = GUI::Action::create("Go To Offset (Hex)...", { Mod_Ctrl, Key_G }, Gfx::Bitmap::load_from_file("/res/icons/16x16/go-forward.png"), [this](const GUI::Action&) { - auto input_box = GUI::InputBox::construct("Enter Hex offset:", "Go To", this); + auto input_box = GUI::InputBox::construct("Enter Hex offset:", "Go To", window()); if (input_box->exec() == GUI::InputBox::ExecOK && !input_box->text_value().is_empty()) { auto new_offset = strtol(input_box->text_value().characters(), nullptr, 16); m_editor->set_position(new_offset); @@ -174,7 +174,7 @@ HexEditorWidget::HexEditorWidget() auto edit_menu = GUI::Menu::construct("Edit"); edit_menu->add_action(GUI::Action::create("Fill selection...", { Mod_Ctrl, Key_B }, [&](const GUI::Action&) { - auto input_box = GUI::InputBox::construct("Fill byte (hex):", "Fill Selection", this); + auto input_box = GUI::InputBox::construct("Fill byte (hex):", "Fill Selection", window()); if (input_box->exec() == GUI::InputBox::ExecOK && !input_box->text_value().is_empty()) { auto fill_byte = strtol(input_box->text_value().characters(), nullptr, 16); m_editor->fill_selection(fill_byte); diff --git a/Applications/IRCClient/IRCAppWindow.cpp b/Applications/IRCClient/IRCAppWindow.cpp index 908453ad11..376f2a7fd6 100644 --- a/Applications/IRCClient/IRCAppWindow.cpp +++ b/Applications/IRCClient/IRCAppWindow.cpp @@ -94,12 +94,12 @@ void IRCAppWindow::setup_client() }; if (m_client->hostname().is_empty()) { - auto& input_box = add<GUI::InputBox>("Enter server:", "Connect to server"); - auto result = input_box.exec(); + auto input_box = GUI::InputBox::construct("Enter server:", "Connect to server", this); + auto result = input_box->exec(); if (result == GUI::InputBox::ExecCancel) ::exit(0); - m_client->set_server(input_box.text_value(), 6667); + m_client->set_server(input_box->text_value(), 6667); } update_title(); bool success = m_client->connect(); @@ -109,9 +109,9 @@ void IRCAppWindow::setup_client() void IRCAppWindow::setup_actions() { m_join_action = GUI::Action::create("Join channel", { Mod_Ctrl, Key_J }, Gfx::Bitmap::load_from_file("/res/icons/16x16/irc-join.png"), [&](auto&) { - auto& input_box = add<GUI::InputBox>("Enter channel name:", "Join channel"); - if (input_box.exec() == GUI::InputBox::ExecOK && !input_box.text_value().is_empty()) - m_client->handle_join_action(input_box.text_value()); + auto input_box = GUI::InputBox::construct("Enter channel name:", "Join channel", this); + if (input_box->exec() == GUI::InputBox::ExecOK && !input_box->text_value().is_empty()) + m_client->handle_join_action(input_box->text_value()); }); m_part_action = GUI::Action::create("Part from channel", { Mod_Ctrl, Key_P }, Gfx::Bitmap::load_from_file("/res/icons/16x16/irc-part.png"), [this](auto&) { diff --git a/DevTools/HackStudio/main.cpp b/DevTools/HackStudio/main.cpp index 8ab77927a9..4c2bab762c 100644 --- a/DevTools/HackStudio/main.cpp +++ b/DevTools/HackStudio/main.cpp @@ -175,10 +175,10 @@ int main(int argc, char** argv) }; auto new_action = GUI::Action::create("Add new file to project...", { Mod_Ctrl, Key_N }, Gfx::Bitmap::load_from_file("/res/icons/16x16/new.png"), [&](const GUI::Action&) { - auto& input_box = g_window->add<GUI::InputBox>("Enter name of new file:", "Add new file to project"); - if (input_box.exec() == GUI::InputBox::ExecCancel) + auto input_box = GUI::InputBox::construct("Enter name of new file:", "Add new file to project", g_window); + if (input_box->exec() == GUI::InputBox::ExecCancel) return; - auto filename = input_box.text_value(); + auto filename = input_box->text_value(); auto file = Core::File::construct(filename); if (!file->open((Core::IODevice::OpenMode)(Core::IODevice::WriteOnly | Core::IODevice::MustBeNew))) { GUI::MessageBox::show(String::format("Failed to create '%s'", filename.characters()), "Error", GUI::MessageBox::Type::Error, GUI::MessageBox::InputType::OK, g_window); diff --git a/Libraries/LibGUI/AboutDialog.cpp b/Libraries/LibGUI/AboutDialog.cpp index 12b43c3f40..9fe9f836bf 100644 --- a/Libraries/LibGUI/AboutDialog.cpp +++ b/Libraries/LibGUI/AboutDialog.cpp @@ -33,8 +33,8 @@ namespace GUI { -AboutDialog::AboutDialog(const StringView& name, const Gfx::Bitmap* icon, Core::Object* parent) - : Dialog(parent) +AboutDialog::AboutDialog(const StringView& name, const Gfx::Bitmap* icon, Window* parent_window) + : Dialog(parent_window) , m_name(name) , m_icon(icon) { diff --git a/Libraries/LibGUI/AboutDialog.h b/Libraries/LibGUI/AboutDialog.h index 265f8c2fa0..562f404c17 100644 --- a/Libraries/LibGUI/AboutDialog.h +++ b/Libraries/LibGUI/AboutDialog.h @@ -35,14 +35,14 @@ class AboutDialog final : public Dialog { public: virtual ~AboutDialog() override; - static void show(const StringView& name, const Gfx::Bitmap* icon = nullptr, Core::Object* parent = nullptr) + static void show(const StringView& name, const Gfx::Bitmap* icon = nullptr, Window* parent_window = nullptr) { - auto dialog = AboutDialog::construct(name, icon, parent); + auto dialog = AboutDialog::construct(name, icon, parent_window); dialog->exec(); } private: - AboutDialog(const StringView& name, const Gfx::Bitmap* icon = nullptr, Core::Object* parent = nullptr); + AboutDialog(const StringView& name, const Gfx::Bitmap* icon = nullptr, Window* parent_window = nullptr); String m_name; RefPtr<Gfx::Bitmap> m_icon; diff --git a/Libraries/LibGUI/ColorPicker.cpp b/Libraries/LibGUI/ColorPicker.cpp index 7640812a5b..e58059481e 100644 --- a/Libraries/LibGUI/ColorPicker.cpp +++ b/Libraries/LibGUI/ColorPicker.cpp @@ -34,8 +34,8 @@ namespace GUI { -ColorPicker::ColorPicker(Color color, Core::Object* parent) - : Dialog(parent) +ColorPicker::ColorPicker(Color color, Window* parent_window) + : Dialog(parent_window) , m_color(color) { set_title("Edit Color"); diff --git a/Libraries/LibGUI/ColorPicker.h b/Libraries/LibGUI/ColorPicker.h index d4d3548f1e..3aeea23384 100644 --- a/Libraries/LibGUI/ColorPicker.h +++ b/Libraries/LibGUI/ColorPicker.h @@ -38,7 +38,7 @@ public: Color color() const { return m_color; } private: - explicit ColorPicker(Color, Core::Object* parent = nullptr); + explicit ColorPicker(Color, Window* parent_window = nullptr); void build(); diff --git a/Libraries/LibGUI/Dialog.cpp b/Libraries/LibGUI/Dialog.cpp index 9c4468b112..491fbfb8d0 100644 --- a/Libraries/LibGUI/Dialog.cpp +++ b/Libraries/LibGUI/Dialog.cpp @@ -31,8 +31,8 @@ namespace GUI { -Dialog::Dialog(Core::Object* parent) - : Window(parent) +Dialog::Dialog(Window* parent_window) + : Window(parent_window) { set_modal(true); } diff --git a/Libraries/LibGUI/Dialog.h b/Libraries/LibGUI/Dialog.h index 10de2981a5..857177d64c 100644 --- a/Libraries/LibGUI/Dialog.h +++ b/Libraries/LibGUI/Dialog.h @@ -53,7 +53,7 @@ public: virtual void close() override; protected: - explicit Dialog(Core::Object* parent); + explicit Dialog(Window* parent_window); private: OwnPtr<Core::EventLoop> m_event_loop; diff --git a/Libraries/LibGUI/FilePicker.cpp b/Libraries/LibGUI/FilePicker.cpp index 3936f038fe..575fb47c29 100644 --- a/Libraries/LibGUI/FilePicker.cpp +++ b/Libraries/LibGUI/FilePicker.cpp @@ -74,8 +74,8 @@ Optional<String> FilePicker::get_save_filepath(const String& title, const String return {}; } -FilePicker::FilePicker(Mode mode, const StringView& file_name, const StringView& path, Core::Object* parent) - : Dialog(parent) +FilePicker::FilePicker(Mode mode, const StringView& file_name, const StringView& path, Window* parent_window) + : Dialog(parent_window) , m_model(FileSystemModel::create()) , m_mode(mode) { diff --git a/Libraries/LibGUI/FilePicker.h b/Libraries/LibGUI/FilePicker.h index 2fc98b2a04..99d577d721 100644 --- a/Libraries/LibGUI/FilePicker.h +++ b/Libraries/LibGUI/FilePicker.h @@ -52,7 +52,7 @@ private: void clear_preview(); void on_file_return(); - FilePicker(Mode type = Mode::Open, const StringView& file_name = "Untitled", const StringView& path = String(get_current_user_home_path()), Core::Object* parent = nullptr); + FilePicker(Mode type = Mode::Open, const StringView& file_name = "Untitled", const StringView& path = String(get_current_user_home_path()), Window* parent_window = nullptr); static String ok_button_name(Mode mode) { diff --git a/Libraries/LibGUI/InputBox.cpp b/Libraries/LibGUI/InputBox.cpp index aada52ddcb..7a0a22918d 100644 --- a/Libraries/LibGUI/InputBox.cpp +++ b/Libraries/LibGUI/InputBox.cpp @@ -34,8 +34,8 @@ namespace GUI { -InputBox::InputBox(const StringView& prompt, const StringView& title, Core::Object* parent) - : Dialog(parent) +InputBox::InputBox(const StringView& prompt, const StringView& title, GUI::Window* parent_window) + : Dialog(parent_window) , m_prompt(prompt) { set_title(title); diff --git a/Libraries/LibGUI/InputBox.h b/Libraries/LibGUI/InputBox.h index 1d0bd47e24..4df9917eee 100644 --- a/Libraries/LibGUI/InputBox.h +++ b/Libraries/LibGUI/InputBox.h @@ -33,7 +33,7 @@ namespace GUI { class InputBox : public Dialog { C_OBJECT(InputBox) public: - explicit InputBox(const StringView& prompt, const StringView& title, Core::Object* parent = nullptr); + explicit InputBox(const StringView& prompt, const StringView& title, Window* parent_window = nullptr); virtual ~InputBox() override; String text_value() const { return m_text_value; } diff --git a/Libraries/LibGUI/MessageBox.cpp b/Libraries/LibGUI/MessageBox.cpp index 952ace264c..750f1ccaaa 100644 --- a/Libraries/LibGUI/MessageBox.cpp +++ b/Libraries/LibGUI/MessageBox.cpp @@ -33,16 +33,16 @@ namespace GUI { -int MessageBox::show(const StringView& text, const StringView& title, Type type, InputType input_type, Core::Object* parent) +int MessageBox::show(const StringView& text, const StringView& title, Type type, InputType input_type, Window* parent_window) { auto box = MessageBox::construct(text, title, type, input_type); - if (parent) - parent->add_child(box); + if (parent_window) + parent_window->add_child(box); return box->exec(); } -MessageBox::MessageBox(const StringView& text, const StringView& title, Type type, InputType input_type, Core::Object* parent) - : Dialog(parent) +MessageBox::MessageBox(const StringView& text, const StringView& title, Type type, InputType input_type, Window* parent_window) + : Dialog(parent_window) , m_text(text) , m_type(type) , m_input_type(input_type) diff --git a/Libraries/LibGUI/MessageBox.h b/Libraries/LibGUI/MessageBox.h index bcf7232774..0d7ea6f96e 100644 --- a/Libraries/LibGUI/MessageBox.h +++ b/Libraries/LibGUI/MessageBox.h @@ -49,10 +49,10 @@ public: virtual ~MessageBox() override; - static int show(const StringView& text, const StringView& title, Type type = Type::None, InputType = InputType::OK, Core::Object* parent = nullptr); + static int show(const StringView& text, const StringView& title, Type type = Type::None, InputType = InputType::OK, Window* parent_window = nullptr); private: - explicit MessageBox(const StringView& text, const StringView& title, Type type = Type::None, InputType = InputType::OK, Core::Object* parent = nullptr); + explicit MessageBox(const StringView& text, const StringView& title, Type type = Type::None, InputType = InputType::OK, Window* parent_window = nullptr); bool should_include_ok_button() const; bool should_include_cancel_button() const; |