-
Notifications
You must be signed in to change notification settings - Fork 21
Expand file tree
/
Copy patherror.rs
More file actions
60 lines (48 loc) · 1.8 KB
/
error.rs
File metadata and controls
60 lines (48 loc) · 1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
use std::{io, path::Path, sync::Arc};
use vite_path::{
AbsolutePath, AbsolutePathBuf, RelativePathBuf, absolute::StripPrefixError,
relative::InvalidPathDataError,
};
use vite_str::Str;
#[derive(Debug, thiserror::Error)]
pub enum Error {
#[error("Duplicate package name `{name}` found at `{path1}` and `{path2}`")]
DuplicatedPackageName { name: Str, path1: RelativePathBuf, path2: RelativePathBuf },
#[error("Package not found in workspace: `{0:?}`")]
PackageJsonNotFound(AbsolutePathBuf),
#[error("Package at `{package_path:?}` is outside workspace root `{workspace_root:?}`")]
PackageOutsideWorkspace { package_path: Arc<AbsolutePath>, workspace_root: Arc<AbsolutePath> },
#[error(
"The stripped path ({stripped_path:?}) is not a valid relative path because: {invalid_path_data_error}"
)]
StripPath { stripped_path: Box<Path>, invalid_path_data_error: InvalidPathDataError },
// External library errors
#[error(transparent)]
Io(#[from] io::Error),
#[error("Failed to parse JSON file at {file_path:?}")]
SerdeJson {
file_path: Arc<AbsolutePath>,
#[source]
serde_json_error: serde_json::Error,
},
#[error("Failed to parse YAML file at {file_path:?}")]
SerdeYml {
file_path: Arc<AbsolutePath>,
#[source]
serde_yml_error: serde_yml::Error,
},
#[error(transparent)]
WaxBuild(#[from] wax::BuildError),
#[error(transparent)]
WaxWalk(#[from] wax::WalkError),
#[error(transparent)]
Glob(#[from] vite_glob::Error),
}
impl From<StripPrefixError<'_>> for Error {
fn from(value: StripPrefixError<'_>) -> Self {
Self::StripPath {
stripped_path: Box::from(value.stripped_path),
invalid_path_data_error: value.invalid_path_data_error,
}
}
}