mod impls {
use std::ops::{Deref, DerefMut};
use crate::{File, State};
impl Deref for File {
type Target = State;
fn deref(&self) -> &Self::Target {
&self.state
}
}
impl DerefMut for File {
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.state
}
}
}
mod impl_ {
use std::fmt::Formatter;
use crate::{Entry, File, PathStorageRef, State};
impl std::fmt::Debug for File {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
if f.alternate() {
return f
.debug_struct("File")
.field("path", &self.path.display())
.field("checksum", &self.checksum)
.field("object_hash", &self.state.object_hash)
.field("timestamp", &self.state.timestamp)
.field("version", &self.state.version)
.field(
"entries",
&EntriesDebug {
entries: &self.state.entries,
path_backing: &self.state.path_backing,
},
)
.field("path_backing_size_bytes", &self.state.path_backing.len())
.field("is_sparse", &self.state.is_sparse)
.field("end_of_index_at_decode_time", &self.state.end_of_index_at_decode_time)
.field("offset_table_at_decode_time", &self.state.offset_table_at_decode_time)
.field("tree", &self.state.tree)
.field("has_link", &self.state.link.is_some())
.field("has_resolve_undo", &self.state.resolve_undo.is_some())
.field("untracked", &self.state.untracked)
.field("has_fs_monitor", &self.state.fs_monitor.is_some())
.finish();
}
f.debug_struct("File")
.field("path", &self.path.display())
.field("checksum", &self.checksum)
.finish_non_exhaustive()
}
}
struct EntriesDebug<'a> {
entries: &'a [Entry],
path_backing: &'a PathStorageRef,
}
impl std::fmt::Debug for EntriesDebug<'_> {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
if !f.alternate() {
return f.debug_list().entries(self.entries).finish();
}
writeln!(f, "[")?;
for entry in self.entries {
write!(f, " ")?;
entry.fmt_debug(f, Some(self.path_backing))?;
writeln!(f, ",")?;
}
write!(f, "]")
}
}
impl From<File> for State {
fn from(f: File) -> Self {
f.state
}
}
}
mod access {
use crate::File;
impl File {
pub fn into_parts(self) -> (crate::State, std::path::PathBuf) {
(self.state, self.path)
}
}
impl File {
pub fn path(&self) -> &std::path::Path {
&self.path
}
pub fn checksum(&self) -> Option<gix_hash::ObjectId> {
self.checksum
}
}
}
mod mutation {
use std::path::PathBuf;
use crate::File;
impl File {
pub fn set_path(&mut self, path: impl Into<PathBuf>) {
self.path = path.into();
}
}
}
pub mod init;
pub mod verify;
pub mod write;