9 releases (breaking)

0.7.0 Dec 28, 2022
0.6.0 Jan 12, 2022
0.5.0 Feb 13, 2019
0.4.2 Sep 7, 2017
0.4.1 Nov 25, 2016

#731 in Parser implementations

Download history 1813/week @ 2024-09-25 2015/week @ 2024-10-02 1740/week @ 2024-10-09 1904/week @ 2024-10-16 1809/week @ 2024-10-23 1604/week @ 2024-10-30 1802/week @ 2024-11-06 2696/week @ 2024-11-13 2325/week @ 2024-11-20 2493/week @ 2024-11-27 2696/week @ 2024-12-04 2209/week @ 2024-12-11 1852/week @ 2024-12-18 843/week @ 2024-12-25 1833/week @ 2025-01-01 2367/week @ 2025-01-08

7,305 downloads per month
Used in 14 crates (12 directly)

MIT license

36KB
697 lines

Patch

Checks Crates.io Badge docs.rs Lines of Code

Rust crate for parsing and producing patch files in the Unified Format.

The parser attempts to be forgiving enough to be compatible with diffs produced by programs like git. It accomplishes this by ignoring the additional code context and information provided in the diff by those programs.

See the Documentation for more information and for examples.


lib.rs:

Parse and produce patch files (diffs) in the Unified Format.

The format is not fully specified, but people like Guido van Rossum have done the work to figure out the details.

The parser attempts to be forgiving enough to be compatible with diffs produced by programs like git. It accomplishes this by ignoring the additional code context and information provided in the diff by those programs.

Example

// Make sure you add the `patch` crate to the `[dependencies]` key of your Cargo.toml file.
use patch::Patch;

let sample = "\
--- before.py
+++ path/to/after.py
@@ -1,4 +1,4 @@
-bacon
-eggs
-ham
+python
+eggy
+hamster
 guido\n";

let patch = Patch::from_single(sample)?;
assert_eq!(&patch.old.path, "before.py");
assert_eq!(&patch.new.path, "path/to/after.py");

// Print out the parsed patch file in its Rust representation
println!("{:#?}", patch);

// Print out the parsed patch file in the Unified Format. For input that was originally in the
// Unified Format, this will produce output identical to that original input.
println!("{}", patch); // use format!("{}\n", patch) to get this as a String

Dependencies

~2.5MB
~38K SLoC