use crate::find;
pub trait Header {
fn try_header(&self, id: &gix_hash::oid) -> Result<Option<find::Header>, gix_object::find::Error>;
}
mod _impls {
use std::{ops::Deref, rc::Rc, sync::Arc};
use gix_hash::oid;
use crate::find::Header;
impl<T> crate::Header for &T
where
T: crate::Header,
{
fn try_header(&self, id: &oid) -> Result<Option<Header>, gix_object::find::Error> {
(*self).try_header(id)
}
}
impl<T> crate::Header for Rc<T>
where
T: crate::Header,
{
fn try_header(&self, id: &oid) -> Result<Option<Header>, gix_object::find::Error> {
self.deref().try_header(id)
}
}
impl<T> crate::Header for Arc<T>
where
T: crate::Header,
{
fn try_header(&self, id: &oid) -> Result<Option<Header>, gix_object::find::Error> {
self.deref().try_header(id)
}
}
}
mod ext {
use crate::find;
pub trait HeaderExt: super::Header {
fn header(&self, id: impl AsRef<gix_hash::oid>) -> Result<find::Header, gix_object::find::existing::Error> {
let id = id.as_ref();
self.try_header(id)
.map_err(gix_object::find::existing::Error::Find)?
.ok_or_else(|| gix_object::find::existing::Error::NotFound { oid: id.to_owned() })
}
}
impl<T: super::Header> HeaderExt for T {}
}
pub use ext::HeaderExt;