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
use std::ops::DerefMut;
use git_odb::Find;
use git_ref::file::ReferenceExt;
use crate::{
easy,
easy::{Oid, Reference},
};
pub mod iter;
mod errors;
use std::{borrow::Borrow, cell::RefMut, marker::PhantomData};
pub use errors::{edit, find, namespace, peel};
use crate::ext::ObjectIdExt;
pub mod logs;
pub(crate) mod packed;
impl<'repo, A> Reference<'repo, A> {
pub fn target(&self) -> git_ref::TargetRef<'_> {
self.inner.target.to_ref()
}
pub fn name(&self) -> git_ref::FullNameRef<'_> {
self.inner.name.to_ref()
}
pub fn detach(self) -> git_ref::Reference {
self.inner
}
}
#[must_use = "Iterators should be obtained from this log platform"]
pub struct Logs<'repo, A: 'repo, R>
where
R: Borrow<Reference<'repo, A>>,
{
pub(crate) reference: R,
pub(crate) buf: RefMut<'repo, Vec<u8>>,
pub(crate) _phantom: PhantomData<A>,
}
impl<'repo, A> Reference<'repo, A>
where
A: easy::Access + Sized,
{
pub(crate) fn from_ref(reference: git_ref::Reference, access: &'repo A) -> Self {
Reference {
inner: reference,
access,
}
}
pub fn id(&self) -> easy::Oid<'repo, A> {
match self.inner.target {
git_ref::Target::Symbolic(_) => panic!("BUG: tries to obtain object id from symbolic target"),
git_ref::Target::Peeled(oid) => oid.to_owned().attach(self.access),
}
}
pub fn peel_to_id_in_place(&mut self) -> Result<Oid<'repo, A>, peel::Error> {
let repo = self.access.repo()?;
let state = self.access.state();
let mut pack_cache = state.try_borrow_mut_pack_cache()?;
let oid = self.inner.peel_to_id_in_place(
&repo.refs,
state.assure_packed_refs_uptodate(&repo.refs)?.buffer.as_ref(),
|oid, buf| {
repo.odb
.try_find(oid, buf, pack_cache.deref_mut())
.map(|po| po.map(|o| (o.kind, o.data)))
},
)?;
Ok(Oid::from_id(oid, self.access))
}
pub fn into_fully_peeled_id(mut self) -> Result<Oid<'repo, A>, peel::Error> {
self.peel_to_id_in_place()
}
}