2022-06-18 21:56:31 -07:00
|
|
|
use super::*;
|
2019-06-01 22:38:03 -07:00
|
|
|
|
Gargantuan refactor (#522)
- Instead of changing the current directory with `env::set_current_dir`
to be implicitly inherited by subprocesses, we now use
`Command::current_dir` to set it explicitly. This feels much better,
since we aren't dependent on the implicit state of the process's
current directory.
- Subcommand execution is much improved.
- Added a ton of tests for config parsing, config execution, working
dir, and search dir.
- Error messages are improved. Many more will be colored.
- The Config is now onwed, instead of borrowing from the arguments and
the `clap::ArgMatches` object. This is a huge ergonomic improvement,
especially in tests, and I don't think anyone will notice.
- `--edit` now uses `$VISUAL`, `$EDITOR`, or `vim`, in that order,
matching git, which I think is what most people will expect.
- Added a cute `tmptree!{}` macro, for creating temporary directories
populated with directories and files for tests.
- Admitted that grammer is LL(k) and I don't know what `k` is.
2019-11-09 21:43:20 -08:00
|
|
|
#[derive(Debug, Snafu)]
|
|
|
|
#[snafu(visibility(pub(crate)))]
|
2019-09-21 15:35:03 -07:00
|
|
|
pub(crate) enum SearchError {
|
2021-07-26 01:26:06 -07:00
|
|
|
#[snafu(display(
|
|
|
|
"I/O error reading directory `{}`: {}",
|
|
|
|
directory.display(),
|
|
|
|
io_error
|
|
|
|
))]
|
|
|
|
Io {
|
|
|
|
directory: PathBuf,
|
2021-09-16 06:44:40 -07:00
|
|
|
io_error: io::Error,
|
2021-07-26 01:26:06 -07:00
|
|
|
},
|
|
|
|
#[snafu(display("Justfile path had no parent: {}", path.display()))]
|
|
|
|
JustfileHadNoParent { path: PathBuf },
|
Gargantuan refactor (#522)
- Instead of changing the current directory with `env::set_current_dir`
to be implicitly inherited by subprocesses, we now use
`Command::current_dir` to set it explicitly. This feels much better,
since we aren't dependent on the implicit state of the process's
current directory.
- Subcommand execution is much improved.
- Added a ton of tests for config parsing, config execution, working
dir, and search dir.
- Error messages are improved. Many more will be colored.
- The Config is now onwed, instead of borrowing from the arguments and
the `clap::ArgMatches` object. This is a huge ergonomic improvement,
especially in tests, and I don't think anyone will notice.
- `--edit` now uses `$VISUAL`, `$EDITOR`, or `vim`, in that order,
matching git, which I think is what most people will expect.
- Added a cute `tmptree!{}` macro, for creating temporary directories
populated with directories and files for tests.
- Admitted that grammer is LL(k) and I don't know what `k` is.
2019-11-09 21:43:20 -08:00
|
|
|
#[snafu(display(
|
|
|
|
"Multiple candidate justfiles found in `{}`: {}",
|
2021-07-31 12:25:49 -07:00
|
|
|
candidates.iter().next().unwrap().parent().unwrap().display(),
|
Gargantuan refactor (#522)
- Instead of changing the current directory with `env::set_current_dir`
to be implicitly inherited by subprocesses, we now use
`Command::current_dir` to set it explicitly. This feels much better,
since we aren't dependent on the implicit state of the process's
current directory.
- Subcommand execution is much improved.
- Added a ton of tests for config parsing, config execution, working
dir, and search dir.
- Error messages are improved. Many more will be colored.
- The Config is now onwed, instead of borrowing from the arguments and
the `clap::ArgMatches` object. This is a huge ergonomic improvement,
especially in tests, and I don't think anyone will notice.
- `--edit` now uses `$VISUAL`, `$EDITOR`, or `vim`, in that order,
matching git, which I think is what most people will expect.
- Added a cute `tmptree!{}` macro, for creating temporary directories
populated with directories and files for tests.
- Admitted that grammer is LL(k) and I don't know what `k` is.
2019-11-09 21:43:20 -08:00
|
|
|
List::and_ticked(
|
|
|
|
candidates
|
|
|
|
.iter()
|
|
|
|
.map(|candidate| candidate.file_name().unwrap().to_string_lossy())
|
|
|
|
),
|
|
|
|
))]
|
2021-07-31 12:25:49 -07:00
|
|
|
MultipleCandidates { candidates: BTreeSet<PathBuf> },
|
Gargantuan refactor (#522)
- Instead of changing the current directory with `env::set_current_dir`
to be implicitly inherited by subprocesses, we now use
`Command::current_dir` to set it explicitly. This feels much better,
since we aren't dependent on the implicit state of the process's
current directory.
- Subcommand execution is much improved.
- Added a ton of tests for config parsing, config execution, working
dir, and search dir.
- Error messages are improved. Many more will be colored.
- The Config is now onwed, instead of borrowing from the arguments and
the `clap::ArgMatches` object. This is a huge ergonomic improvement,
especially in tests, and I don't think anyone will notice.
- `--edit` now uses `$VISUAL`, `$EDITOR`, or `vim`, in that order,
matching git, which I think is what most people will expect.
- Added a cute `tmptree!{}` macro, for creating temporary directories
populated with directories and files for tests.
- Admitted that grammer is LL(k) and I don't know what `k` is.
2019-11-09 21:43:20 -08:00
|
|
|
#[snafu(display("No justfile found"))]
|
2019-06-01 22:38:03 -07:00
|
|
|
NotFound,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn multiple_candidates_formatting() {
|
|
|
|
let error = SearchError::MultipleCandidates {
|
2021-07-31 12:25:49 -07:00
|
|
|
candidates: [Path::new("/foo/justfile"), Path::new("/foo/JUSTFILE")]
|
|
|
|
.iter()
|
|
|
|
.map(|path| path.to_path_buf())
|
|
|
|
.collect(),
|
2019-06-01 22:38:03 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
error.to_string(),
|
2021-07-31 12:25:49 -07:00
|
|
|
"Multiple candidate justfiles found in `/foo`: `JUSTFILE` and `justfile`"
|
2021-05-07 00:14:38 -07:00
|
|
|
);
|
2019-06-01 22:38:03 -07:00
|
|
|
}
|
|
|
|
}
|