##// END OF EJS Templates
filemerge: add support for partial conflict resolution by external tool...
filemerge: add support for partial conflict resolution by external tool A common class of merge conflicts is in imports/#includes/etc. It's relatively easy to write a tool that can resolve these conflicts, perhaps by naively just unioning the statements and leaving any cleanup to other tools to do later [1]. Such specialized tools cannot generally resolve all conflicts in a file, of course. Let's therefore call them "partial merge tools". Note that the internal simplemerge algorithm is such a partial merge tool - one that only resolves trivial "conflicts" where one side is unchanged or both sides change in the same way. One can also imagine having smarter language-aware partial tools that merge the AST. It may be useful for such tools to interactively let the user resolve any conflicts it can't resolve itself. However, having the option of implementing it as a partial merge tool means that the developer doesn't *need* to create a UI for it. Instead, the user can resolve any remaining conflicts with their regular merge tool (e.g. `:merge3` or `meld). We don't currently have a way to let the user define such partial merge tools. That's what this patch addresses. It lets the user configure partial merge tools to run. Each tool can be configured to run only on files matching certain patterns (e.g. "*.py"). The tool takes three inputs (local, base, other) and resolves conflicts by updating these in place. For example, let's say the inputs are these: base: ``` import sys def main(): print('Hello') ``` local: ``` import os import sys def main(): print('Hi') ``` other: ``` import re import sys def main(): print('Howdy') ``` A partial merge tool could now resolve the conflicting imports by replacing the import statements in *all* files by the following snippet, while leaving the remainder of the files unchanged. ``` import os import re import sys ``` As a result, simplemerge and any regular merge tool that runs after the partial merge tool(s) will consider the imports to be non-conflicting and will only present the conflict in `main()` to the user. Differential Revision: https://phab.mercurial-scm.org/D12356

File last commit:

r49730:6000f5b2 default
r49838:f3aafd78 default
Show More
__init__.py
74 lines | 2.3 KiB | text/x-python | PythonLexer
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 # Copyright (c) 2017-present, Gregory Szorc
# All rights reserved.
#
# This software may be modified and distributed under the terms
# of the BSD license. See the LICENSE file for details.
"""Python interface to the Zstandard (zstd) compression library."""
# This module serves 2 roles:
#
# 1) Export the C or CFFI "backend" through a central module.
# 2) Implement additional functionality built on top of C or CFFI backend.
import os
import platform
# Some Python implementations don't support C extensions. That's why we have
# a CFFI implementation in the first place. The code here import one of our
# "backends" then re-exports the symbols from this module. For convenience,
# we support falling back to the CFFI backend if the C extension can't be
# imported. But for performance reasons, we only do this on unknown Python
# implementation. Notably, for CPython we require the C extension by default.
# Because someone will inevitably want special behavior, the behavior is
# configurable via an environment variable. A potentially better way to handle
# this is to import a special ``__importpolicy__`` module or something
# defining a variable and `setup.py` could write the file with whatever
# policy was specified at build time. Until someone needs it, we go with
# the hacky but simple environment variable approach.
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446 _module_policy = os.environ.get("PYTHON_ZSTANDARD_IMPORT_POLICY", "default")
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446 if _module_policy == "default":
if platform.python_implementation() in ("CPython",):
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 from zstd import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cext"
elif platform.python_implementation() in ("PyPy",):
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cffi"
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 else:
try:
from zstd import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cext"
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 except ImportError:
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cffi"
elif _module_policy == "cffi_fallback":
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 try:
from zstd import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cext"
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 except ImportError:
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cffi"
elif _module_policy == "cext":
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 from zstd import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cext"
elif _module_policy == "cffi":
Gregory Szorc
zstandard: vendor python-zstandard 0.11...
r42237 from .cffi import *
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446
backend = "cffi"
Gregory Szorc
zstandard: vendor python-zstandard 0.9.0...
r37513 else:
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446 raise ImportError(
"unknown module import policy: %s; use default, cffi_fallback, "
"cext, or cffi" % _module_policy
)
Gregory Szorc
zstandard: vendor python-zstandard 0.10.1...
r40157
# Keep this in sync with python-zstandard.h.
Gregory Szorc
zstandard: vendor python-zstandard 0.13.0...
r44446 __version__ = "0.13.0"