blob: 848d9eeabd72c6201235107582d5cf667f8e9967 [file] [log] [blame]
use super::Tree;
use crate::Repository;
/// An entry within a tree
pub struct EntryRef<'repo, 'a> {
/// The actual entry ref we are wrapping.
pub inner: gix_object::tree::EntryRef<'a>,
pub(crate) repo: &'repo Repository,
}
impl<'repo, 'a> EntryRef<'repo, 'a> {
/// The kind of object to which [`id()`][Self::id()] is pointing.
pub fn mode(&self) -> gix_object::tree::EntryMode {
self.inner.mode
}
/// The name of the file in the parent tree.
pub fn filename(&self) -> &gix_object::bstr::BStr {
self.inner.filename
}
/// Return the entries id, connected to the underlying repository.
pub fn id(&self) -> crate::Id<'repo> {
crate::Id::from_id(self.inner.oid, self.repo)
}
/// Return the plain object id of this entry, without access to the repository.
pub fn oid(&self) -> &gix_hash::oid {
self.inner.oid
}
/// Return the object this entry points to.
pub fn object(&self) -> Result<crate::Object<'repo>, crate::object::find::existing::Error> {
self.id().object()
}
/// Return the plain object id of this entry, without access to the repository.
pub fn object_id(&self) -> gix_hash::ObjectId {
self.inner.oid.to_owned()
}
/// Detach the repository from this instance.
pub fn detach(&self) -> gix_object::tree::EntryRef<'a> {
self.inner
}
}
impl<'repo, 'a> std::fmt::Display for EntryRef<'repo, 'a> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(
f,
"{:06o} {:>6} {}\t{}",
self.mode() as u32,
self.mode().as_str(),
self.id().shorten_or_id(),
self.filename()
)
}
}
impl<'repo> Tree<'repo> {
/// Return an iterator over tree entries to obtain information about files and directories this tree contains.
pub fn iter(&self) -> impl Iterator<Item = Result<EntryRef<'repo, '_>, gix_object::decode::Error>> {
let repo = self.repo;
gix_object::TreeRefIter::from_bytes(&self.data).map(move |e| e.map(|entry| EntryRef { inner: entry, repo }))
}
}