summaryrefslogtreecommitdiff
path: root/Userland/Applications/Spreadsheet
diff options
context:
space:
mode:
authorMustafa Quraish <mustafaq9@gmail.com>2022-01-17 06:09:19 -0500
committerAndreas Kling <kling@serenityos.org>2022-01-20 10:39:12 +0100
commitbba32de857ae392a0271fdcc0bfe0f57b52d136c (patch)
tree9486317a8d5df8e19141ca0f78662dcd6e77312f /Userland/Applications/Spreadsheet
parentca2c7dced5b2a6ff7648cb6f3c3a7d7c3bfdce44 (diff)
downloadserenity-bba32de857ae392a0271fdcc0bfe0f57b52d136c.zip
SpreadSheet: Use FileSystemAccessClient::try_* APIs
Diffstat (limited to 'Userland/Applications/Spreadsheet')
-rw-r--r--Userland/Applications/Spreadsheet/SpreadsheetWidget.cpp15
-rw-r--r--Userland/Applications/Spreadsheet/SpreadsheetWidget.h2
-rw-r--r--Userland/Applications/Spreadsheet/Workbook.cpp21
-rw-r--r--Userland/Applications/Spreadsheet/Workbook.h2
-rw-r--r--Userland/Applications/Spreadsheet/main.cpp10
5 files changed, 17 insertions, 33 deletions
diff --git a/Userland/Applications/Spreadsheet/SpreadsheetWidget.cpp b/Userland/Applications/Spreadsheet/SpreadsheetWidget.cpp
index 767626625a..5f20f9281a 100644
--- a/Userland/Applications/Spreadsheet/SpreadsheetWidget.cpp
+++ b/Userland/Applications/Spreadsheet/SpreadsheetWidget.cpp
@@ -124,15 +124,10 @@ SpreadsheetWidget::SpreadsheetWidget(GUI::Window& parent_window, NonnullRefPtrVe
if (!load_path.has_value())
return;
- auto response = FileSystemAccessClient::Client::the().request_file_read_only_approved(window()->window_id(), *load_path);
-
- if (response.error != 0) {
- if (response.error != -1)
- GUI::MessageBox::show_error(window(), String::formatted("Opening \"{}\" failed: {}", *response.chosen_file, strerror(response.error)));
+ auto response = FileSystemAccessClient::Client::the().try_request_file_read_only_approved(window(), *load_path);
+ if (response.is_error())
return;
- }
-
- load_file(*response.fd, *load_path);
+ load_file(*response.value());
});
m_save_action = GUI::CommonActions::make_save_action([&](auto&) {
@@ -400,9 +395,9 @@ void SpreadsheetWidget::save(StringView filename)
GUI::MessageBox::show_error(window(), result.error());
}
-void SpreadsheetWidget::load_file(int fd, StringView filename)
+void SpreadsheetWidget::load_file(Core::File& file)
{
- auto result = m_workbook->open_file(fd, filename);
+ auto result = m_workbook->open_file(file);
if (result.is_error()) {
GUI::MessageBox::show_error(window(), result.error());
return;
diff --git a/Userland/Applications/Spreadsheet/SpreadsheetWidget.h b/Userland/Applications/Spreadsheet/SpreadsheetWidget.h
index f9bbae7dae..0908293239 100644
--- a/Userland/Applications/Spreadsheet/SpreadsheetWidget.h
+++ b/Userland/Applications/Spreadsheet/SpreadsheetWidget.h
@@ -20,7 +20,7 @@ public:
~SpreadsheetWidget();
void save(StringView filename);
- void load_file(int fd, StringView filename);
+ void load_file(Core::File&);
bool request_close();
void add_sheet();
void add_sheet(NonnullRefPtr<Sheet>&&);
diff --git a/Userland/Applications/Spreadsheet/Workbook.cpp b/Userland/Applications/Spreadsheet/Workbook.cpp
index d67e64ae5a..c79b872119 100644
--- a/Userland/Applications/Spreadsheet/Workbook.cpp
+++ b/Userland/Applications/Spreadsheet/Workbook.cpp
@@ -51,15 +51,9 @@ bool Workbook::set_filename(const String& filename)
return true;
}
-Result<bool, String> Workbook::open_file(int fd, StringView filename)
+Result<bool, String> Workbook::open_file(Core::File& file)
{
- auto file = Core::File::construct();
-
- if (!file->open(fd, Core::OpenMode::ReadOnly, Core::File::ShouldCloseFileDescriptor::Yes) && file->error() != ENOENT) {
- return String::formatted("Opening \"{}\" failed: {}", file, strerror(errno));
- }
-
- auto mime = Core::guess_mime_type_based_on_filename(filename);
+ auto mime = Core::guess_mime_type_based_on_filename(file.filename());
// Make an import dialog, we might need to import it.
auto result = ImportDialog::make_and_run_for(m_parent_window, mime, file, *this);
@@ -68,25 +62,24 @@ Result<bool, String> Workbook::open_file(int fd, StringView filename)
m_sheets = result.release_value();
- set_filename(filename);
+ set_filename(file.filename());
return true;
}
Result<bool, String> Workbook::load(StringView filename)
{
- auto response = FileSystemAccessClient::Client::the().request_file_read_only_approved(m_parent_window.window_id(), filename);
- if (response.error != 0) {
+ auto response = FileSystemAccessClient::Client::the().try_request_file_read_only_approved(&m_parent_window, filename);
+ if (response.is_error()) {
StringBuilder sb;
sb.append("Failed to open ");
sb.append(filename);
sb.append(" for reading. Error: ");
- sb.appendff("{}", response.error);
-
+ sb.appendff("{}", response.error());
return sb.to_string();
}
- return open_file(*response.fd, filename);
+ return open_file(*response.value());
}
Result<bool, String> Workbook::save(StringView filename)
diff --git a/Userland/Applications/Spreadsheet/Workbook.h b/Userland/Applications/Spreadsheet/Workbook.h
index c0c49d3f44..5c570b21e0 100644
--- a/Userland/Applications/Spreadsheet/Workbook.h
+++ b/Userland/Applications/Spreadsheet/Workbook.h
@@ -19,7 +19,7 @@ public:
Result<bool, String> save(StringView filename);
Result<bool, String> load(StringView filename);
- Result<bool, String> open_file(int fd, StringView filename);
+ Result<bool, String> open_file(Core::File&);
const String& current_filename() const { return m_current_filename; }
bool set_filename(const String& filename);
diff --git a/Userland/Applications/Spreadsheet/main.cpp b/Userland/Applications/Spreadsheet/main.cpp
index 29b4084f87..277e3d2b8a 100644
--- a/Userland/Applications/Spreadsheet/main.cpp
+++ b/Userland/Applications/Spreadsheet/main.cpp
@@ -94,14 +94,10 @@ int main(int argc, char* argv[])
window->show();
if (filename) {
- auto response = FileSystemAccessClient::Client::the().request_file_read_only_approved(window->window_id(), filename);
-
- if (response.error != 0) {
- if (response.error != -1)
- GUI::MessageBox::show_error(window, String::formatted("Opening \"{}\" failed: {}", *response.chosen_file, strerror(response.error)));
+ auto response = FileSystemAccessClient::Client::the().try_request_file_read_only_approved(window, filename);
+ if (response.is_error())
return 1;
- }
- spreadsheet_widget.load_file(*response.fd, filename);
+ spreadsheet_widget.load_file(*response.value());
}
return app->exec();