Skip to main content

GitRepository

Struct GitRepository 

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

A wrapper around gix::Repository providing a simplified interface for Git repository operations.

Implementations§

Source§

impl GitRepository

Source

pub fn init(path: &Path) -> Result<Self>

Initialize a new Git repository at the given path.

Creates the directory (and parents) if it does not exist, then initializes a standard (non-bare) Git repository with a .git directory.

Source

pub fn open(path: &Path) -> Result<Self>

Open an existing Git repository at the given path.

Source

pub fn path(&self) -> &Path

Get the working directory path of the repository.

Returns the working tree directory if available, otherwise falls back to the .git directory itself.

Source

pub fn inner(&self) -> &Repository

Get a reference to the inner gix::Repository.

Source

pub fn commit( &self, message: &str, author_name: &str, author_email: &str, ) -> Result<String>

Create a Git commit with the current working directory state. Uses command-line git for simplicity (gix’s commit API is complex).

Source

pub fn read_tree_entry(&self, commit_hex: &str, path: &str) -> Result<Vec<u8>>

Read a file’s content from a specific commit’s tree (NOT the working directory). This is the core isolation primitive for Native Session Isolation.

commit_hex — hex SHA of the commit whose tree to read from. path — relative file path within the tree (e.g. “src/main.rs”).

Returns the raw bytes of the blob, or an error if the commit / path does not exist or the entry is not a blob.

Source

pub fn list_tree_files(&self, commit_hex: &str) -> Result<Vec<String>>

List all files (recursive) in a commit’s tree. Returns relative paths using forward-slash separators.

Only non-tree entries (blobs, symlinks, submodules) are included.

Source

pub fn commit_tree_overlay( &self, base_commit_hex: &str, overlay: &[(String, Option<Vec<u8>>)], parent_commit_hex: &str, message: &str, author_name: &str, author_email: &str, ) -> Result<String>

Build a new git tree by applying overlay changes on a base tree, create a commit, and update the working directory.

For each overlay entry:

  • Some(content) → upsert a blob at that path
  • None → delete the entry at that path

After committing, the working directory is updated via git checkout HEAD -- ..

Returns the hex SHA of the new commit.

Source

pub fn commit_initial_overlay( &self, overlay: &[(String, Option<Vec<u8>>)], message: &str, author_name: &str, author_email: &str, ) -> Result<String>

Create an orphan commit from overlay entries on an empty repository (no existing commits). This is used for the very first commit.

Builds a tree from scratch using only the overlay entries (ignoring None/deletion entries since there’s nothing to delete), creates a root commit with no parents, and updates HEAD.

Returns the hex SHA of the new commit.

Source

pub fn head_hash(&self) -> Result<Option<String>>

Get the HEAD commit hash as a hex string, or None if the repository is empty (no commits yet).

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<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
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
Source§

impl<T> Fruit for T
where T: Send + Downcast,