This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author asolovyov
Recipients asolovyov
Date 2010-09-16.16:38:04
SpamBayes Score 9.1138045e-06
Marked as misclassified No
Message-id <1284655085.98.0.131711113127.issue9876@psf.upfronthosting.co.za>
In-reply-to
Content
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)
History
Date User Action Args
2010-09-16 16:38:06asolovyovsetrecipients: + asolovyov
2010-09-16 16:38:05asolovyovsetmessageid: <1284655085.98.0.131711113127.issue9876@psf.upfronthosting.co.za>
2010-09-16 16:38:04asolovyovlinkissue9876 messages
2010-09-16 16:38:04asolovyovcreate