From 47f7cfd429b28cfd8980e9ca2bcb564b8e684dda Mon Sep 17 00:00:00 2001 From: imaqtkatt Date: Wed, 10 Jul 2024 16:34:21 -0300 Subject: [PATCH 1/2] Add error message when file is not found --- CHANGELOG.md | 2 ++ src/fun/load_book.rs | 12 ++++++++++-- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f73f6814c..99f1b9fcf 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,6 +17,7 @@ and this project does not currently adhere to a particular versioning scheme. - Add import system. ([#544][gh-544]) - Add multi line comment `#{ ... #}` syntax. ([#595][gh-595]) +- Add error message when input file is not found. ([#513][gh-513]) ## [0.2.36] - 2024-07-04 @@ -372,6 +373,7 @@ and this project does not currently adhere to a particular versioning scheme. [gh-494]: https://github.com/HigherOrderCO/Bend/issues/494 [gh-502]: https://github.com/HigherOrderCO/Bend/issues/502 [gh-512]: https://github.com/HigherOrderCO/Bend/issues/512 +[gh-513]: https://github.com/HigherOrderCO/Bend/issues/513 [gh-514]: https://github.com/HigherOrderCO/Bend/issues/514 [gh-516]: https://github.com/HigherOrderCO/Bend/issues/516 [gh-526]: https://github.com/HigherOrderCO/Bend/issues/526 diff --git a/src/fun/load_book.rs b/src/fun/load_book.rs index 4e94a1fb8..db1bd1211 100644 --- a/src/fun/load_book.rs +++ b/src/fun/load_book.rs @@ -16,8 +16,16 @@ pub fn load_file_to_book( package_loader: impl PackageLoader, diag: DiagnosticsConfig, ) -> Result { - let code = std::fs::read_to_string(path).map_err(|e| e.to_string())?; - load_to_book(path, &code, package_loader, diag) + match path.try_exists() { + Ok(exists) => { + if !exists { + return Err(format!("The file '{}' was not found.", path.display()).into()); + } + let code = std::fs::read_to_string(path).map_err(|e| e.to_string())?; + load_to_book(path, &code, package_loader, diag) + } + Err(e) => Err(e.to_string().into()), + } } pub fn load_to_book( From 2f8062bc5fbb5e2663289f56adb8eeaea976d5be Mon Sep 17 00:00:00 2001 From: imaqtkatt Date: Wed, 10 Jul 2024 22:07:19 -0300 Subject: [PATCH 2/2] Add cli test for input file not found --- tests/golden_tests/cli/input_file_not_found.args | 2 ++ tests/golden_tests/cli/input_file_not_found.bend | 0 tests/snapshots/cli__input_file_not_found.bend.snap | 6 ++++++ 3 files changed, 8 insertions(+) create mode 100644 tests/golden_tests/cli/input_file_not_found.args create mode 100644 tests/golden_tests/cli/input_file_not_found.bend create mode 100644 tests/snapshots/cli__input_file_not_found.bend.snap diff --git a/tests/golden_tests/cli/input_file_not_found.args b/tests/golden_tests/cli/input_file_not_found.args new file mode 100644 index 000000000..b5f6bc09c --- /dev/null +++ b/tests/golden_tests/cli/input_file_not_found.args @@ -0,0 +1,2 @@ +run +tests/golden_tests/missing_dir/input_file_not_found.bend diff --git a/tests/golden_tests/cli/input_file_not_found.bend b/tests/golden_tests/cli/input_file_not_found.bend new file mode 100644 index 000000000..e69de29bb diff --git a/tests/snapshots/cli__input_file_not_found.bend.snap b/tests/snapshots/cli__input_file_not_found.bend.snap new file mode 100644 index 000000000..58ec93951 --- /dev/null +++ b/tests/snapshots/cli__input_file_not_found.bend.snap @@ -0,0 +1,6 @@ +--- +source: tests/golden_tests.rs +input_file: tests/golden_tests/cli/input_file_not_found.bend +--- +Errors: +The file 'tests/golden_tests/missing_dir/input_file_not_found.bend' was not found.