diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2013-09-29 20:18:38 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2013-09-29 20:18:38 (GMT) |
commit | 5d23e6d54352db7c64d152dbabef798340127ccb (patch) | |
tree | 014cb6e1ea26a7c9f25e565874c7b3b41ed1b54a /Lib | |
parent | 95536b8405e318457ea41f8f10ee645231b48faa (diff) | |
download | cpython-5d23e6d54352db7c64d152dbabef798340127ccb.zip cpython-5d23e6d54352db7c64d152dbabef798340127ccb.tar.gz cpython-5d23e6d54352db7c64d152dbabef798340127ccb.tar.bz2 |
Issue #5845: In site.py, only load readline history from ~/.python_history if no history has been read already. This avoids double writes to the history file at shutdown.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/site.py | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/Lib/site.py b/Lib/site.py index 9f935a3..e1fa30e 100644 --- a/Lib/site.py +++ b/Lib/site.py @@ -405,12 +405,19 @@ def enablerlcompleter(): # want to ignore the exception. pass - history = os.path.join(os.path.expanduser('~'), '.python_history') - try: - readline.read_history_file(history) - except IOError: - pass - atexit.register(readline.write_history_file, history) + if readline.get_history_item(1) is None: + # If no history was loaded, default to .python_history. + # The guard is necessary to avoid doubling history size at + # each interpreter exit when readline was already configured + # through a PYTHONSTARTUP hook, see: + # http://bugs.python.org/issue5845#msg198636 + history = os.path.join(os.path.expanduser('~'), + '.python_history') + try: + readline.read_history_file(history) + except IOError: + pass + atexit.register(readline.write_history_file, history) sys.__interactivehook__ = register_readline |