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

TerminalSettings: Port to GML Compiler

This commit is contained in:
Mr.UNIX 2024-01-18 15:07:55 +01:00 committed by Tim Schumacher
parent f6c32ea45e
commit 2440a2f83f
8 changed files with 39 additions and 39 deletions

View file

@ -4,19 +4,16 @@ serenity_component(
TARGETS TerminalSettings TARGETS TerminalSettings
) )
stringify_gml(TerminalSettingsMain.gml TerminalSettingsMainGML.h terminal_settings_main_gml) compile_gml(TerminalSettingsMain.gml TerminalSettingsMainGML.cpp)
stringify_gml(TerminalSettingsView.gml TerminalSettingsViewGML.h terminal_settings_view_gml) compile_gml(TerminalSettingsView.gml TerminalSettingsViewGML.cpp)
set(SOURCES set(SOURCES
TerminalSettingsMainGML.cpp
TerminalSettingsViewGML.cpp
MainWidget.cpp MainWidget.cpp
ViewWidget.cpp ViewWidget.cpp
main.cpp main.cpp
) )
set(GENERATED_SOURCES
TerminalSettingsMainGML.h
TerminalSettingsViewGML.h
)
serenity_app(TerminalSettings ICON app-terminal) serenity_app(TerminalSettings ICON app-terminal)
target_link_libraries(TerminalSettings PRIVATE LibCore LibGfx LibGUI LibConfig LibMain LibVT) target_link_libraries(TerminalSettings PRIVATE LibCore LibGfx LibGUI LibConfig LibMain LibVT)

View file

