Skip to main content

Simple library for merging two strings with respect to a base one

Project description

three-merge

Project License - MIT pypi version conda version download count Downloads PyPI status Linux tests MacOS tests Windows tests

Copyright © 2020– Spyder Project Contributors

Overview

Simple Python library to perform a 3-way merge between strings, based on diff-match-patch. This library performs merges at a character level, as opposed to most VCS systems, which opt for a line-based approach.

Installing

To install three-merge, you can use both conda or pip package managers:

# Using conda (Recommended)
conda install three-merge -c spyder-ide

# Using pip
pip install three-merge

Dependencies

This package depends on diff-match-patch to compute and track the differences across the source and target strings with respect to the base one.

Installing locally

To install and develop three-merge locally, you will need to install diff-match-patch:

# Using conda
conda install diff-match-patch

# Using pip
pip install diff-match-patch

Then, you can install the package locally using pip:

pip install -U -e .

Running tests

We use pytest to run tests as it follows:

pytest -x -v three_merge/tests

Package usage

Three-merge provides a merge function to merge changes from two strings (source, target) with respect a original string (base). This library is able to handle additions, deletions and preserved sections across both strings, while detecting and highlighting possible merge conflicts (like Git).

# Package import
from three_merge import merge

# Strings have non-conflicting additions
base = '123456789101112'
source = '0123456789101112'
target = '12345678910111213'

# merged = '012345678910111213'
merged = merge(source, target, base)

# Strings have an addition conflict
base = '123456789101112'
source = '123a456789101112'
target = '123b456789101112'

# merged = '123<<<<<<< ++ a ======= ++ b >>>>>>>456789101112'
merged = merge(source, target, base)

# Strings have non-conflicting addition/deletions
base = '123456789101112'
source = '123456789ab101112'
target = '123789101112'

# merged = '123789ab101112'
merged = merge(source, target, base)

For more examples, please take a look at our tests.

Changelog

Please see our CHANGELOG file to learn more about our new features and improvements.

Contribution guidelines

We follow PEP8 and PEP257 for all Python modules. We use MyPy type annotations for all functions and classes declared on this package. Feel free to send a PR or create an issue if you have any problem/question.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

three-merge-0.1.1.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

three_merge-0.1.1-py2.py3-none-any.whl (6.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file three-merge-0.1.1.tar.gz.

File metadata

  • Download URL: three-merge-0.1.1.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.3.1.post20200622 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.7.6

File hashes

Hashes for three-merge-0.1.1.tar.gz
Algorithm Hash digest
SHA256 60f6afe144595560d63ae32625351bcef3b94733b54eb97800a9feb0f3d9d970
MD5 31746f7ec935ded29def046321c7dcb1
BLAKE2b-256 4dd186f4a088f2ebdc3ff1a9cb653aab91e588a8d0930b41c2e066e6a2920ae7

See more details on using hashes here.

File details

Details for the file three_merge-0.1.1-py2.py3-none-any.whl.

File metadata

  • Download URL: three_merge-0.1.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 6.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.3.1.post20200622 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.7.6

File hashes

Hashes for three_merge-0.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 dd219f4696aa0bbec6099ac3528b4de0450ff9bde862dd8f6d6f52e745f83464
MD5 09c71e83711f5962c30e2b7c25066ee9
BLAKE2b-256 23bea52588102605ec52b4e88340d65a290b6465c1dbcd2d943ab149b012908b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page