/* * Copyright (c) 2020-2022, the SerenityOS developers. * * SPDX-License-Identifier: BSD-2-Clause */ #include "HelpWindow.h" #include "LibFileSystemAccessClient/Client.h" #include "Spreadsheet.h" #include "SpreadsheetWidget.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include ErrorOr serenity_main(Main::Arguments arguments) { TRY(Core::System::pledge("stdio recvfd sendfd rpath fattr unix cpath wpath thread", nullptr)); auto app = GUI::Application::construct(arguments); const char* filename = nullptr; Core::ArgsParser args_parser; args_parser.add_positional_argument(filename, "File to read from", "file", Core::ArgsParser::Required::No); args_parser.parse(arguments); if (filename) { if (!Core::File::exists(filename) || Core::File::is_directory(filename)) { warnln("File does not exist or is a directory: {}", filename); return 1; } } TRY(Core::System::unveil("/tmp/portal/webcontent", "rw")); // For writing temporary files when exporting. TRY(Core::System::unveil("/tmp", "crw")); TRY(Core::System::unveil("/etc", "r")); TRY(Core::System::unveil(Core::StandardPaths::home_directory().characters(), "rwc")); TRY(Core::System::unveil("/res", "r")); TRY(Core::System::unveil(nullptr, nullptr)); auto app_icon = GUI::Icon::default_icon("app-spreadsheet"); auto window = GUI::Window::construct(); window->resize(640, 480); window->set_icon(app_icon.bitmap_for_size(16)); auto& spreadsheet_widget = window->set_main_widget(*window, NonnullRefPtrVector {}, filename == nullptr); spreadsheet_widget.initialize_menubar(*window); spreadsheet_widget.update_window_title(); window->on_close_request = [&]() -> GUI::Window::CloseRequestDecision { if (spreadsheet_widget.request_close()) return GUI::Window::CloseRequestDecision::Close; return GUI::Window::CloseRequestDecision::StayOpen; }; window->show(); if (filename) { auto response = FileSystemAccessClient::Client::the().try_request_file_read_only_approved(window, filename); if (response.is_error()) return 1; spreadsheet_widget.load_file(*response.value()); } return app->exec(); }