pub struct Patch {
pub diff_algorithm: DiffAlgorithm,
pub compress_algorithm: CompressAlgorithm,
pub before_hash: String,
pub after_hash: String,
pub patch: Vec<u8>,
}
Expand description
A patch that can transform one file into another.
Contains all the information needed to verify and apply a patch, including source and target file hashes for integrity validation.
§Example
use files_diff::{diff, apply, DiffAlgorithm, CompressAlgorithm};
let source = b"original content";
let target = b"modified content";
// Generate a patch
let patch = diff(
source,
target,
DiffAlgorithm::Rsync020,
CompressAlgorithm::Zstd
)?;
// Verify source hash matches
assert_eq!(files_diff::hash(source), patch.before_hash);
// Apply patch and verify result
let result = apply(source, &patch)?;
assert_eq!(files_diff::hash(&result), patch.after_hash);
Fields§
§diff_algorithm: DiffAlgorithm
Algorithm used to generate this patch
compress_algorithm: CompressAlgorithm
Compression method used for the patch data
before_hash: String
MD5 hash of the source file
after_hash: String
MD5 hash of the target file
patch: Vec<u8>
The actual patch data
Implementations§
Trait Implementations§
Source§impl Archive for Patch
impl Archive for Patch
Source§const COPY_OPTIMIZATION: CopyOptimization<Self>
const COPY_OPTIMIZATION: CopyOptimization<Self>
An optimization flag that allows the bytes of this type to be copied
directly to a writer instead of calling
serialize
. Read moreSource§impl<__D: Fallible + ?Sized> Deserialize<Patch, __D> for Archived<Patch>where
DiffAlgorithm: Archive,
<DiffAlgorithm as Archive>::Archived: Deserialize<DiffAlgorithm, __D>,
CompressAlgorithm: Archive,
<CompressAlgorithm as Archive>::Archived: Deserialize<CompressAlgorithm, __D>,
String: Archive,
<String as Archive>::Archived: Deserialize<String, __D>,
Vec<u8>: Archive,
<Vec<u8> as Archive>::Archived: Deserialize<Vec<u8>, __D>,
impl<__D: Fallible + ?Sized> Deserialize<Patch, __D> for Archived<Patch>where
DiffAlgorithm: Archive,
<DiffAlgorithm as Archive>::Archived: Deserialize<DiffAlgorithm, __D>,
CompressAlgorithm: Archive,
<CompressAlgorithm as Archive>::Archived: Deserialize<CompressAlgorithm, __D>,
String: Archive,
<String as Archive>::Archived: Deserialize<String, __D>,
Vec<u8>: Archive,
<Vec<u8> as Archive>::Archived: Deserialize<Vec<u8>, __D>,
Source§impl<__S: Fallible + ?Sized> Serialize<__S> for Patchwhere
DiffAlgorithm: Serialize<__S>,
CompressAlgorithm: Serialize<__S>,
String: Serialize<__S>,
Vec<u8>: Serialize<__S>,
impl<__S: Fallible + ?Sized> Serialize<__S> for Patchwhere
DiffAlgorithm: Serialize<__S>,
CompressAlgorithm: Serialize<__S>,
String: Serialize<__S>,
Vec<u8>: Serialize<__S>,
impl StructuralPartialEq for Patch
Auto Trait Implementations§
impl Freeze for Patch
impl RefUnwindSafe for Patch
impl Send for Patch
impl Sync for Patch
impl Unpin for Patch
impl UnwindSafe for Patch
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> ArchiveUnsized for Twhere
T: Archive,
impl<T> ArchiveUnsized for Twhere
T: Archive,
Source§type Archived = <T as Archive>::Archived
type Archived = <T as Archive>::Archived
The archived counterpart of this type. Unlike
Archive
, it may be
unsized. Read moreSource§fn archived_metadata(
&self,
) -> <<T as ArchiveUnsized>::Archived as ArchivePointee>::ArchivedMetadata
fn archived_metadata( &self, ) -> <<T as ArchiveUnsized>::Archived as ArchivePointee>::ArchivedMetadata
Creates the archived version of the metadata for this value.
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> 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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out
indicating that a T
is niched.