main.cpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include "FileArgument.h"
  7. #include "MainWidget.h"
  8. #include <LibConfig/Client.h>
  9. #include <LibCore/ArgsParser.h>
  10. #include <LibCore/System.h>
  11. #include <LibFileSystemAccessClient/Client.h>
  12. #include <LibGUI/Menubar.h>
  13. #include <LibGUI/MessageBox.h>
  14. #include <LibMain/Main.h>
  15. using namespace TextEditor;
  16. ErrorOr<int> serenity_main(Main::Arguments arguments)
  17. {
  18. TRY(Core::System::pledge("stdio recvfd sendfd thread rpath cpath wpath unix"));
  19. auto app = TRY(GUI::Application::try_create(arguments));
  20. Config::pledge_domains("TextEditor");
  21. char const* preview_mode = "auto";
  22. char const* file_to_edit = nullptr;
  23. Core::ArgsParser parser;
  24. parser.add_option(preview_mode, "Preview mode, one of 'none', 'html', 'markdown', 'auto'", "preview-mode", '\0', "mode");
  25. parser.add_positional_argument(file_to_edit, "File to edit, with optional starting line and column number", "file[:line[:column]]", Core::ArgsParser::Required::No);
  26. parser.parse(arguments);
  27. TRY(Core::System::unveil("/res", "r"));
  28. TRY(Core::System::unveil("/tmp/portal/launch", "rw"));
  29. TRY(Core::System::unveil("/tmp/portal/webcontent", "rw"));
  30. TRY(Core::System::unveil("/tmp/portal/filesystemaccess", "rw"));
  31. TRY(Core::System::unveil(nullptr, nullptr));
  32. StringView preview_mode_view = preview_mode;
  33. auto app_icon = GUI::Icon::default_icon("app-text-editor");
  34. auto window = TRY(GUI::Window::try_create());
  35. window->resize(640, 400);
  36. auto text_widget = TRY(window->try_set_main_widget<MainWidget>());
  37. text_widget->editor().set_focus(true);
  38. window->on_close_request = [&]() -> GUI::Window::CloseRequestDecision {
  39. if (text_widget->request_close())
  40. return GUI::Window::CloseRequestDecision::Close;
  41. return GUI::Window::CloseRequestDecision::StayOpen;
  42. };
  43. if (preview_mode_view == "auto") {
  44. text_widget->set_auto_detect_preview_mode(true);
  45. } else if (preview_mode_view == "markdown") {
  46. text_widget->set_preview_mode(MainWidget::PreviewMode::Markdown);
  47. } else if (preview_mode_view == "html") {
  48. text_widget->set_preview_mode(MainWidget::PreviewMode::HTML);
  49. } else if (preview_mode_view == "none") {
  50. text_widget->set_preview_mode(MainWidget::PreviewMode::None);
  51. } else {
  52. warnln("Invalid mode '{}'", preview_mode);
  53. return 1;
  54. }
  55. text_widget->initialize_menubar(*window);
  56. window->show();
  57. window->set_icon(app_icon.bitmap_for_size(16));
  58. if (file_to_edit) {
  59. FileArgument parsed_argument(file_to_edit);
  60. auto response = FileSystemAccessClient::Client::the().try_request_file_read_only_approved(window, parsed_argument.filename());
  61. if (response.is_error()) {
  62. if (response.error().code() == ENOENT)
  63. text_widget->open_nonexistent_file(parsed_argument.filename());
  64. else
  65. return 1;
  66. } else {
  67. if (!text_widget->read_file(*response.value()))
  68. return 1;
  69. text_widget->editor().set_cursor_and_focus_line(parsed_argument.line().value_or(1) - 1, parsed_argument.column().value_or(0));
  70. }
  71. }
  72. text_widget->update_title();
  73. return app->exec();
  74. }