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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
/*
* graftfs
* Copyright (C) 2026 Chris Tisdale
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
use crateResolveError;
use env;
use ;
use path;
/// Resolves a given path to an absolute path, expanding the home directory symbol (`~`) if present.
///
/// # Platform Support
/// This function only compiles on Windows due to the `#[cfg(target_os = "windows")]` attribute.
///
/// # Arguments
/// * `path` - A reference to a `Path` object representing a relative or tilde-prefixed path.
///
/// # Returns
/// * `Ok(PathBuf)` - The absolute path corresponding to the input path if resolution is successful.
/// * `Err(ConfigError)` - An error if the path cannot be resolved, either due to:
/// - Failure to retrieve the user's home directory.
/// - Failure to compute an absolute path.
///
/// # Behavior
/// - If the path does **not** start with `~`, it simply returns the absolute path of the input using `path::absolute`.
/// - If the path **does** start with `~`, it expands it to the user's home directory (`env::home_dir`)
/// and appends the remaining path components, then computes and returns the absolute path.
///
/// # Errors
/// This function returns a `ConfigError::UnableToResolveDirectory` error in cases where:
/// - The user's home directory cannot be determined.
/// - An absolute path cannot be computed for the resolved path.
///
/// # Example
/// ```
/// use std::path::Path;
/// use create::config::path_resolver;
///
/// let path = Path::new("~/Documents/config.txt");
/// match path_resolver::resolve_path(&path) {
/// Ok(resolved_path) => println!("Resolved path: {}", resolved_path.display()),
/// Err(e) => eprintln!("Failed to resolve path: {}", e),
/// }
/// ```
/// Resolves a given file path, expanding the home directory (`~`) if necessary,
/// and returning a canonicalized absolute path.
///
/// This function is only available on non-Windows target operating systems,
/// as indicated by the `#[cfg(not(target_os = "windows"))]` attribute.
///
/// If the `path` does not start with the `~` character (home directory shorthand),
/// the function directly attempts to canonicalize the path using the filesystem.
///
/// If the `path` starts with `~`, the function resolves the user's home directory
/// using `env::home_dir`. It then joins the resolved home directory with the rest
/// of the path (after stripping the `~` prefix), and finally canonicalizes it.
///
/// # Parameters
/// - `path`: A reference to a `Path` representing the input path to be resolved.
///
/// # Returns
/// - `Ok(PathBuf)`: The resolved absolute path as a `PathBuf`.
/// - `Err(ConfigError)`: Returns a `ConfigError` in the following cases:
/// - The function is unable to retrieve the user’s home directory.
/// - The provided path cannot be canonicalized.
/// - The path after prefix stripping cannot be joined or further resolved.
///
/// # Errors
/// - `ConfigError::UnableToResolveDirectory`: Thrown when the home directory cannot be resolved.
/// - Any `std::io::Error` occurring during path canonicalization will also be propagated
/// as part of the `Result`.
///
/// # Example
/// ```rust
/// use std::path::Path;
/// use create::config::path_resolver;
///
/// let input_path = Path::new("~/example/path");
/// match path_resolver::resolve_path(input_path) {
/// Ok(resolved_path) => println!("Resolved Path: {}", resolved_path.display()),
/// Err(error) => eprintln!("Error resolving path: {:?}", error),
/// }
/// ```
/// Builds a given file path, expanding the home directory (`~`) if necessary.
/// This is the same as `resolve_path` except that it does not canonicalize the path.
///
/// If the `path` starts with `~`, the function resolves the user's home directory
/// using `env::home_dir`. It then joins the resolved home directory with the rest
/// of the path (after stripping the `~` prefix).
///
/// # Parameters
/// - `path`: A reference to a `Path` representing the input path to be resolved.
///
/// # Returns
/// - `Ok(PathBuf)`: The resolved absolute path as a `PathBuf`.
/// - `Err(ConfigError)`: Returns a `ConfigError` in the following cases:
/// - The function is unable to retrieve the user’s home directory.
/// - The provided path cannot be canonicalized.
/// - The path after prefix stripping cannot be joined or further resolved.
///
/// # Errors
/// - `ConfigError::UnableToResolveDirectory`: Thrown when the home directory cannot be resolved.
///
/// # Example
/// ```rust
/// use std::path::Path;
/// use create::config::path_resolver;
///
/// let input_path = Path::new("~/example/path");
/// match path_resolver::resolve_home_path(input_path) {
/// Ok(resolved_path) => println!("Resolved Path: {}", resolved_path.display()),
/// Err(error) => eprintln!("Error resolving path: {:?}", error),
/// }
/// ```