#[non_exhaustive]pub enum StrictApplyError {
Patch(PatchError),
PartialApply {
report: ApplyResult,
},
}Expand description
Represents errors that can occur during “strict” apply operations.
This enum is returned by functions like try_apply_patch_to_file() and
try_apply_patch_to_content(), which treat partial applications as an error.
It consolidates hard failures (PatchError) and soft failures (StrictApplyError::PartialApply)
into a single error type for easier handling in apply-or-fail workflows.
§Example
use mpatch::{parse_single_patch, try_apply_patch_to_content, ApplyOptions, StrictApplyError};
let original_content = "line 1\nline 2\n";
// This patch will fail because the context "WRONG CONTEXT" is not in the original content.
let failing_diff = r#"
```diff
--- a/file.txt
+++ b/file.txt
@@ -1,2 +1,2 @@
line 1
-WRONG CONTEXT
+line two
```
"#;
let patch = parse_single_patch(failing_diff)?;
let options = ApplyOptions::exact();
// Using the try_ variant simplifies error handling for partial applications.
let result = try_apply_patch_to_content(&patch, Some(original_content), &options);
assert!(matches!(result, Err(StrictApplyError::PartialApply { .. })));
if let Err(StrictApplyError::PartialApply { report }) = result {
assert!(!report.all_applied_cleanly());
}Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Patch(PatchError)
A hard error occurred during the patch operation (e.g., I/O error, file not found).
PartialApply
The patch was only partially applied, with some hunks failing.
Fields
§
report: ApplyResultThe detailed report of the operation, including which hunks succeeded/failed.
Trait Implementations§
Source§impl Debug for StrictApplyError
impl Debug for StrictApplyError
Source§impl Display for StrictApplyError
impl Display for StrictApplyError
Source§impl Error for StrictApplyError
impl Error for StrictApplyError
Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
👎Deprecated since 1.42.0:
use the Display impl or to_string()
Source§impl From<PatchError> for StrictApplyError
impl From<PatchError> for StrictApplyError
Source§fn from(source: PatchError) -> Self
fn from(source: PatchError) -> Self
Converts to this type from the input type.
Source§impl From<StrictApplyError> for OneShotError
impl From<StrictApplyError> for OneShotError
Source§fn from(source: StrictApplyError) -> Self
fn from(source: StrictApplyError) -> Self
Converts to this type from the input type.
Auto Trait Implementations§
impl Freeze for StrictApplyError
impl !RefUnwindSafe for StrictApplyError
impl Send for StrictApplyError
impl Sync for StrictApplyError
impl Unpin for StrictApplyError
impl UnsafeUnpin for StrictApplyError
impl !UnwindSafe for StrictApplyError
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> 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 more