##// END OF EJS Templates
commit: clear resolved mergestate even if working copy is clean...
commit: clear resolved mergestate even if working copy is clean If the mergestate has resolved conflicts and a commit is successfully created (either because there are changes in the working copy or because ui.allowemptycommit=yes), we will also clear the merge state. However, if the working copy is clean (and ui.allowemptycommit=no), we leave the mergestate there. The user may notice it in `hg resolve -l` output (but not in `hg status -v` output). It's not clear how the user should clear it, but probably via `hg co -C .`. It's also quite likely that they won't even notice it and it will get cleared by a later `hg commit` (of unrelated changes). This patch makes it so that `hg commit` also clears resolved merge conflicts even if the command doesn't end up writing a commit because the working copy was empty. That's probably a little weird (commands that abort should generally avoid changing the repo), but it still seems mostly harmless, and it reduces the risk of more bugs like https://bz.mercurial-scm.org/show_bug.cgi?id=5494. I just ran into a version of that bug in the Evolve extension and that's what triggered this series. Differential Revision: https://phab.mercurial-scm.org/D8196

File last commit:

r44919:6a34e438 default
r44919:6a34e438 default
Show More
next
83 lines | 2.9 KiB | text/plain | TextLexer
Martin von Zweigbergk
releasenotes: add a file in which to record release notes...
r42457 == New Features ==
Valentin Gatien-Baron
purge: add -i flag to delete ignored files instead of untracked files...
r44771 * `hg purge`/`hg clean` can now delete ignored files instead of
untracked files, with the new -i flag.
Martin von Zweigbergk
log: add config for making `hg log -G` always topo-sorted...
r42500
Martin von Zweigbergk
graphlog: use '%' for other context in merge conflict...
r44819 * `hg log` now defaults to using an '%' symbol for commits involved
in unresolved merge conflicts. That includes unresolved conflicts
caused by e.g. `hg update --merge` and `hg graft`. '@' still takes
precedence, so what used to be marked '@' still is.
* New `conflictlocal()` and `conflictother()` revsets return the
Martin von Zweigbergk
revset: add a revset for parents in merge state...
r44817 commits that are being merged, when there are conflicts. Also works
for conflicts caused by e.g. `hg graft`.
Martin von Zweigbergk
copy: add option to unmark file as copied...
r44844 * `hg copy --forget` can be used to unmark a file as copied.
revlog-compression: release note entry for update the config to be a list...
r44875 * The `format.revlog-compression` configuration entry now accept a list. The
first available option will be used. for example setting::
[format]
revlog-compression=zstd, zlib
Will use `zstd` compression for new repositories is available, and will
simply fall back to `zlib` if not.
Martin von Zweigbergk
debugmergestate: make templated...
r44880 * `hg debugmergestate` output is now templated, which may be useful
e.g. for IDEs that want to help the user resolve merge conflicts.
Martin von Zweigbergk
copy: add experimental support for marking committed copies...
r44847 == New Experimental Features ==
Martin von Zweigbergk
revset: add a revset for parents in merge state...
r44817
Martin von Zweigbergk
copy: add experimental support for marking committed copies...
r44847 * `hg copy` now supports a `--at-rev` argument to mark files as
copied in the specified commit. It only works with `--after` for
now (i.e., it's only useful for marking files copied using non-hg
`cp` as copied).
Martin von Zweigbergk
log: add config for making `hg log -G` always topo-sorted...
r42500
Martin von Zweigbergk
copy: add experimetal support for unmarking committed copies...
r44845 * Use `hg copy --forget --at-rev REV` to unmark already committed
copies.
Martin von Zweigbergk
releasenotes: add a file in which to record release notes...
r42457 == Bug Fixes ==
Valentin Gatien-Baron
bookmarks: avoid traceback when two pushes race to delete the same bookmark...
r44852 * Fix server exception when concurrent pushes delete the same bookmark
Martin von Zweigbergk
releasenotes: add a file in which to record release notes...
r42457
Valentin Gatien-Baron
relnotes: move entry to the right spot...
r44876 * Prevent pushes of divergent bookmarks (foo@remote)
Valentin Gatien-Baron
exchange: turn on option that makes concurrent pushes work better...
r44896 * The push error "remote repository changed while pushing - please
try again" now only happens when a concurrent push changed related
heads (instead of when a concurrent pushed any revision).
Martin von Zweigbergk
releasenotes: add a file in which to record release notes...
r42457 == Backwards Compatibility Changes ==
Martin von Zweigbergk
rebase: don't use rebased node as dirstate p2 (BC)...
r44821 * When `hg rebase` pauses for merge conflict resolution, the working
copy will no longer have the rebased node as a second parent. You
can use the new `conflictparents()` revset for finding the other
parent during a conflict.
Valentin Gatien-Baron
relnotes: add entry about previous `hg recover` change...
r44851 * `hg recover` does not verify the validity of the whole repository
anymore. You can pass `--verify` or call `hg verify` if necessary.
Martin von Zweigbergk
narrow: don't hexify paths and double-hexify known nodes on wire (BC)...
r43214
Martin von Zweigbergk
debugmergestate: make templated...
r44880 * `hg debugmergestate` output format changed. Let us know if that is
causing you problems and we'll roll it back.
Martin von Zweigbergk
commit: clear resolved mergestate even if working copy is clean...
r44919 * Resolved merge conflicts are now cleared by `hg commit` even if the
working copy has no changes.
Martin von Zweigbergk
debugmergestate: make templated...
r44880
Martin von Zweigbergk
releasenotes: add a file in which to record release notes...
r42457 == Internal API Changes ==
Martin von Zweigbergk
progress: delete deprecated ui.progress()...
r44619 * The deprecated `ui.progress()` has now been deleted. Please use
`ui.makeprogress()` instead.
Martin von Zweigbergk
merge: drop now-unused "abort" argument from hg.merge()...
r44639
Martin von Zweigbergk
merge: make hg.merge() take a context instead of a node...
r44916 * `hg.merge()` now takes a `ctx` instead of the previous `repo` and
`node` arguments.
Martin von Zweigbergk
merge: drop now-unused "abort" argument from hg.merge()...
r44639 * `hg.merge()` has lost its `abort` argument. Please call
`hg.abortmerge()` directly instead.
Martin von Zweigbergk
cmdutil: change check_incompatible_arguments() *arg to single iterable...
r44655
Martin von Zweigbergk
merge: drop redundant mergeforce argument from hg.merge()...
r44882 * `hg.merge()` has lost its `mergeforce` argument. It should have
only ever been called with the same value as the `force` argument.
Martin von Zweigbergk
cmdutil: change check_incompatible_arguments() *arg to single iterable...
r44655 * The `*others` argument of `cmdutil.check_incompatible_arguments()`
changed from being varargs argument to being a single collection.