mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 16:57:46 +00:00
Userland: Add GUI::Window::add_menu() and use it everywhere
Applications previously had to create a GUI::Menubar object, add menus to it, and then call GUI::Window::set_menubar(). This patch introduces GUI::Window::add_menu() which creates the menubar automatically and adds items to it. Application code becomes slightly simpler as a result. :^)
This commit is contained in:
parent
a4fdb7f029
commit
687a12d7fb
58 changed files with 187 additions and 311 deletions
|
@ -922,9 +922,9 @@ void HackStudioWidget::create_project_tab(GUI::Widget& parent)
|
|||
};
|
||||
}
|
||||
|
||||
void HackStudioWidget::create_file_menubar(GUI::Menubar& menubar)
|
||||
void HackStudioWidget::create_file_menu(GUI::Window& window)
|
||||
{
|
||||
auto& file_menu = menubar.add_menu("&File");
|
||||
auto& file_menu = window.add_menu("&File");
|
||||
file_menu.add_action(*m_new_project_action);
|
||||
file_menu.add_action(*m_open_action);
|
||||
file_menu.add_action(*m_save_action);
|
||||
|
@ -934,16 +934,16 @@ void HackStudioWidget::create_file_menubar(GUI::Menubar& menubar)
|
|||
}));
|
||||
}
|
||||
|
||||
void HackStudioWidget::create_project_menubar(GUI::Menubar& menubar)
|
||||
void HackStudioWidget::create_project_menu(GUI::Window& window)
|
||||
{
|
||||
auto& project_menu = menubar.add_menu("&Project");
|
||||
auto& project_menu = window.add_menu("&Project");
|
||||
project_menu.add_action(*m_new_file_action);
|
||||
project_menu.add_action(*m_new_directory_action);
|
||||
}
|
||||
|
||||
void HackStudioWidget::create_edit_menubar(GUI::Menubar& menubar)
|
||||
void HackStudioWidget::create_edit_menu(GUI::Window& window)
|
||||
{
|
||||
auto& edit_menu = menubar.add_menu("&Edit");
|
||||
auto& edit_menu = window.add_menu("&Edit");
|
||||
edit_menu.add_action(GUI::Action::create("&Find in Files...", { Mod_Ctrl | Mod_Shift, Key_F }, Gfx::Bitmap::try_load_from_file("/res/icons/16x16/find.png"), [this](auto&) {
|
||||
reveal_action_tab(*m_find_in_files_widget);
|
||||
m_find_in_files_widget->focus_textbox_and_select_all();
|
||||
|
@ -961,9 +961,9 @@ void HackStudioWidget::create_edit_menubar(GUI::Menubar& menubar)
|
|||
edit_menu.add_action(vim_emulation_setting_action);
|
||||
}
|
||||
|
||||
void HackStudioWidget::create_build_menubar(GUI::Menubar& menubar)
|
||||
void HackStudioWidget::create_build_menu(GUI::Window& window)
|
||||
{
|
||||
auto& build_menu = menubar.add_menu("&Build");
|
||||
auto& build_menu = window.add_menu("&Build");
|
||||
build_menu.add_action(*m_build_action);
|
||||
build_menu.add_separator();
|
||||
build_menu.add_action(*m_run_action);
|
||||
|
@ -972,7 +972,7 @@ void HackStudioWidget::create_build_menubar(GUI::Menubar& menubar)
|
|||
build_menu.add_action(*m_debug_action);
|
||||
}
|
||||
|
||||
void HackStudioWidget::create_view_menubar(GUI::Menubar& menubar)
|
||||
void HackStudioWidget::create_view_menu(GUI::Window& window)
|
||||
{
|
||||
auto hide_action_tabs_action = GUI::Action::create("&Hide Action Tabs", { Mod_Ctrl | Mod_Shift, Key_X }, [this](auto&) {
|
||||
hide_action_tabs();
|
||||
|
@ -981,7 +981,7 @@ void HackStudioWidget::create_view_menubar(GUI::Menubar& menubar)
|
|||
m_locator->open();
|
||||
});
|
||||
|
||||
auto& view_menu = menubar.add_menu("&View");
|
||||
auto& view_menu = window.add_menu("&View");
|
||||
view_menu.add_action(hide_action_tabs_action);
|
||||
view_menu.add_action(open_locator_action);
|
||||
view_menu.add_separator();
|
||||
|
@ -1018,10 +1018,10 @@ void HackStudioWidget::create_view_menubar(GUI::Menubar& menubar)
|
|||
view_menu.add_action(*m_remove_current_terminal_action);
|
||||
}
|
||||
|
||||
void HackStudioWidget::create_help_menubar(GUI::Menubar& menubar)
|
||||
void HackStudioWidget::create_help_menu(GUI::Window& window)
|
||||
{
|
||||
auto& help_menu = menubar.add_menu("&Help");
|
||||
help_menu.add_action(GUI::CommonActions::make_about_action("Hack Studio", GUI::Icon::default_icon("app-hack-studio"), window()));
|
||||
auto& help_menu = window.add_menu("&Help");
|
||||
help_menu.add_action(GUI::CommonActions::make_about_action("Hack Studio", GUI::Icon::default_icon("app-hack-studio"), &window));
|
||||
}
|
||||
|
||||
NonnullRefPtr<GUI::Action> HackStudioWidget::create_stop_action()
|
||||
|
@ -1039,14 +1039,14 @@ NonnullRefPtr<GUI::Action> HackStudioWidget::create_stop_action()
|
|||
return action;
|
||||
}
|
||||
|
||||
void HackStudioWidget::initialize_menubar(GUI::Menubar& menubar)
|
||||
void HackStudioWidget::initialize_menubar(GUI::Window& window)
|
||||
{
|
||||
create_file_menubar(menubar);
|
||||
create_project_menubar(menubar);
|
||||
create_edit_menubar(menubar);
|
||||
create_build_menubar(menubar);
|
||||
create_view_menubar(menubar);
|
||||
create_help_menubar(menubar);
|
||||
create_file_menu(window);
|
||||
create_project_menu(window);
|
||||
create_edit_menu(window);
|
||||
create_build_menu(window);
|
||||
create_view_menu(window);
|
||||
create_help_menu(window);
|
||||
}
|
||||
|
||||
void HackStudioWidget::update_statusbar()
|
||||
|
|
|
@ -42,7 +42,7 @@ public:
|
|||
void set_current_editor_wrapper(RefPtr<EditorWrapper>);
|
||||
|
||||
const String& active_file() const { return m_current_editor_wrapper->filename(); }
|
||||
void initialize_menubar(GUI::Menubar&);
|
||||
void initialize_menubar(GUI::Window&);
|
||||
|
||||
Locator& locator()
|
||||
{
|
||||
|
@ -104,12 +104,12 @@ private:
|
|||
void create_open_files_view(GUI::Widget& parent);
|
||||
void create_toolbar(GUI::Widget& parent);
|
||||
void create_action_tab(GUI::Widget& parent);
|
||||
void create_file_menubar(GUI::Menubar&);
|
||||
void create_project_menubar(GUI::Menubar&);
|
||||
void create_edit_menubar(GUI::Menubar&);
|
||||
void create_build_menubar(GUI::Menubar&);
|
||||
void create_view_menubar(GUI::Menubar&);
|
||||
void create_help_menubar(GUI::Menubar&);
|
||||
void create_file_menu(GUI::Window&);
|
||||
void create_project_menu(GUI::Window&);
|
||||
void create_edit_menu(GUI::Window&);
|
||||
void create_build_menu(GUI::Window&);
|
||||
void create_view_menu(GUI::Window&);
|
||||
void create_help_menu(GUI::Window&);
|
||||
void create_project_tab(GUI::Widget& parent);
|
||||
void configure_project_tree_view();
|
||||
|
||||
|
|
|
@ -66,9 +66,7 @@ int main(int argc, char** argv)
|
|||
|
||||
s_window->set_title(String::formatted("{} - Hack Studio", s_hack_studio_widget->project().name()));
|
||||
|
||||
auto menubar = GUI::Menubar::construct();
|
||||
s_hack_studio_widget->initialize_menubar(menubar);
|
||||
s_window->set_menubar(menubar);
|
||||
s_hack_studio_widget->initialize_menubar(*s_window);
|
||||
|
||||
s_window->on_close_request = [&]() -> GUI::Window::CloseRequestDecision {
|
||||
s_hack_studio_widget->locator().close();
|
||||
|
|
|
@ -113,12 +113,10 @@ int main(int argc, char** argv)
|
|||
window->resize(685, 500);
|
||||
window->set_icon(app_icon.bitmap_for_size(16));
|
||||
|
||||
auto menubar = GUI::Menubar::construct();
|
||||
|
||||
auto& file_menu = menubar->add_menu("&File");
|
||||
auto& file_menu = window->add_menu("&File");
|
||||
file_menu.add_action(GUI::CommonActions::make_quit_action([&](auto&) { app->quit(); }));
|
||||
|
||||
auto& help_menu = menubar->add_menu("&Help");
|
||||
auto& help_menu = window->add_menu("&Help");
|
||||
help_menu.add_action(GUI::CommonActions::make_help_action([](auto&) {
|
||||
Desktop::Launcher::open(URL::create_with_file_protocol("/usr/share/man/man1/Inspector.md"), "/bin/Help");
|
||||
}));
|
||||
|
@ -172,7 +170,6 @@ int main(int argc, char** argv)
|
|||
}
|
||||
};
|
||||
|
||||
window->set_menubar(move(menubar));
|
||||
window->show();
|
||||
remote_process.update();
|
||||
|
||||
|
|
|
@ -156,8 +156,7 @@ int main(int argc, char** argv)
|
|||
update_title();
|
||||
};
|
||||
|
||||
auto menubar = GUI::Menubar::construct();
|
||||
auto& file_menu = menubar->add_menu("&File");
|
||||
auto& file_menu = window->add_menu("&File");
|
||||
|
||||
auto save_as_action = GUI::CommonActions::make_save_as_action([&](auto&) {
|
||||
Optional<String> new_save_path = GUI::FilePicker::get_save_filepath(window, "Untitled", "gml");
|
||||
|
@ -223,7 +222,7 @@ int main(int argc, char** argv)
|
|||
app->quit();
|
||||
}));
|
||||
|
||||
auto& edit_menu = menubar->add_menu("&Edit");
|
||||
auto& edit_menu = window->add_menu("&Edit");
|
||||
edit_menu.add_action(GUI::Action::create("&Format GML", { Mod_Ctrl | Mod_Shift, Key_I }, [&](auto&) {
|
||||
auto source = editor.text();
|
||||
GUI::GMLLexer lexer(source);
|
||||
|
@ -252,13 +251,12 @@ int main(int argc, char** argv)
|
|||
}
|
||||
}));
|
||||
|
||||
auto& help_menu = menubar->add_menu("&Help");
|
||||
auto& help_menu = window->add_menu("&Help");
|
||||
help_menu.add_action(GUI::CommonActions::make_help_action([](auto&) {
|
||||
Desktop::Launcher::open(URL::create_with_file_protocol("/usr/share/man/man1/Playground.md"), "/bin/Help");
|
||||
}));
|
||||
help_menu.add_action(GUI::CommonActions::make_about_action("GML Playground", app_icon, window));
|
||||
|
||||
window->set_menubar(move(menubar));
|
||||
window->on_close_request = [&] {
|
||||
if (!window->is_modified())
|
||||
return GUI::Window::CloseRequestDecision::Close;
|
||||
|
|
|
@ -191,11 +191,10 @@ int main(int argc, char** argv)
|
|||
statusbar.set_text(builder.to_string());
|
||||
};
|
||||
|
||||
auto menubar = GUI::Menubar::construct();
|
||||
auto& file_menu = menubar->add_menu("&File");
|
||||
auto& file_menu = window->add_menu("&File");
|
||||
file_menu.add_action(GUI::CommonActions::make_quit_action([&](auto&) { app->quit(); }));
|
||||
|
||||
auto& view_menu = menubar->add_menu("&View");
|
||||
auto& view_menu = window->add_menu("&View");
|
||||
|
||||
auto invert_action = GUI::Action::create_checkable("&Invert Tree", { Mod_Ctrl, Key_I }, [&](auto& action) {
|
||||
profile->set_inverted(action.is_checked());
|
||||
|
@ -219,13 +218,12 @@ int main(int argc, char** argv)
|
|||
|
||||
view_menu.add_action(disassembly_action);
|
||||
|
||||
auto& help_menu = menubar->add_menu("&Help");
|
||||
auto& help_menu = window->add_menu("&Help");
|
||||
help_menu.add_action(GUI::CommonActions::make_help_action([](auto&) {
|
||||
Desktop::Launcher::open(URL::create_with_file_protocol("/usr/share/man/man1/Profiler.md"), "/bin/Help");
|
||||
}));
|
||||
help_menu.add_action(GUI::CommonActions::make_about_action("Profiler", app_icon, window));
|
||||
|
||||
window->set_menubar(move(menubar));
|
||||
window->show();
|
||||
return app->exec();
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue