You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Note: these values reflect the state of the issue at the time it was migrated and might not reflect the current state.
Show more details
GitHub fields:
assignee=Noneclosed_at=<Date2010-11-22.03:20:05.036>created_at=<Date2010-09-16.16:38:04.774>labels= ['type-feature', 'library']
title="ConfigParser can't interpolate values from other sections"updated_at=<Date2010-11-22.03:20:05.034>user='https://bugs.python.org/asolovyov'
Often it is useful to access some variable in other section for interpolation needs: for example, parent directory declared in common section could be used in configuration of certain components. Included patch can fix that (using syntax 'section.variable'), is there any chances that it could be applied? :)
--- ConfigParser.old.py 2010-09-16 19:20:27.000000000 +0300+++ ConfigParser.py 2010-09-16 19:22:33.000000000 +0300@@ -585,7 +585,7 @@
if "%(" in value:
value = self._KEYCRE.sub(self._interpolation_replace, value)
try:
- value = value % vars+ value = value % _Context(self, section)
except KeyError, e:
raise InterpolationMissingOptionError(
option, section, rawval, e.args[0])
@@ -667,3 +667,15 @@
raise ValueError("invalid interpolation syntax in %r at "
"position %d" % (value, m.start()))
ConfigParser.set(self, section, option, value)
+++class _Context(object):+ def __init__(self, config, section):+ self.config = config+ self.section = section++ def __getitem__(self, key):+ if '.' in key:+ return self.config.get(*key.split('.'))+ else:+ return self.config.get(self.section, key)
Note: these values reflect the state of the issue at the time it was migrated and might not reflect the current state.
Show more details
GitHub fields:
bugs.python.org fields:
The text was updated successfully, but these errors were encountered: