[Commented On] D9924: config: use a new `alter` method in `fixconfig`
baymax (Baymax, Your Personal Patch-care Companion)
phabricator at mercurial-scm.org
Thu Feb 11 18:46:57 UTC 2021
baymax added a comment.
baymax updated this revision to Diff 25573.
✅ refresh by Heptapod after a successful CI run (🐙 💚)
REPOSITORY
rHG Mercurial
CHANGES SINCE LAST UPDATE
https://phab.mercurial-scm.org/D9924?vs=25516&id=25573
BRANCH
default
CHANGES SINCE LAST ACTION
https://phab.mercurial-scm.org/D9924/new/
REVISION DETAIL
https://phab.mercurial-scm.org/D9924
AFFECTED FILES
mercurial/config.py
mercurial/ui.py
CHANGE DETAILS
diff --git a/mercurial/ui.py b/mercurial/ui.py
--- a/mercurial/ui.py
+++ b/mercurial/ui.py
@@ -556,7 +556,7 @@
p = util.expandpath(p)
if not util.hasscheme(p) and not os.path.isabs(p):
p = os.path.normpath(os.path.join(root, p))
- c.set(b"paths", n, p)
+ c.alter(b"paths", n, p)
if section in (None, b'ui'):
# update ui options
diff --git a/mercurial/config.py b/mercurial/config.py
--- a/mercurial/config.py
+++ b/mercurial/config.py
@@ -108,6 +108,16 @@
self._source = self._source.preparewrite()
self._source[(section, item)] = source
+ def alter(self, section, key, new_value):
+ """alter a value without altering its source or level
+
+ This method is meant to be used by `ui.fixconfig` only."""
+ item = self._data[section][key]
+ size = len(item)
+ new_item = (new_value,) + item[1:]
+ assert len(new_item) == size
+ self._data[section][key] = new_item
+
def restore(self, data):
"""restore data returned by self.backup"""
self._source = self._source.preparewrite()
To: marmoute, #hg-reviewers, Alphare
Cc: Alphare, mercurial-patches
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mercurial-scm.org/pipermail/mercurial-patches/attachments/20210211/f2c45c83/attachment-0002.html>
More information about the Mercurial-patches
mailing list