blob: 5b75254c0eaf807ebd3f49274b536b916d244c49 (
plain)
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
|
use std::fs::{remove_file, symlink_metadata};
use std::os::unix::fs::symlink;
use std::path::PathBuf;
use dirs::home_dir;
use crate::config::Dot;
pub fn deploy_dots(dots: Vec<Dot>, dots_dir: PathBuf) {
let prepended_dots = dots.iter().map(|m|
Dot {
source: dots_dir.join(&m.source),
destination: prepend_user_dir(&m.destination)
}
);
for dot in prepended_dots {
println!("linking from {} to {}", dot.source.display(), dot.destination.display());
let _ = symlink(&dot.source, &dot.destination).map_err(|err|
eprintln!("failed to symlink: {}", err.to_string())
);
}
}
pub fn unlink_dots(dots: Vec<Dot>, dots_dir: PathBuf) {
let prepended_dots = dots.iter().map(|m|
Dot {
source: dots_dir.join(&m.source),
destination: prepend_user_dir(&m.destination)
}
);
for dot in prepended_dots {
println!("unlinking {}", dot.destination.display());
let metadata = symlink_metadata(dot.destination.clone());
if metadata.is_err() {
eprintln!("failed to query metadata for {}: {}", dot.destination.display(), metadata.err().unwrap());
continue
}
if metadata.ok().unwrap().is_symlink() {
let _ = remove_file(dot.destination).map_err(|err|
eprintln!("failed to remove symlink: {}", err)
);
}
}
}
fn prepend_user_dir(path: &PathBuf) -> PathBuf {
home_dir().unwrap().join(path)
}
|