• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

bystep15/google-diff-match-patch: Automatically exported from code.google.com/p/ ...

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称(OpenSource Name):

bystep15/google-diff-match-patch

开源软件地址(OpenSource Url):

https://github.com/bystep15/google-diff-match-patch

开源编程语言(OpenSource Language):

Python 16.9%

开源软件介绍(OpenSource Introduction):

Diff, Match and Patch Library http://code.google.com/p/google-diff-match-patch/ Neil Fraser

This library is currently available in seven different ports, all using the same API. Every version includes a full set of unit tests.

API地址(https://github.com/bystep15/google-diff-match-patch/tree/wiki)

C++:

  • Ported by Mike Slemmer.
  • Currently requires the Qt library.

C#:

  • Ported by Matthaeus G. Chajdas.

Dart:

  • The Dart language is still growing and evolving, so this port is only as stable as the underlying language.

Java:

  • Included is both the source and a Maven package.

JavaScript:

  • diff_match_patch_uncompressed.js is the human-readable version. Users of node.js should 'require' this uncompressed version since the compressed version is not guaranteed to work outside of a web browser.
  • diff_match_patch.js has been compressed using Google's internal JavaScript compressor. Non-Google hackers who wish to recompress the source can use: http://dean.edwards.name/packer/

Lua:

  • Ported by Duncan Cross.
  • Does not support line-mode speedup.

Objective C:

  • Ported by Jan Weiss.
  • Includes speed test (this is a separate bundle for other languages).

Python:

  • Two versions, one for Python 2.x, the other for Python 3.x.
  • Runs 10x faster under PyPy than CPython.

Demos:

  • Separate demos for Diff, Match and Patch in JavaScript.

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

Diff

  • Compare two blocks of plain text and efficiently return a list of differences.
  • Diff Demo

Match

  • Given a search string, find its best fuzzy match in a block of plain text. Weighted for both accuracy and location.
  • Match Demo

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

Currently available in Java, JavaScript, Dart, C++, C#, Objective C, Lua and Python. Regardless of language, each library features the same API and the same functionality. All versions also have comprehensive test harnesses.

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.




鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Sponsor @gocanto on GitHub Sponsors · GitHub发布时间:2022-06-11
下一篇:
gocanto/google-autocomplete: Google Autocomplete Vue Component发布时间:2022-06-11
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap