summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Doc/library/optparse.rst5
-rw-r--r--[-rwxr-xr-x]Lib/mailbox.py0
-rw-r--r--Lib/pstats.py29
-rw-r--r--Lib/test/test_set.py2
-rw-r--r--Misc/NEWS2
5 files changed, 30 insertions, 8 deletions
diff --git a/Doc/library/optparse.rst b/Doc/library/optparse.rst
index 8a5b9c2..918e3ec 100644
--- a/Doc/library/optparse.rst
+++ b/Doc/library/optparse.rst
@@ -1228,8 +1228,9 @@ where the input parameters are
the list of arguments to process (default: ``sys.argv[1:]``)
``values``
- object to store option arguments in (default: a new instance of
- :class:`optparse.Values`)
+ a :class:`optparse.Values` object to store option arguments in (default: a
+ new instance of :class:`Values`) -- if you give an existing object, the
+ option defaults will not be initialized on it
and the return values are
diff --git a/Lib/mailbox.py b/Lib/mailbox.py
index d9c289b..d9c289b 100755..100644
--- a/Lib/mailbox.py
+++ b/Lib/mailbox.py
diff --git a/Lib/pstats.py b/Lib/pstats.py
index 3e6e994..a61e93d 100644
--- a/Lib/pstats.py
+++ b/Lib/pstats.py
@@ -596,7 +596,10 @@ if __name__ == '__main__':
print(" that match it are printed.", file=self.stream)
def do_add(self, line):
- self.stats.add(line)
+ if self.stats:
+ self.stats.add(line)
+ else:
+ print("No statistics object is loaded.", file=self.stream)
return 0
def help_add(self):
print("Add profile info from given file to current statistics object.", file=self.stream)
@@ -631,22 +634,33 @@ if __name__ == '__main__':
except IOError as err:
print(err.args[1], file=self.stream)
return
+ except Exception as err:
+ print(err.__class__.__name__ + ':', err, file=self.stream)
+ return
self.prompt = line + "% "
elif len(self.prompt) > 2:
- line = self.prompt[-2:]
+ line = self.prompt[:-2]
+ self.do_read(line)
else:
print("No statistics object is current -- cannot reload.", file=self.stream)
return 0
def help_read(self):
print("Read in profile data from a specified file.", file=self.stream)
+ print("Without argument, reload the current file.", file=self.stream)
def do_reverse(self, line):
- self.stats.reverse_order()
+ if self.stats:
+ self.stats.reverse_order()
+ else:
+ print("No statistics object is loaded.", file=self.stream)
return 0
def help_reverse(self):
print("Reverse the sort order of the profiling report.", file=self.stream)
def do_sort(self, line):
+ if not self.stats:
+ print("No statistics object is loaded.", file=self.stream)
+ return
abbrevs = self.stats.get_sort_arg_defs()
if line and not filter(lambda x,a=abbrevs: x not in a,line.split()):
self.stats.sort_stats(*line.split())
@@ -668,11 +682,16 @@ if __name__ == '__main__':
self.generic_help()
def do_strip(self, line):
- self.stats.strip_dirs()
- return 0
+ if self.stats:
+ self.stats.strip_dirs()
+ else:
+ print("No statistics object is loaded.", file=self.stream)
def help_strip(self):
print("Strip leading path information from filenames in the report.", file=self.stream)
+ def help_help(self):
+ print("Show help for a given command.", file=self.stream)
+
def postcmd(self, stop, line):
if stop:
return stop
diff --git a/Lib/test/test_set.py b/Lib/test/test_set.py
index 3dde82f..de0d9a8 100644
--- a/Lib/test/test_set.py
+++ b/Lib/test/test_set.py
@@ -797,7 +797,7 @@ class TestBasicOps(unittest.TestCase):
result = self.set ^ self.set
self.assertEqual(result, empty_set)
- def checkempty_symmetric_difference(self):
+ def test_empty_symmetric_difference(self):
result = self.set ^ empty_set
self.assertEqual(result, self.set)
diff --git a/Misc/NEWS b/Misc/NEWS
index 3637754..3f186a6 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -84,6 +84,8 @@ C-API
Library
-------
+- Issue #7395: Fix tracebacks in pstats interactive browser.
+
- Issue #1713: Fix os.path.ismount(), which returned true for symbolic links
across devices.