pub struct Index { /* private fields */ }Expand description
see index-format
to Working Dir relative path
Implementations§
Source§impl Index
impl Index
pub fn new() -> Self
pub fn size(&self) -> usize
pub fn from_file(path: impl AsRef<Path>) -> Result<Self, GitError>
pub fn to_file(&self, path: impl AsRef<Path>) -> Result<(), GitError>
pub fn refresh( &mut self, file: impl AsRef<Path>, workdir: &Path, ) -> Result<bool, GitError>
Source§impl Index
impl Index
Sourcepub fn load(index_file: impl AsRef<Path>) -> Result<Self, GitError>
pub fn load(index_file: impl AsRef<Path>) -> Result<Self, GitError>
Load index. If it does not exist, return an empty index.
pub fn update(&mut self, entry: IndexEntry)
pub fn add(&mut self, entry: IndexEntry)
pub fn remove(&mut self, name: &str, stage: u8) -> Option<IndexEntry>
pub fn get(&self, name: &str, stage: u8) -> Option<&IndexEntry>
pub fn tracked(&self, name: &str, stage: u8) -> bool
pub fn get_hash(&self, file: &str, stage: u8) -> Option<ObjectHash>
pub fn verify_hash(&self, file: &str, stage: u8, hash: &ObjectHash) -> bool
Sourcepub fn is_modified(&self, file: &str, stage: u8, workdir: &Path) -> bool
pub fn is_modified(&self, file: &str, stage: u8, workdir: &Path) -> bool
is file modified after last add (need hash to confirm content change)
workdiris used to rebuild absolute file path
Sourcepub fn tracked_entries(&self, stage: u8) -> Vec<&IndexEntry>
pub fn tracked_entries(&self, stage: u8) -> Vec<&IndexEntry>
Get all entries with the same stage
Sourcepub fn tracked_files(&self) -> Vec<PathBuf>
pub fn tracked_files(&self) -> Vec<PathBuf>
Get all tracked files(stage = 0)
Sourcepub fn contains_dir_file(&self, dir: &str) -> bool
pub fn contains_dir_file(&self, dir: &str) -> bool
Judge if the file(s) of dir is in the index
- false if
diris a file
Sourcepub fn remove_dir_files(&mut self, dir: &str) -> Vec<String>
pub fn remove_dir_files(&mut self, dir: &str) -> Vec<String>
remove all files in dir from index
- do nothing if
diris a file
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Index
impl RefUnwindSafe for Index
impl Send for Index
impl Sync for Index
impl Unpin for Index
impl UnwindSafe for Index
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> ValueSize for T
impl<T> ValueSize for T
Source§fn value_size(&self) -> usize
fn value_size(&self) -> usize
The size of this value in bytes, excluding allocated data. Read more
Source§fn value_size_sum_iter<'item>(iterator: impl Iterator<Item = &'item T>) -> usizewhere
T: 'item,
fn value_size_sum_iter<'item>(iterator: impl Iterator<Item = &'item T>) -> usizewhere
T: 'item,
The total sum of the sizes of all values in the given iterator, in
bytes. This is default-implemented by computing ValueSize::value_size
on every element and summing them. For Sized types, a more potentially
efficient implementation using Iterator::count is provided. If you are
implementing this trait manually, it is unlikely to be more efficient to
provide a manual implementation here. Read more
Source§fn value_size_sum_exact_size_iter<'item>(
iterator: impl ExactSizeIterator<Item = &'item T>,
) -> usizewhere
T: 'item,
fn value_size_sum_exact_size_iter<'item>(
iterator: impl ExactSizeIterator<Item = &'item T>,
) -> usizewhere
T: 'item,
The total sum of the sizes of all values in the given
exact-size-iterator, in bytes. This is default-implemented by using
ValueSize::value_size_sum_iter. For Sized types, a usually more
efficient implementation using ExactSizeIterator::len is provided. If
you are implementing this trait manually, it is unlikely to be more
efficient to provide a manual implementation here. Read more