Skip to main content

GitLayer

Struct GitLayer 

Source
pub struct GitLayer { /* private fields */ }
Expand description

Git-based version control layer.

Uses gix for in-process git operations — no subprocess spawning, no performance overhead of forking git CLI commands.

Implementations§

Source§

impl GitLayer

Source

pub fn new(root: PathBuf, enabled: bool) -> Result<Self>

Create a new GitLayer, initializing a repo if needed.

Source

pub fn commit_file(&self, rel_path: &str, message: &str) -> Result<CommitInfo>

Commit a single file with a message (backward-compatible).

Source

pub fn commit_file_with( &self, rel_path: &str, message: &str, ctx: CommitContext, ) -> Result<CommitInfo>

Commit a single file with a message and explicit commit context.

Source

pub fn commit_files( &self, rel_paths: &[&str], message: &str, ) -> Result<CommitInfo>

Commit multiple files in a single commit (backward-compatible).

Source

pub fn commit_files_with( &self, rel_paths: &[&str], message: &str, ctx: CommitContext, ) -> Result<CommitInfo>

Commit multiple files with a message and explicit commit context.

Source

pub fn remove_file(&self, rel_path: &str, message: &str) -> Result<CommitInfo>

Remove a file from the repo and commit.

Source

pub fn log_action( &self, agent: &str, action: &str, target: &str, allowed: bool, detail: Option<&str>, ) -> Result<()>

Append an audit entry to a monthly audit log file and commit it.

Source

pub fn tag(&self, name: &str, message: &str) -> Result<()>

Create an annotated tag at the current HEAD.

Source

pub fn list_tags(&self) -> Result<Vec<String>>

List all tags in the repository.

Uses Category::Tag to correctly filter only tag refs.

Source

pub fn log(&self, max_count: usize) -> Result<Vec<LogEntry>>

Return commit log entries, most recent first.

Source

pub fn resolve_partial_hash(&self, partial: &str) -> Result<ObjectId>

Resolve a partial commit hash to full ObjectId.

Source

pub fn restore_file(&self, rel_path: &str, hash: &str) -> Result<()>

Restore a file to its state in a specific commit.

Supports nested paths like audit/2024-05.audit by traversing each path component through sub-trees.

Source

pub fn diff_commits(&self, from_hash: &str, to_hash: &str) -> Result<CommitDiff>

Compute the diff between two commits.

Source

pub fn file_at_commit(&self, rel_path: &str, hash: &str) -> Result<Vec<u8>>

Retrieve file content as it was at a specific commit.

Source

pub fn verify(&self) -> Result<bool>

Verify repository integrity.

Source

pub fn is_enabled(&self) -> bool

Whether auto-commit is enabled.

Source

pub fn root(&self) -> &Path

Get the root path of this git repository.

Trait Implementations§

Source§

impl MemoryGit for GitLayer

Source§

fn commit_file<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, path: &'life1 str, message: &'life2 str, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Commit a file to git.
Source§

fn is_enabled(&self) -> bool

Whether git integration is enabled.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more