##// END OF EJS Templates
tracked-key: remove the dual write and rename to tracked-hint...
tracked-key: remove the dual write and rename to tracked-hint The dual-write approach was mostly useless. As explained in the previous version of the help, the key had to be read twice before we could cache a value. However this "read twice" limitation actually also apply to any usage of the key. If some operation wants to rely of the "same value == same tracked set" property it would need to read the value before, and after running that operation (or at least, after, in all cases). So it cannot be sure the operation it did is "valid" until checking the key after the operation. As a resultat such operation can only be read-only or rollbackable. This reduce the utility of the "same value == same tracked set" a lot. So it seems simpler to drop the double write and to update the documentation to highlight that this file does not garantee race-free operation. As a result the "key" is demoted to a "hint". Documentation is updated accordingly. Differential Revision: https://phab.mercurial-scm.org/D12201

File last commit:

r46554:89a2afe3 default
r49644:6e559391 default
Show More
rcutil.py
119 lines | 3.6 KiB | text/x-python | PythonLexer
Jun Wu
rcutil: move scmutil.*rcpath to rcutil (API)...
r31679 # rcutil.py - utilities about config paths, special config sections etc.
#
# Copyright Mercurial Contributors
#
# This software may be used and distributed according to the terms of the
# GNU General Public License version 2 or any later version.
from __future__ import absolute_import
import os
from . import (
encoding,
pycompat,
util,
)
Martin von Zweigbergk
util: remove datapath and swith users over to resourceutil...
r44070 from .utils import resourceutil
Jun Wu
codemod: use pycompat.iswindows...
r34646 if pycompat.iswindows:
Jun Wu
rcutil: move scmutil.*rcpath to rcutil (API)...
r31679 from . import scmwindows as scmplatform
else:
from . import scmposix as scmplatform
Yuya Nishihara
pager: use less as a fallback on Unix...
r32078 fallbackpager = scmplatform.fallbackpager
Jun Wu
rcutil: move scmutil.*rcpath to rcutil (API)...
r31679 systemrcpath = scmplatform.systemrcpath
userrcpath = scmplatform.userrcpath
Augie Fackler
style: run a patched black on a subset of mercurial...
r43345
Jun Wu
rcutil: extract rc directory listing logic...
r31681 def _expandrcpath(path):
'''path could be a file or a directory. return a list of file paths'''
p = util.expandpath(path)
if os.path.isdir(p):
join = os.path.join
Augie Fackler
style: run a patched black on a subset of mercurial...
r43345 return sorted(
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 join(p, f) for f, k in util.listdir(p) if f.endswith(b'.rc')
Augie Fackler
style: run a patched black on a subset of mercurial...
r43345 )
Jun Wu
rcutil: extract rc directory listing logic...
r31681 return [p]
Augie Fackler
style: run a patched black on a subset of mercurial...
r43345
Jun Wu
rcutil: add a method to convert environment variables to config items...
r31684 def envrcitems(env=None):
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """Return [(section, name, value, source)] config items.
Jun Wu
rcutil: add a method to convert environment variables to config items...
r31684
The config items are extracted from environment variables specified by env,
used to override systemrc, but not userrc.
If env is not provided, encoding.environ will be used.
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """
Jun Wu
rcutil: add a method to convert environment variables to config items...
r31684 if env is None:
env = encoding.environ
checklist = [
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 (b'EDITOR', b'ui', b'editor'),
(b'VISUAL', b'ui', b'editor'),
(b'PAGER', b'pager', b'pager'),
Jun Wu
rcutil: add a method to convert environment variables to config items...
r31684 ]
result = []
for envname, section, configname in checklist:
if envname not in env:
continue
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 result.append((section, configname, env[envname], b'$%s' % envname))
Jun Wu
rcutil: add a method to convert environment variables to config items...
r31684 return result
Augie Fackler
style: run a patched black on a subset of mercurial...
r43345
Matt Harbison
ui: add the ability to apply `defaultrc` configs from resources...
r44483 def default_rc_resources():
"""return rc resource IDs in defaultrc"""
rsrcs = resourceutil.contents(b'mercurial.defaultrc')
return [
(b'mercurial.defaultrc', r)
for r in sorted(rsrcs)
if resourceutil.is_resource(b'mercurial.defaultrc', r)
and r.endswith(b'.rc')
]
Jun Wu
rcutil: rename rcpath to rccomponents (API)
r31682 def rccomponents():
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """return an ordered [(type, obj)] about where to load configs.
Jun Wu
rcutil: let rccomponents return different types of configs (API)...
r31683
respect $HGRCPATH. if $HGRCPATH is empty, only .hg/hgrc of current repo is
used. if $HGRCPATH is not set, the platform default will be used.
if a directory is provided, *.rc files under it will be used.
Matt Harbison
ui: add the ability to apply `defaultrc` configs from resources...
r44483 type could be either 'path', 'items' or 'resource'. If type is 'path',
obj is a string, and is the config file path. if type is 'items', obj is a
list of (section, name, value, source) that should fill the config directly.
If type is 'resource', obj is a tuple of (package name, resource name).
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 envrc = (b'items', envrcitems())
Jun Wu
rcutil: let environ override system configs (BC)...
r31685
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 if b'HGRCPATH' in encoding.environ:
Jun Wu
rcutil: unindent a block...
r31693 # assume HGRCPATH is all about user configs so environments can be
# overridden.
_rccomponents = [envrc]
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 for p in encoding.environ[b'HGRCPATH'].split(pycompat.ospathsep):
Jun Wu
rcutil: unindent a block...
r31693 if not p:
continue
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 _rccomponents.extend((b'path', p) for p in _expandrcpath(p))
Jun Wu
rcutil: unindent a block...
r31693 else:
Matt Harbison
ui: add the ability to apply `defaultrc` configs from resources...
r44483 _rccomponents = [(b'resource', r) for r in default_rc_resources()]
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 normpaths = lambda paths: [
(b'path', os.path.normpath(p)) for p in paths
]
Matt Harbison
rcutil: drop the `defaultrcpath()` method (API)...
r44484 _rccomponents.extend(normpaths(systemrcpath()))
Jun Wu
rcutil: unindent a block...
r31693 _rccomponents.append(envrc)
Jun Wu
rcutil: extract duplicated logic to a lambda...
r31694 _rccomponents.extend(normpaths(userrcpath()))
Jun Wu
rcutil: rename rcpath to rccomponents (API)
r31682 return _rccomponents
Jun Wu
pager: set some environment variables if they're not set...
r31954
Augie Fackler
style: run a patched black on a subset of mercurial...
r43345
Jun Wu
pager: set some environment variables if they're not set...
r31954 def defaultpagerenv():
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """return a dict of default environment variables and their values,
Jun Wu
pager: set some environment variables if they're not set...
r31954 intended to be set before starting a pager.
Augie Fackler
formating: upgrade to black 20.8b1...
r46554 """
Augie Fackler
formatting: byteify all mercurial/ and hgext/ string literals...
r43347 return {b'LESS': b'FRX', b'LV': b'-c'}
config: add a function in `rcutil` to abstract HGRCSKIPREPO...
r44727
def use_repo_hgrc():
"""True if repositories `.hg/hgrc` config should be read"""
return b'HGRCSKIPREPO' not in encoding.environ