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
use std::{ffi::OsString, path::PathBuf};
use gix::prelude::FindExt;
pub fn from_tree(
mut spec: OsString,
index_path: Option<PathBuf>,
force: bool,
repo: gix::Repository,
) -> anyhow::Result<()> {
spec.push("^{tree}");
let spec = gix::path::os_str_into_bstr(&spec)?;
let tree = repo.rev_parse_single(spec)?;
let index = gix::index::State::from_tree(&tree, |oid, buf| repo.objects.find_tree_iter(oid, buf).ok())?;
let options = gix::index::write::Options::default();
match index_path {
Some(index_path) => {
if index_path.is_file() && !force {
anyhow::bail!(
"File at \"{}\" already exists, to overwrite use the '-f' flag",
index_path.display()
);
}
let mut index = gix::index::File::from_state(index, index_path);
index.write(options)?;
}
None => {
let index = gix::index::File::from_state(index, std::path::PathBuf::new());
let mut out = Vec::with_capacity(512 * 1024);
index.write_to(&mut out, options)?;
}
}
Ok(())
}