mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-08 12:19:37 +03:00
SQLStudio: Simplify action handling a bit
Most actions do not need to care about whether there is an open editor tab, as we can (and should) disable those actions when there isn't an open tab. We can also hide the verify_cast handling inside a helper function.
This commit is contained in:
parent
b8e4ca3b0f
commit
74cd0a0c82
Notes:
sideshowbarker
2024-07-17 06:24:08 +09:00
Author: https://github.com/trflynn89 Commit: https://github.com/SerenityOS/serenity/commit/74cd0a0c82 Pull-request: https://github.com/SerenityOS/serenity/pull/16710
@ -1,5 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2022, Dylan Katz <dykatz@uw.edu>
|
* Copyright (c) 2022, Dylan Katz <dykatz@uw.edu>
|
||||||
|
* Copyright (c) 2022, Tim Flynn <trflynn89@serenityos.org>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
@ -44,104 +45,83 @@ MainWidget::MainWidget()
|
|||||||
});
|
});
|
||||||
|
|
||||||
m_open_action = GUI::CommonActions::make_open_action([&](auto&) {
|
m_open_action = GUI::CommonActions::make_open_action([&](auto&) {
|
||||||
auto maybe_load_path = GUI::FilePicker::get_open_filepath(window());
|
if (auto result = GUI::FilePicker::get_open_filepath(window()); result.has_value())
|
||||||
if (!maybe_load_path.has_value())
|
open_script_from_file(LexicalPath { result.release_value() });
|
||||||
return;
|
|
||||||
auto lexical_path = LexicalPath(maybe_load_path.release_value());
|
|
||||||
open_script_from_file(lexical_path);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
m_save_action = GUI::CommonActions::make_save_action([&](auto&) {
|
m_save_action = GUI::CommonActions::make_save_action([&](auto&) {
|
||||||
if (!m_tab_widget)
|
auto* editor = active_editor();
|
||||||
return;
|
VERIFY(editor);
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
|
||||||
if (!editor)
|
if (auto result = editor->save(); result.is_error())
|
||||||
return;
|
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save {}\n{}", editor->path(), result.error()));
|
||||||
auto save_attempt = editor->save();
|
|
||||||
if (save_attempt.is_error())
|
|
||||||
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save\n{}", save_attempt.release_error()));
|
|
||||||
});
|
});
|
||||||
|
|
||||||
m_save_as_action = GUI::CommonActions::make_save_as_action([&](auto&) {
|
m_save_as_action = GUI::CommonActions::make_save_as_action([&](auto&) {
|
||||||
if (!m_tab_widget)
|
auto* editor = active_editor();
|
||||||
return;
|
VERIFY(editor);
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
|
||||||
if (!editor)
|
if (auto result = editor->save_as(); result.is_error())
|
||||||
return;
|
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save {}\n{}", editor->path(), result.error()));
|
||||||
auto save_attempt = editor->save_as();
|
|
||||||
if (save_attempt.is_error())
|
|
||||||
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save\n{}", save_attempt.release_error()));
|
|
||||||
});
|
});
|
||||||
|
|
||||||
m_save_all_action = GUI::Action::create("Save All", { Mod_Ctrl | Mod_Alt, Key_S }, [this](auto&) {
|
m_save_all_action = GUI::Action::create("Save All", { Mod_Ctrl | Mod_Alt, Key_S }, [this](auto&) {
|
||||||
auto current_active_widget = m_tab_widget->active_widget();
|
auto* editor = active_editor();
|
||||||
ErrorOr<void> error {};
|
VERIFY(editor);
|
||||||
|
|
||||||
m_tab_widget->for_each_child_widget([&](auto& child) {
|
m_tab_widget->for_each_child_widget([&](auto& child) {
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(&child);
|
auto& editor = verify_cast<ScriptEditor>(child);
|
||||||
if (!editor)
|
m_tab_widget->set_active_widget(&editor);
|
||||||
return IterationDecision::Continue;
|
|
||||||
m_tab_widget->set_active_widget(editor);
|
if (auto result = editor.save(); result.is_error()) {
|
||||||
auto save_attempt = editor->save();
|
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save {}\n{}", editor.path(), result.error()));
|
||||||
if (save_attempt.is_error()) {
|
return IterationDecision::Break;
|
||||||
error = save_attempt.release_error();
|
} else if (!result.value()) {
|
||||||
return IterationDecision::Break;
|
return IterationDecision::Break;
|
||||||
}
|
}
|
||||||
auto save_result = save_attempt.release_value();
|
|
||||||
if (save_result)
|
return IterationDecision::Continue;
|
||||||
return IterationDecision::Continue;
|
|
||||||
return IterationDecision::Break;
|
|
||||||
});
|
});
|
||||||
if (error.is_error())
|
|
||||||
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save all files\n{}", error.release_error()));
|
m_tab_widget->set_active_widget(editor);
|
||||||
m_tab_widget->set_active_widget(current_active_widget);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
m_copy_action = GUI::CommonActions::make_copy_action([&](auto&) {
|
m_copy_action = GUI::CommonActions::make_copy_action([&](auto&) {
|
||||||
if (!m_tab_widget)
|
auto* editor = active_editor();
|
||||||
return;
|
VERIFY(editor);
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
|
||||||
if (!editor)
|
|
||||||
return;
|
|
||||||
editor->copy_action().activate();
|
editor->copy_action().activate();
|
||||||
update_editor_actions(editor);
|
update_editor_actions(editor);
|
||||||
});
|
});
|
||||||
|
|
||||||
m_cut_action = GUI::CommonActions::make_cut_action([&](auto&) {
|
m_cut_action = GUI::CommonActions::make_cut_action([&](auto&) {
|
||||||
if (!m_tab_widget)
|
auto* editor = active_editor();
|
||||||
return;
|
VERIFY(editor);
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
|
||||||
if (!editor)
|
|
||||||
return;
|
|
||||||
editor->cut_action().activate();
|
editor->cut_action().activate();
|
||||||
update_editor_actions(editor);
|
update_editor_actions(editor);
|
||||||
});
|
});
|
||||||
|
|
||||||
m_paste_action = GUI::CommonActions::make_paste_action([&](auto&) {
|
m_paste_action = GUI::CommonActions::make_paste_action([&](auto&) {
|
||||||
if (!m_tab_widget)
|
auto* editor = active_editor();
|
||||||
return;
|
VERIFY(editor);
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
|
||||||
if (!editor)
|
|
||||||
return;
|
|
||||||
editor->paste_action().activate();
|
editor->paste_action().activate();
|
||||||
update_editor_actions(editor);
|
update_editor_actions(editor);
|
||||||
});
|
});
|
||||||
|
|
||||||
m_undo_action = GUI::CommonActions::make_undo_action([&](auto&) {
|
m_undo_action = GUI::CommonActions::make_undo_action([&](auto&) {
|
||||||
if (!m_tab_widget)
|
auto* editor = active_editor();
|
||||||
return;
|
VERIFY(editor);
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
|
||||||
if (!editor)
|
|
||||||
return;
|
|
||||||
editor->document().undo();
|
editor->document().undo();
|
||||||
update_editor_actions(editor);
|
update_editor_actions(editor);
|
||||||
});
|
});
|
||||||
|
|
||||||
m_redo_action = GUI::CommonActions::make_redo_action([&](auto&) {
|
m_redo_action = GUI::CommonActions::make_redo_action([&](auto&) {
|
||||||
if (!m_tab_widget)
|
auto* editor = active_editor();
|
||||||
return;
|
VERIFY(editor);
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
|
||||||
if (!editor)
|
|
||||||
return;
|
|
||||||
editor->document().redo();
|
editor->document().redo();
|
||||||
update_editor_actions(editor);
|
update_editor_actions(editor);
|
||||||
});
|
});
|
||||||
@ -179,16 +159,12 @@ MainWidget::MainWidget()
|
|||||||
m_tab_widget = find_descendant_of_type_named<GUI::TabWidget>("script_tab_widget"sv);
|
m_tab_widget = find_descendant_of_type_named<GUI::TabWidget>("script_tab_widget"sv);
|
||||||
|
|
||||||
m_tab_widget->on_tab_close_click = [&](auto& widget) {
|
m_tab_widget->on_tab_close_click = [&](auto& widget) {
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(&widget);
|
auto& editor = verify_cast<ScriptEditor>(widget);
|
||||||
if (!editor)
|
|
||||||
return;
|
if (auto result = editor.attempt_to_close(); result.is_error()) {
|
||||||
auto close_attempt = editor->attempt_to_close();
|
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save {}\n{}", editor.path(), result.error()));
|
||||||
if (close_attempt.is_error()) {
|
} else if (result.value()) {
|
||||||
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to save before closing\n{}", close_attempt.release_error()));
|
m_tab_widget->remove_tab(editor);
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (close_attempt.release_value()) {
|
|
||||||
m_tab_widget->remove_tab(widget);
|
|
||||||
update_title();
|
update_title();
|
||||||
on_editor_change();
|
on_editor_change();
|
||||||
}
|
}
|
||||||
@ -298,9 +274,9 @@ void MainWidget::open_new_script()
|
|||||||
void MainWidget::open_script_from_file(LexicalPath const& file_path)
|
void MainWidget::open_script_from_file(LexicalPath const& file_path)
|
||||||
{
|
{
|
||||||
auto& editor = m_tab_widget->add_tab<ScriptEditor>(file_path.title());
|
auto& editor = m_tab_widget->add_tab<ScriptEditor>(file_path.title());
|
||||||
auto maybe_error = editor.open_script_from_file(file_path);
|
|
||||||
if (maybe_error.is_error()) {
|
if (auto result = editor.open_script_from_file(file_path); result.is_error()) {
|
||||||
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to open {}\n{}", file_path, maybe_error.release_error()));
|
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Failed to open {}\n{}", file_path, result.error()));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -320,15 +296,16 @@ bool MainWidget::request_close()
|
|||||||
{
|
{
|
||||||
auto any_scripts_modified { false };
|
auto any_scripts_modified { false };
|
||||||
auto is_script_modified = [&](auto& child) {
|
auto is_script_modified = [&](auto& child) {
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(&child);
|
auto& editor = verify_cast<ScriptEditor>(child);
|
||||||
if (!editor)
|
|
||||||
return IterationDecision::Continue;
|
if (editor.document().is_modified()) {
|
||||||
if (editor->document().is_modified()) {
|
|
||||||
any_scripts_modified = true;
|
any_scripts_modified = true;
|
||||||
return IterationDecision::Break;
|
return IterationDecision::Break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return IterationDecision::Continue;
|
return IterationDecision::Continue;
|
||||||
};
|
};
|
||||||
|
|
||||||
m_tab_widget->for_each_child_widget(is_script_modified);
|
m_tab_widget->for_each_child_widget(is_script_modified);
|
||||||
if (!any_scripts_modified)
|
if (!any_scripts_modified)
|
||||||
return true;
|
return true;
|
||||||
@ -345,23 +322,29 @@ bool MainWidget::request_close()
|
|||||||
|
|
||||||
m_save_all_action->activate();
|
m_save_all_action->activate();
|
||||||
any_scripts_modified = false;
|
any_scripts_modified = false;
|
||||||
|
|
||||||
m_tab_widget->for_each_child_widget(is_script_modified);
|
m_tab_widget->for_each_child_widget(is_script_modified);
|
||||||
return !any_scripts_modified;
|
return !any_scripts_modified;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ScriptEditor* MainWidget::active_editor()
|
||||||
|
{
|
||||||
|
if (!m_tab_widget || !m_tab_widget->active_widget())
|
||||||
|
return nullptr;
|
||||||
|
return verify_cast<ScriptEditor>(m_tab_widget->active_widget());
|
||||||
|
}
|
||||||
|
|
||||||
void MainWidget::update_title()
|
void MainWidget::update_title()
|
||||||
{
|
{
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
if (auto* editor = active_editor())
|
||||||
if (editor) {
|
|
||||||
window()->set_title(DeprecatedString::formatted("{} - SQL Studio", editor->name()));
|
window()->set_title(DeprecatedString::formatted("{} - SQL Studio", editor->name()));
|
||||||
} else {
|
else
|
||||||
window()->set_title("SQL Studio");
|
window()->set_title("SQL Studio");
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWidget::on_editor_change()
|
void MainWidget::on_editor_change()
|
||||||
{
|
{
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
auto* editor = active_editor();
|
||||||
update_statusbar(editor);
|
update_statusbar(editor);
|
||||||
update_editor_actions(editor);
|
update_editor_actions(editor);
|
||||||
}
|
}
|
||||||
@ -390,18 +373,28 @@ void MainWidget::update_statusbar(ScriptEditor* editor)
|
|||||||
void MainWidget::update_editor_actions(ScriptEditor* editor)
|
void MainWidget::update_editor_actions(ScriptEditor* editor)
|
||||||
{
|
{
|
||||||
if (!editor) {
|
if (!editor) {
|
||||||
|
m_save_action->set_enabled(false);
|
||||||
|
m_save_as_action->set_enabled(false);
|
||||||
|
m_save_all_action->set_enabled(false);
|
||||||
|
m_run_script_action->set_enabled(false);
|
||||||
|
|
||||||
m_copy_action->set_enabled(false);
|
m_copy_action->set_enabled(false);
|
||||||
m_cut_action->set_enabled(false);
|
m_cut_action->set_enabled(false);
|
||||||
m_paste_action->set_enabled(false);
|
m_paste_action->set_enabled(false);
|
||||||
m_undo_action->set_enabled(false);
|
m_undo_action->set_enabled(false);
|
||||||
m_redo_action->set_enabled(false);
|
m_redo_action->set_enabled(false);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_save_action->set_enabled(true);
|
||||||
|
m_save_as_action->set_enabled(true);
|
||||||
|
m_save_all_action->set_enabled(true);
|
||||||
|
m_run_script_action->set_enabled(true);
|
||||||
|
|
||||||
m_copy_action->set_enabled(editor->copy_action().is_enabled());
|
m_copy_action->set_enabled(editor->copy_action().is_enabled());
|
||||||
m_cut_action->set_enabled(editor->cut_action().is_enabled());
|
m_cut_action->set_enabled(editor->cut_action().is_enabled());
|
||||||
m_paste_action->set_enabled(editor->paste_action().is_enabled());
|
m_paste_action->set_enabled(editor->paste_action().is_enabled());
|
||||||
|
|
||||||
m_undo_action->set_enabled(editor->undo_action().is_enabled());
|
m_undo_action->set_enabled(editor->undo_action().is_enabled());
|
||||||
m_redo_action->set_enabled(editor->redo_action().is_enabled());
|
m_redo_action->set_enabled(editor->redo_action().is_enabled());
|
||||||
}
|
}
|
||||||
@ -492,7 +485,7 @@ void MainWidget::read_next_sql_statement_of_editor()
|
|||||||
if (auto statement_id = m_sql_client->prepare_statement(m_connection_id, sql_statement); statement_id.has_value()) {
|
if (auto statement_id = m_sql_client->prepare_statement(m_connection_id, sql_statement); statement_id.has_value()) {
|
||||||
m_sql_client->async_execute_statement(*statement_id, {});
|
m_sql_client->async_execute_statement(*statement_id, {});
|
||||||
} else {
|
} else {
|
||||||
auto* editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
auto* editor = active_editor();
|
||||||
VERIFY(editor);
|
VERIFY(editor);
|
||||||
|
|
||||||
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Could not parse {}\n{}", editor->path(), sql_statement));
|
GUI::MessageBox::show_error(window(), DeprecatedString::formatted("Could not parse {}\n{}", editor->path(), sql_statement));
|
||||||
@ -501,16 +494,16 @@ void MainWidget::read_next_sql_statement_of_editor()
|
|||||||
|
|
||||||
Optional<DeprecatedString> MainWidget::read_next_line_of_editor()
|
Optional<DeprecatedString> MainWidget::read_next_line_of_editor()
|
||||||
{
|
{
|
||||||
auto editor = dynamic_cast<ScriptEditor*>(m_tab_widget->active_widget());
|
auto* editor = active_editor();
|
||||||
if (!editor)
|
if (!editor)
|
||||||
return {};
|
return {};
|
||||||
if (m_current_line_for_parsing < editor->document().line_count()) {
|
|
||||||
DeprecatedString result = editor->document().line(m_current_line_for_parsing).to_utf8();
|
if (m_current_line_for_parsing >= editor->document().line_count())
|
||||||
m_current_line_for_parsing++;
|
|
||||||
return result;
|
|
||||||
} else {
|
|
||||||
return {};
|
return {};
|
||||||
}
|
|
||||||
|
auto result = editor->document().line(m_current_line_for_parsing).to_utf8();
|
||||||
|
++m_current_line_for_parsing;
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2022, Dylan Katz <dykatz@uw.edu>
|
* Copyright (c) 2022, Dylan Katz <dykatz@uw.edu>
|
||||||
|
* Copyright (c) 2022, Tim Flynn <trflynn89@serenityos.org>
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
* SPDX-License-Identifier: BSD-2-Clause
|
||||||
*/
|
*/
|
||||||
@ -31,6 +32,8 @@ public:
|
|||||||
private:
|
private:
|
||||||
MainWidget();
|
MainWidget();
|
||||||
|
|
||||||
|
ScriptEditor* active_editor();
|
||||||
|
|
||||||
void update_title();
|
void update_title();
|
||||||
void on_editor_change();
|
void on_editor_change();
|
||||||
void update_statusbar(ScriptEditor*);
|
void update_statusbar(ScriptEditor*);
|
||||||
|
Loading…
Reference in New Issue
Block a user