]> granicus.if.org Git - python/commitdiff
Issue #17540: Added style to Formatter configuration by dict.
authorVinay Sajip <vinay_sajip@yahoo.co.uk>
Fri, 29 Mar 2013 17:56:54 +0000 (17:56 +0000)
committerVinay Sajip <vinay_sajip@yahoo.co.uk>
Fri, 29 Mar 2013 17:56:54 +0000 (17:56 +0000)
Lib/logging/config.py
Lib/test/test_logging.py
Misc/NEWS

index 11e79a26218dc3afba067bfcc41270678c4b7362..188061449d1d6c984555ac39725b3803479ac78e 100644 (file)
@@ -669,7 +669,8 @@ class DictConfigurator(BaseConfigurator):
         else:
             fmt = config.get('format', None)
             dfmt = config.get('datefmt', None)
-            result = logging.Formatter(fmt, dfmt)
+            style = config.get('style', '%')
+            result = logging.Formatter(fmt, dfmt, style)
         return result
 
     def configure_filter(self, config):
@@ -691,6 +692,7 @@ class DictConfigurator(BaseConfigurator):
 
     def configure_handler(self, config):
         """Configure a handler from a dictionary."""
+        config_copy = dict(config)  # for restoring in case of error
         formatter = config.pop('formatter', None)
         if formatter:
             try:
@@ -714,7 +716,7 @@ class DictConfigurator(BaseConfigurator):
                 try:
                     th = self.config['handlers'][config['target']]
                     if not isinstance(th, logging.Handler):
-                        config['class'] = cname # restore for deferred configuration
+                        config.update(config_copy)  # restore for deferred cfg
                         raise TypeError('target not configured yet')
                     config['target'] = th
                 except Exception as e:
index 2ff8c9134dd68f1a27cb4de0369710bd91ceebbc..c9a051ae9f5725a3d9796fd2594bf4c2c89cf2a7 100644 (file)
@@ -2398,7 +2398,8 @@ class ConfigDictTest(BaseTest):
         "version": 1,
         "formatters": {
             "mySimpleFormatter": {
-                "format": "%(asctime)s (%(name)s) %(levelname)s: %(message)s"
+                "format": "%(asctime)s (%(name)s) %(levelname)s: %(message)s",
+                "style": "$"
             }
         },
         "handlers": {
@@ -2728,6 +2729,8 @@ class ConfigDictTest(BaseTest):
         self.apply_config(self.out_of_order)
         handler = logging.getLogger('mymodule').handlers[0]
         self.assertIsInstance(handler.target, logging.Handler)
+        self.assertIsInstance(handler.formatter._style,
+                              logging.StringTemplateStyle)
 
     def test_baseconfig(self):
         d = {
index 7034bcd78523a454dcf5b1aeb7c7181b1ee6ba70..8c016a4c80d95d2be8d32143185d39ad74e4ca44 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -200,6 +200,8 @@ Core and Builtins
 Library
 -------
 
+- Issue #17540: Added style to formatter configuration by dict.
+
 - Issue #17536: Add to webbrowser's browser list: www-browser, x-www-browser,
   iceweasel, iceape.