relnotes/6.2
author Arun Kulshreshtha <akulshreshtha@janestreet.com>
Tue, 30 Aug 2022 15:29:55 -0400
changeset 49491 c6a1beba27e9
parent 49369 cf566b57107c
child 49475 f64261762f3d
permissions -rw-r--r--
bisect: avoid copying ancestor list for non-merge commits During a bisection, hg needs to compute a list of all ancestors for every candidate commit. This is accomplished via a bottom-up traversal of the set of candidates, during which each revision's ancestor list is populated using the ancestor list of its parent(s). Previously, this involved copying the entire list, which could be very long in if the bisection range was large. To help improve this, we can observe that each candidate commit is visited exactly once, at which point its ancestor list is copied into its children's lists and then dropped. In the case of non-merge commits, a commit's ancestor list consists exactly of its parent's list plus itself. This means that we can trivially reuse the parent's existing list for one of its non-merge children, which avoids copying entirely if that commit is the parent's only child. This makes bisections over linear ranges of commits much faster. During some informal testing in the large publicly-available `mozilla-central` repository, this noticeably sped up bisections over large ranges of history: Setup: $ cd mozilla-central $ hg bisect --reset $ hg bisect --good 0 $ hg log -r tip -T '{rev}\n' 628417 Test: $ time hg bisect --bad tip --noupdate Before: real 3m35.927s user 3m35.553s sys 0m0.319s After: real 1m41.142s user 1m40.810s sys 0m0.285s

= Mercurial 6.2rc0 =

'''This is the first release to support Python 3.6+ ''only'''''

== New Features ==
 * Introduce a way to auto-upgrade a repo for certain requirements (see `hg help config.format`)
 * filemerge: add support for partial conflict resolution by external tool
 * contrib: add a partial-merge tool for sorted lists (such as Python imports)
 * revlog: reorder p1 and p2 when p1 is null and p2 is not while respecting issue6528
 * rhg: add support for ignoring all extensions
 * completion: install completers to conventional locations
 * revert: ask user to confirm before tracking new file when interactive
 * Rust implementation now uses the new dirstate API
 * sslutil: be less strict about which ciphers are allowed when using --insecure
 * sslutil: support TLSV1_ALERT_PROTOCOL_VERSION reason code
 * absorb: make `--edit-lines` imply `--apply-changes`
 * diff: add help text to highlight the ability to do merge diffs
 * censor: make rhg fall back to python when encountering a censored node
 * clone: use better names for temp files
 * debuglock: make the command more useful in non-interactive mode
 * debugdeltachain: distinct between snapshot and other diffs
 * debugindex: rename to debugindex debug-revlog-index
 * Make debug-revlog-index give out more information
 * sparse: use the rust code even when sparse is present

== Bug Fixes ==
 * Python 3 bugfixes
 * Windows bugfixes
 * templates: make `firstline` filter not keep '\v', '\f' and similar
 * rhg: sort unsupported extensions in error message
 * Improve performance of all functions that extract the first line of a text
 * crecord: avoid duplicating lines when reverting noeol->eol change
 * Some config.path options are now discoverable via config
 * mail: don't complain about a multi-word email.method
 * bundlespec: do not overwrite bundlespec value with the config one
 * bundlespec: do not check for `-` in the params portion of the bundlespec
 * bundlespec: handle the presence of obsmarker part
 * sparse: start moving away from the global variable for detection of usage
 * rust-changelog: don't skip empty lines when iterating over changeset lines
 * narrow: support debugupgraderepo
 * bundle: quick fix to ludicrous performance penalty
 * followlines: don't put Unicode directly into the .js file (issue6559)
 * manifest: improve error message in case for tree manifest
 * revlog: use %d to format int instead of %lu (issue6565)
 * revlog: use appropriate format char for int ("i" instead of I")
 * worker: stop relying on garbage collection to release memoryview
 * worker: implement _blockingreader.readinto() (issue6444)
 * worker: avoid potential partial write of pickled data

== Backwards Compatibility Changes ==
 * '''Removed Python 2 support''': this includes a lot of cleanup in our codebase, automation, testing, etc.
 * debugindex: rename to debugindex debug-revlog-index

== Miscellaneous ==

 * Fix typos and add missing items from documentation
 * dirstate-tree: optimize HashMap lookups with raw_entry_mut
 * Rust dependencies have been upgraded
 * revlog: rank computation is done by Rust when available
 * Improve discovery test tooling
 * Audit the number of queries done in discovery
 * Improved .hgignore of the mercurial-devel repository itself
 * Improve test coverage of dirstate-v2
 * rust-requirements: allow loading repos with `bookmarksinstore` requirement
 * Various Rust refactorings to help with revlog management
 * Improve debugability of Rust structs
 * Improve unit testing of the Rust dirstatemap
 * Improve robustness of the Rust dirstatemap to corruption
 * Improve changelog-v2 upgrade system