Skip to content

Commit

Permalink
ModelGallery: Use TRY() a lot more :^)
Browse files Browse the repository at this point in the history
  • Loading branch information
pbrw authored and awesomekling committed Nov 25, 2021
1 parent 601de46 commit 162c271
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 25 deletions.
2 changes: 1 addition & 1 deletion Userland/Demos/ModelGallery/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,4 @@ set(SOURCES

serenity_app(ModelGallery ICON app-model-gallery)

target_link_libraries(ModelGallery LibGUI LibGfx)
target_link_libraries(ModelGallery LibGUI LibGfx LibMain)
24 changes: 13 additions & 11 deletions Userland/Demos/ModelGallery/GalleryWidget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,23 +13,23 @@ GalleryWidget::GalleryWidget()
set_layout<GUI::VerticalBoxLayout>();

auto& inner_widget = add<GUI::Widget>();
auto& inner_layout = inner_widget.set_layout<GUI::VerticalBoxLayout>();
inner_layout.set_margins({ 4 });
auto inner_layout = inner_widget.try_set_layout<GUI::VerticalBoxLayout>().release_value_but_fixme_should_propagate_errors();
inner_layout->set_margins({ 4 });

m_tab_widget = inner_widget.add<GUI::TabWidget>();
m_tab_widget = inner_widget.try_add<GUI::TabWidget>().release_value_but_fixme_should_propagate_errors();
m_statusbar = add<GUI::Statusbar>();

load_basic_model_tab();
(void)load_basic_model_tab();
load_sorting_filtering_tab();
}

void GalleryWidget::load_basic_model_tab()
ErrorOr<void> GalleryWidget::load_basic_model_tab()
{
auto& tab = m_tab_widget->add_tab<GUI::Widget>("Basic Model");
tab.load_from_gml(basic_model_tab_gml);
auto tab = TRY(m_tab_widget->try_add_tab<GUI::Widget>("Basic Model"));
tab->load_from_gml(basic_model_tab_gml);

m_basic_model = BasicModel::create();
m_basic_model_table = *tab.find_descendant_of_type_named<GUI::TableView>("model_table");
m_basic_model_table = *tab->find_descendant_of_type_named<GUI::TableView>("model_table");
m_basic_model_table->set_model(m_basic_model);

m_basic_model->on_invalidate = [&] {
Expand All @@ -43,9 +43,9 @@ void GalleryWidget::load_basic_model_tab()
m_basic_model->add_item("...hello...");
m_basic_model->add_item("...friends! :^)");

m_new_item_name = *tab.find_descendant_of_type_named<GUI::TextBox>("new_item_name");
m_add_new_item = *tab.find_descendant_of_type_named<GUI::Button>("add_new_item");
m_remove_selected_item = *tab.find_descendant_of_type_named<GUI::Button>("remove_selected_item");
m_new_item_name = *tab->find_descendant_of_type_named<GUI::TextBox>("new_item_name");
m_add_new_item = *tab->find_descendant_of_type_named<GUI::Button>("add_new_item");
m_remove_selected_item = *tab->find_descendant_of_type_named<GUI::Button>("remove_selected_item");

m_add_new_item->set_icon(Gfx::Bitmap::try_load_from_file("/res/icons/16x16/plus.png").release_value_but_fixme_should_propagate_errors());
m_remove_selected_item->set_icon(Gfx::Bitmap::try_load_from_file("/res/icons/16x16/minus.png").release_value_but_fixme_should_propagate_errors());
Expand All @@ -59,6 +59,8 @@ void GalleryWidget::load_basic_model_tab()
m_basic_model->remove_item(index);
}
};

return {};
}

void GalleryWidget::load_sorting_filtering_tab()
Expand Down
2 changes: 1 addition & 1 deletion Userland/Demos/ModelGallery/GalleryWidget.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ class GalleryWidget final : public GUI::Widget {
private:
GalleryWidget();

void load_basic_model_tab();
ErrorOr<void> load_basic_model_tab();
void load_sorting_filtering_tab();

void add_textbox_contents_to_basic_model();
Expand Down
20 changes: 8 additions & 12 deletions Userland/Demos/ModelGallery/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,34 +5,30 @@
*/

#include "GalleryWidget.h"
#include <LibCore/System.h>
#include <LibGUI/Application.h>
#include <LibGUI/BoxLayout.h>
#include <LibGUI/Button.h>
#include <LibGUI/Frame.h>
#include <LibGUI/MessageBox.h>
#include <LibMain/Main.h>
#include <unistd.h>

int main(int argc, char** argv)
ErrorOr<int> serenity_main(Main::Arguments arguments)
{
if (pledge("stdio recvfd sendfd rpath wpath cpath unix", nullptr) < 0) {
perror("pledge");
return 1;
}
TRY(Core::System::pledge("stdio recvfd sendfd rpath wpath cpath unix", nullptr));

auto app = GUI::Application::construct(argc, argv);
auto app = TRY(GUI::Application::try_create(arguments));

if (pledge("stdio recvfd sendfd rpath", nullptr) < 0) {
perror("pledge");
return 1;
}
TRY(Core::System::pledge("stdio recvfd sendfd rpath", nullptr));

auto app_icon = GUI::Icon::default_icon("app-model-gallery");

auto window = GUI::Window::construct();
auto window = TRY(GUI::Window::try_create());
window->set_title("Model Gallery");
window->set_icon(app_icon.bitmap_for_size(16));
window->resize(430, 480);
window->set_main_widget<GalleryWidget>();
TRY(window->try_set_main_widget<GalleryWidget>());

window->show();
return app->exec();
Expand Down

0 comments on commit 162c271

Please sign in to comment.