@ -8,7 +8,6 @@
#include <AK/Assertions.h> #include <AK/Assertions.h>
#include <AK/JsonObject.h> #include <AK/JsonObject.h>
#include <AK/QuickSort.h> #include <AK/QuickSort.h>
#include <Applications/TerminalSettings/TerminalSettingsMainGML.h>
#include <LibConfig/Client.h> #include <LibConfig/Client.h>
#include <LibCore/DirIterator.h> #include <LibCore/DirIterator.h>
#include <LibGUI/Application.h> #include <LibGUI/Application.h>
@ -28,17 +27,16 @@
#include <LibVT/TerminalWidget.h> #include <LibVT/TerminalWidget.h>
#include <spawn.h> #include <spawn.h>
ErrorOr<NonnullRefPtr<TerminalSettingsMainWidget>> TerminalSettingsMainWidget::try_create() namespace TerminalSettings {
ErrorOr<NonnullRefPtr<MainWidget>> MainWidget::create()
{ {
auto widget = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) TerminalSettingsMainWidget())); auto widget = MainWidget::try_create().release_value_but_fixme_should_propagate_errors();
TRY(widget->setup()); TRY(widget->setup());
return widget; return widget;
} }
ErrorOr<void> TerminalSettingsMainWidget::setup() ErrorOr<void> MainWidget::setup()
{ {
TRY(load_from_gml(terminal_settings_main_gml));
auto& beep_bell_radio = *find_descendant_of_type_named<GUI::RadioButton>("beep_bell_radio"); auto& beep_bell_radio = *find_descendant_of_type_named<GUI::RadioButton>("beep_bell_radio");
auto& visual_bell_radio = *find_descendant_of_type_named<GUI::RadioButton>("visual_bell_radio"); auto& visual_bell_radio = *find_descendant_of_type_named<GUI::RadioButton>("visual_bell_radio");
auto& no_bell_radio = *find_descendant_of_type_named<GUI::RadioButton>("no_bell_radio"); auto& no_bell_radio = *find_descendant_of_type_named<GUI::RadioButton>("no_bell_radio");
@ -86,7 +84,7 @@ ErrorOr<void> TerminalSettingsMainWidget::setup()
return {}; return {};
} }
VT::TerminalWidget::BellMode TerminalSettingsMainWidget::parse_bell(StringView bell_string) VT::TerminalWidget::BellMode MainWidget::parse_bell(StringView bell_string)
{ {
if (bell_string == "AudibleBeep") if (bell_string == "AudibleBeep")
return VT::TerminalWidget::BellMode::AudibleBeep; return VT::TerminalWidget::BellMode::AudibleBeep;
@ -97,7 +95,7 @@ VT::TerminalWidget::BellMode TerminalSettingsMainWidget::parse_bell(StringView b
VERIFY_NOT_REACHED(); VERIFY_NOT_REACHED();
} }
ByteString TerminalSettingsMainWidget::stringify_bell(VT::TerminalWidget::BellMode bell_mode) ByteString MainWidget::stringify_bell(VT::TerminalWidget::BellMode bell_mode)
{ {
if (bell_mode == VT::TerminalWidget::BellMode::AudibleBeep) if (bell_mode == VT::TerminalWidget::BellMode::AudibleBeep)
return "AudibleBeep"; return "AudibleBeep";
@ -108,19 +106,20 @@ ByteString TerminalSettingsMainWidget::stringify_bell(VT::TerminalWidget::BellMo
VERIFY_NOT_REACHED(); VERIFY_NOT_REACHED();
} }
void TerminalSettingsMainWidget::apply_settings() void MainWidget::apply_settings()
{ {
m_original_bell_mode = m_bell_mode; m_original_bell_mode = m_bell_mode;
m_orignal_confirm_close = m_confirm_close; m_orignal_confirm_close = m_confirm_close;
write_back_settings(); write_back_settings();
} }
void TerminalSettingsMainWidget::write_back_settings() const void MainWidget::write_back_settings() const
{ {
Config::write_bool("Terminal"sv, "Terminal"sv, "ConfirmClose"sv, m_orignal_confirm_close); Config::write_bool("Terminal"sv, "Terminal"sv, "ConfirmClose"sv, m_orignal_confirm_close);
Config::write_string("Terminal"sv, "Window"sv, "Bell"sv, stringify_bell(m_original_bell_mode)); Config::write_string("Terminal"sv, "Window"sv, "Bell"sv, stringify_bell(m_original_bell_mode));
} }
void TerminalSettingsMainWidget::cancel_settings() void MainWidget::cancel_settings()
{ {
write_back_settings(); write_back_settings();
} }
}

View file

@ -13,16 +13,18 @@
#include <LibGUI/TextEditor.h> #include <LibGUI/TextEditor.h>
#include <LibVT/TerminalWidget.h> #include <LibVT/TerminalWidget.h>
class TerminalSettingsMainWidget final : public GUI::SettingsWindow::Tab { namespace TerminalSettings {
class MainWidget final : public GUI::SettingsWindow::Tab {
C_OBJECT_ABSTRACT(TerminalSettingsMainWidget) C_OBJECT_ABSTRACT(TerminalSettingsMainWidget)
public: public:
static ErrorOr<NonnullRefPtr<TerminalSettingsMainWidget>> try_create(); static ErrorOr<NonnullRefPtr<MainWidget>> create();
virtual void apply_settings() override; virtual void apply_settings() override;
virtual void cancel_settings() override; virtual void cancel_settings() override;
private: private:
TerminalSettingsMainWidget() = default; static ErrorOr<NonnullRefPtr<MainWidget>> try_create();
MainWidget() = default;
ErrorOr<void> setup(); ErrorOr<void> setup();
void write_back_settings() const; void write_back_settings() const;
@ -35,3 +37,4 @@ private:
VT::TerminalWidget::BellMode m_original_bell_mode; VT::TerminalWidget::BellMode m_original_bell_mode;
bool m_orignal_confirm_close { true }; bool m_orignal_confirm_close { true };
}; };
}

View file

@ -1,4 +1,4 @@
@GUI::Widget { @TerminalSettings::MainWidget {
fill_with_background_color: true fill_with_background_color: true
layout: @GUI::VerticalBoxLayout { layout: @GUI::VerticalBoxLayout {
margins: [10] margins: [10]

View file

@ -1,4 +1,4 @@
@GUI::Widget { @TerminalSettings::ViewWidget {
fill_with_background_color: true fill_with_background_color: true
layout: @GUI::VerticalBoxLayout { layout: @GUI::VerticalBoxLayout {
margins: [10] margins: [10]
@ -27,7 +27,7 @@
@GUI::Label { @GUI::Label {
background_role: "Base" background_role: "Base"
style: "SunkenContainer" frame_style: "SunkenContainer"
fill_with_background_color: true fill_with_background_color: true
name: "terminal_font_label" name: "terminal_font_label"
} }
@ -111,7 +111,6 @@
name: "history_size_spinbox" name: "history_size_spinbox"
min: 0 min: 0
max: 40960 max: 40960
orientation: "Horizontal"
preferred_width: 100 preferred_width: 100
} }

View file

@ -8,7 +8,6 @@
#include <AK/Assertions.h> #include <AK/Assertions.h>
#include <AK/JsonObject.h> #include <AK/JsonObject.h>
#include <AK/QuickSort.h> #include <AK/QuickSort.h>
#include <Applications/TerminalSettings/TerminalSettingsViewGML.h>
#include <LibConfig/Client.h> #include <LibConfig/Client.h>
#include <LibCore/DirIterator.h> #include <LibCore/DirIterator.h>
#include <LibGUI/Application.h> #include <LibGUI/Application.h>
@ -28,17 +27,16 @@
#include <LibVT/TerminalWidget.h> #include <LibVT/TerminalWidget.h>
#include <spawn.h> #include <spawn.h>
ErrorOr<NonnullRefPtr<TerminalSettingsViewWidget>> TerminalSettingsViewWidget::try_create() namespace TerminalSettings {
ErrorOr<NonnullRefPtr<ViewWidget>> ViewWidget::create()
{ {
auto widget = TRY(adopt_nonnull_ref_or_enomem(new (nothrow) TerminalSettingsViewWidget())); auto widget = TRY(ViewWidget::try_create());
TRY(widget->setup()); TRY(widget->setup());
return widget; return widget;
} }
ErrorOr<void> TerminalSettingsViewWidget::setup() ErrorOr<void> ViewWidget::setup()
{ {
TRY(load_from_gml(terminal_settings_view_gml));
auto& slider = *find_descendant_of_type_named<GUI::HorizontalOpacitySlider>("background_opacity_slider"); auto& slider = *find_descendant_of_type_named<GUI::HorizontalOpacitySlider>("background_opacity_slider");
m_opacity = Config::read_i32("Terminal"sv, "Window"sv, "Opacity"sv); m_opacity = Config::read_i32("Terminal"sv, "Window"sv, "Opacity"sv);
m_original_opacity = m_opacity; m_original_opacity = m_opacity;
@ -166,7 +164,7 @@ ErrorOr<void> TerminalSettingsViewWidget::setup()
return {}; return {};
} }
void TerminalSettingsViewWidget::apply_settings() void ViewWidget::apply_settings()
{ {
m_original_opacity = m_opacity; m_original_opacity = m_opacity;
m_original_font = m_font; m_original_font = m_font;
@ -177,7 +175,7 @@ void TerminalSettingsViewWidget::apply_settings()
write_back_settings(); write_back_settings();
} }
void TerminalSettingsViewWidget::write_back_settings() const void ViewWidget::write_back_settings() const
{ {
Config::write_i32("Terminal"sv, "Window"sv, "Opacity"sv, static_cast<i32>(m_original_opacity)); Config::write_i32("Terminal"sv, "Window"sv, "Opacity"sv, static_cast<i32>(m_original_opacity));
Config::write_string("Terminal"sv, "Text"sv, "Font"sv, m_original_font->qualified_name()); Config::write_string("Terminal"sv, "Text"sv, "Font"sv, m_original_font->qualified_name());
@ -187,7 +185,8 @@ void TerminalSettingsViewWidget::write_back_settings() const
Config::write_bool("Terminal"sv, "Terminal"sv, "ShowScrollBar"sv, m_original_show_scrollbar); Config::write_bool("Terminal"sv, "Terminal"sv, "ShowScrollBar"sv, m_original_show_scrollbar);
} }
void TerminalSettingsViewWidget::cancel_settings() void ViewWidget::cancel_settings()
{ {
write_back_settings(); write_back_settings();
} }
}

View file

@ -13,16 +13,18 @@
#include <LibGUI/TextEditor.h> #include <LibGUI/TextEditor.h>
#include <LibVT/TerminalWidget.h> #include <LibVT/TerminalWidget.h>
class TerminalSettingsViewWidget final : public GUI::SettingsWindow::Tab { namespace TerminalSettings {
class ViewWidget final : public GUI::SettingsWindow::Tab {
C_OBJECT_ABSTRACT(TerminalSettingsViewWidget) C_OBJECT_ABSTRACT(TerminalSettingsViewWidget)
public: public:
static ErrorOr<NonnullRefPtr<TerminalSettingsViewWidget>> try_create(); static ErrorOr<NonnullRefPtr<ViewWidget>> try_create();
static ErrorOr<NonnullRefPtr<ViewWidget>> create();
virtual void apply_settings() override; virtual void apply_settings() override;
virtual void cancel_settings() override; virtual void cancel_settings() override;
private: private:
TerminalSettingsViewWidget() = default; ViewWidget() = default;
ErrorOr<void> setup(); ErrorOr<void> setup();
void write_back_settings() const; void write_back_settings() const;
@ -42,3 +44,4 @@ private:
size_t m_original_max_history_size; size_t m_original_max_history_size;
bool m_original_show_scrollbar { true }; bool m_original_show_scrollbar { true };
}; };
}

View file

@ -33,8 +33,8 @@ ErrorOr<int> serenity_main(Main::Arguments arguments)
auto window = TRY(GUI::SettingsWindow::create("Terminal Settings")); auto window = TRY(GUI::SettingsWindow::create("Terminal Settings"));
window->set_icon(app_icon.bitmap_for_size(16)); window->set_icon(app_icon.bitmap_for_size(16));
(void)TRY(window->add_tab<TerminalSettingsViewWidget>("View"_string, "view"sv)); (void)TRY(window->add_tab(TRY(TerminalSettings::ViewWidget::create()), "View"_string, "view"sv));
(void)TRY(window->add_tab<TerminalSettingsMainWidget>("Terminal"_string, "terminal"sv)); (void)TRY(window->add_tab(TRY(TerminalSettings::MainWidget::create()), "Terminal"_string, "terminal"sv));
window->set_active_tab(selected_tab); window->set_active_tab(selected_tab);
window->show(); window->show();