pub enum CompressAlgorithm {
None,
Zstd,
}
Expand description
Compression algorithms available for patch data.
Determines how patch data is compressed before storage or transmission. Different algorithms offer tradeoffs between compression ratio and speed.
§Example
use files_diff::{diff, DiffAlgorithm, CompressAlgorithm};
let before = b"original content";
let after = b"modified content";
// Use no compression for debugging or when speed is critical
let uncompressed = diff(
before,
after,
DiffAlgorithm::Rsync020,
CompressAlgorithm::None
)?;
// Use Zstd for maximum compression
let compressed = diff(
before,
after,
DiffAlgorithm::Rsync020,
CompressAlgorithm::Zstd
)?;
Variants§
None
No compression. Patch data is stored as-is. Use this when:
- Debugging patches
- Working with already compressed data
- Speed is more important than size
Zstd
Zstandard compression with level 21 (maximum compression). Use this when:
- Minimizing patch size is critical
- Network bandwidth or storage is limited
- Compression time is not a concern
Implementations§
Trait Implementations§
Source§impl Archive for CompressAlgorithm
impl Archive for CompressAlgorithm
Source§type Resolver = CompressAlgorithmResolver
type Resolver = CompressAlgorithmResolver
The resolver for this type. It must contain all the additional
information from serializing needed to make the archived type from
the normal type.
Source§fn resolve(&self, resolver: Self::Resolver, out: Place<Self::Archived>)
fn resolve(&self, resolver: Self::Resolver, out: Place<Self::Archived>)
Creates the archived version of this value at the given position and
writes it to the given output. Read more
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 Clone for CompressAlgorithm
impl Clone for CompressAlgorithm
Source§fn clone(&self) -> CompressAlgorithm
fn clone(&self) -> CompressAlgorithm
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl Debug for CompressAlgorithm
impl Debug for CompressAlgorithm
Source§impl<__D: Fallible + ?Sized> Deserialize<CompressAlgorithm, __D> for Archived<CompressAlgorithm>
impl<__D: Fallible + ?Sized> Deserialize<CompressAlgorithm, __D> for Archived<CompressAlgorithm>
Source§fn deserialize(
&self,
deserializer: &mut __D,
) -> Result<CompressAlgorithm, <__D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut __D, ) -> Result<CompressAlgorithm, <__D as Fallible>::Error>
Deserializes using the given deserializer
Source§impl Display for CompressAlgorithm
impl Display for CompressAlgorithm
Source§impl Hash for CompressAlgorithm
impl Hash for CompressAlgorithm
Source§impl PartialEq for CompressAlgorithm
impl PartialEq for CompressAlgorithm
impl Copy for CompressAlgorithm
impl Eq for CompressAlgorithm
impl StructuralPartialEq for CompressAlgorithm
Auto Trait Implementations§
impl Freeze for CompressAlgorithm
impl RefUnwindSafe for CompressAlgorithm
impl Send for CompressAlgorithm
impl Sync for CompressAlgorithm
impl Unpin for CompressAlgorithm
impl UnwindSafe for CompressAlgorithm
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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.