[Python-checkins] cpython (3.4): Issue #21172: isinstance check relaxed from dict to collections.Mapping.

vinay.sajip python-checkins at python.org
Thu Apr 10 08:14:17 CEST 2014


http://hg.python.org/cpython/rev/5e303360db14
changeset:   90215:5e303360db14
branch:      3.4
parent:      90211:094615256a54
user:        Vinay Sajip <vinay_sajip at yahoo.co.uk>
date:        Thu Apr 10 07:12:19 2014 +0100
summary:
  Issue #21172: isinstance check relaxed from dict to collections.Mapping.

files:
  Lib/logging/__init__.py |  11 +++++++++--
  Misc/NEWS               |   2 ++
  2 files changed, 11 insertions(+), 2 deletions(-)


diff --git a/Lib/logging/__init__.py b/Lib/logging/__init__.py
--- a/Lib/logging/__init__.py
+++ b/Lib/logging/__init__.py
@@ -23,7 +23,8 @@
 To use, simply 'import logging' and log away!
 """
 
-import sys, os, time, io, traceback, warnings, weakref
+import sys, os, time, io, traceback, warnings, weakref, collections
+
 from string import Template
 
 __all__ = ['BASIC_FORMAT', 'BufferingFormatter', 'CRITICAL', 'DEBUG', 'ERROR',
@@ -253,7 +254,13 @@
         # 'Value is %d' instead of 'Value is 0'.
         # For the use case of passing a dictionary, this should not be a
         # problem.
-        if args and len(args) == 1 and isinstance(args[0], dict) and args[0]:
+        # Issue #21172: a request was made to relax the isinstance check
+        # to hasattr(args[0], '__getitem__'). However, the docs on string
+        # formatting still seem to suggest a mapping object is required.
+        # Thus, while not removing the isinstance check, it does now look
+        # for collections.Mapping rather than, as before, dict.
+        if (args and len(args) == 1 and isinstance(args[0], collections.Mapping)
+            and args[0]):
             args = args[0]
         self.args = args
         self.levelname = getLevelName(level)
diff --git a/Misc/NEWS b/Misc/NEWS
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -27,6 +27,8 @@
 Library
 -------
 
+- Issue #21172: isinstance check relaxed from dict to collections.Mapping.
+
 - Issue #21155: asyncio.EventLoop.create_unix_server() now raises a ValueError
   if path and sock are specified at the same time.
 

-- 
Repository URL: http://hg.python.org/cpython


More information about the Python-checkins mailing list