tests/fakemergerecord.py
author Augie Fackler <augie@google.com>
Wed, 14 Feb 2018 21:34:12 -0500
changeset 36275 f574cc00831a
parent 36222 56635c506608
child 36510 4dc6f0905722
permissions -rw-r--r--
node: make bin() be a wrapper instead of just an alias This includes a full backout of 59affe7e and 30d0cb27. Per the review of the former, we'd rather adapt the API to behave like it used to (at least for now), and take a second run at it if it shows up in our performance numbers. I ran perfrevlogindex with and without this change and it didn't make a measurable difference, so maybe it's fine (despite my intuition to the contrary). Differential Revision: https://phab.mercurial-scm.org/D2279

# Extension to write out fake unsupported records into the merge state
#
#

from __future__ import absolute_import

from mercurial import (
    merge,
    registrar,
)

cmdtable = {}
command = registrar.command(cmdtable)

@command(b'fakemergerecord',
         [(b'X', b'mandatory', None, b'add a fake mandatory record'),
          (b'x', b'advisory', None, b'add a fake advisory record')], '')
def fakemergerecord(ui, repo, *pats, **opts):
    with repo.wlock():
        ms = merge.mergestate.read(repo)
        records = ms._makerecords()
        if opts.get(b'mandatory'):
            records.append((b'X', b'mandatory record'))
        if opts.get(b'advisory'):
            records.append((b'x', b'advisory record'))
        ms._writerecords(records)