Skip to content

Diff Match Patch is a high-performance library in multiple languages that manipulates plain text.

License

Notifications You must be signed in to change notification settings

FabienZE/diff-match-patch

This branch is 7 commits ahead of google/diff-match-patch:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

1b8d2ed · Feb 2, 2023

History

51 Commits
Jun 18, 2018
Aug 6, 2018
Feb 2, 2023
Aug 27, 2018
Jul 12, 2018
Jul 25, 2019
Jul 12, 2018
Mar 12, 2019
Jul 12, 2018
Jul 25, 2019
Feb 2, 2023
Jan 23, 2018
Jan 23, 2018
Jan 23, 2018
Feb 12, 2018

Repository files navigation

The Diff Match and Patch libraries offer robust algorithms to perform the operations required for synchronizing plain text.

  1. Diff:
    • Compare two blocks of plain text and efficiently return a list of differences.
    • Diff Demo
  2. Match:
    • Given a search string, find its best fuzzy match in a block of plain text. Weighted for both accuracy and location.
    • Match Demo
  3. Patch:
    • Apply a list of patches onto plain text. Use best-effort to apply patch even when the underlying text doesn't match.
    • Patch Demo

Originally built in 2006 to power Google Docs, this library is now available in C++, C#, Dart, Java, JavaScript, Lua, Objective C, and Python.

Reference

Languages

Although each language port of Diff Match Patch uses the same API, there are some language-specific notes.

A standardized speed test tracks the relative performance of diffs in each language.

Algorithms

This library implements Myer's diff algorithm which is generally considered to be the best general-purpose diff. A layer of pre-diff speedups and post-diff cleanups surround the diff algorithm, improving both performance and output quality.

This library also implements a Bitap matching algorithm at the heart of a flexible matching and patching strategy.

About

Diff Match Patch is a high-performance library in multiple languages that manipulates plain text.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 16.9%
  • Objective-C 14.2%
  • Dart 12.2%
  • C# 11.1%
  • C++ 11.1%
  • Java 10.8%
  • Other 23.7%