]> granicus.if.org Git - python/commitdiff
Bug #2606: Avoid calling .sort() on a dict_keys object.
authorMartin v. Löwis <martin@v.loewis.de>
Thu, 10 Apr 2008 19:02:25 +0000 (19:02 +0000)
committerMartin v. Löwis <martin@v.loewis.de>
Thu, 10 Apr 2008 19:02:25 +0000 (19:02 +0000)
Lib/trace.py
Misc/NEWS

index 06b72b7de52434c40458be79baa7cd3d69973da6..a5c2f1104becce7466068390a569b0e074e443be 100644 (file)
@@ -249,19 +249,15 @@ class CoverageResults:
         if self.calledfuncs:
             print()
             print("functions called:")
-            calls = self.calledfuncs.keys()
-            calls.sort()
-            for filename, modulename, funcname in calls:
+            for filename, modulename, funcname in sorted(calls.keys()):
                 print(("filename: %s, modulename: %s, funcname: %s"
                        % (filename, modulename, funcname)))
 
         if self.callers:
             print()
             print("calling relationships:")
-            calls = self.callers.keys()
-            calls.sort()
             lastfile = lastcfile = ""
-            for ((pfile, pmod, pfunc), (cfile, cmod, cfunc)) in calls:
+            for ((pfile, pmod, pfunc), (cfile, cmod, cfunc)) in sorted(self.callers.keys()):
                 if pfile != lastfile:
                     print()
                     print("***", pfile, "***")
@@ -318,10 +314,8 @@ class CoverageResults:
                 sums[modulename] = n_lines, percent, modulename, filename
 
         if summary and sums:
-            mods = sums.keys()
-            mods.sort()
             print("lines   cov%   module   (path)")
-            for m in mods:
+            for m in sorted(sums.keys()):
                 n_lines, percent, modulename, filename = sums[m]
                 print("%5d   %3d%%   %s   (%s)" % sums[m])
 
index 1ff242aaf7a4abbcd628484cb88f540551879c13..beed5cb17054b1457cdbf19d4f5bf1ab28d1d003 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -25,6 +25,8 @@ Extension Modules
 Library
 -------
 
+- Bug #2606: Avoid calling .sort() on a dict_keys object.
+
 - The bundled libffi copy is now in sync with the recently released
   libffi3.0.5 version, apart from some small changes to
   Modules/_ctypes/libffi/configure.ac.