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
use std::convert::TryInto;
use git_actor as actor;
use git_hash::ObjectId;
use git_lock as lock;
use git_ref::{
file::find::Error,
transaction::{Change, Create, RefEdit},
PartialNameRef, Target,
};
use crate::{
easy,
easy::{reference, Reference},
};
pub trait ReferenceAccessExt: easy::Access + Sized {
fn tag(
&self,
name: impl AsRef<str>,
target: impl Into<ObjectId>,
lock_mode: lock::acquire::Fail,
force: bool,
) -> Result<Vec<RefEdit>, reference::edit::Error> {
self.edit_references(
Some(RefEdit {
change: Change::Update {
log: Default::default(),
mode: if force {
Create::OrUpdate { previous: None }
} else {
Create::Only
},
new: Target::Peeled(target.into()),
},
name: format!("refs/tags/{}", name.as_ref()).try_into()?,
deref: false,
}),
lock_mode,
None,
)
}
fn edit_reference(
&self,
edit: RefEdit,
lock_mode: lock::acquire::Fail,
log_committer: Option<&actor::Signature>,
) -> Result<Vec<RefEdit>, reference::edit::Error> {
self.edit_references(Some(edit), lock_mode, log_committer)
}
fn edit_references(
&self,
edits: impl IntoIterator<Item = RefEdit>,
lock_mode: lock::acquire::Fail,
log_committer: Option<&actor::Signature>,
) -> Result<Vec<RefEdit>, reference::edit::Error> {
let committer_storage;
let committer = match log_committer {
Some(c) => c,
None => {
committer_storage = actor::Signature::empty();
&committer_storage
}
};
self.repo()?
.refs
.transaction()
.prepare(edits, lock_mode)?
.commit(committer)
.map_err(Into::into)
}
fn find_reference<'a, Name, E>(&self, name: Name) -> Result<Reference<'_, Self>, reference::find::existing::Error>
where
Name: TryInto<PartialNameRef<'a>, Error = E>,
Error: From<E>,
{
self.try_find_reference(name)?
.ok_or(reference::find::existing::Error::NotFound)
}
fn try_find_reference<'a, Name, E>(&self, name: Name) -> Result<Option<Reference<'_, Self>>, reference::find::Error>
where
Name: TryInto<PartialNameRef<'a>, Error = E>,
Error: From<E>,
{
let state = self.state();
let repo = self.repo()?;
match repo
.refs
.try_find(name, state.assure_packed_refs_uptodate(&repo.refs)?.as_ref())
{
Ok(r) => match r {
Some(r) => Ok(Some(Reference::from_file_ref(r, self))),
None => Ok(None),
},
Err(err) => Err(err.into()),
}
}
}
impl<A> ReferenceAccessExt for A where A: easy::Access + Sized {}