From 5e71407359ce9dae0c42b013b663782b86030b2f 2011-11-20 09:02:05 From: Fernando Perez Date: 2011-11-20 09:02:05 Subject: [PATCH] Merge pull request #1003 from takluyver/refill-readline-dedup Drop consecutive duplicates when refilling history, both in the terminal (via readline) and in the qt console. --- diff --git a/IPython/core/interactiveshell.py b/IPython/core/interactiveshell.py index c09cab0..ce2ebc3 100644 --- a/IPython/core/interactiveshell.py +++ b/IPython/core/interactiveshell.py @@ -1794,16 +1794,20 @@ class InteractiveShell(SingletonConfigurable, Magic): # Load the last 1000 lines from history self.readline.clear_history() stdin_encoding = sys.stdin.encoding or "utf-8" + last_cell = u"" for _, _, cell in self.history_manager.get_tail(1000, include_latest=True): - if cell.strip(): # Ignore blank lines + # Ignore blank lines and consecutive duplicates + cell = cell.rstrip() + if cell and (cell != last_cell): if self.multiline_history: - self.readline.add_history(py3compat.unicode_to_str(cell.rstrip(), - stdin_encoding)) + self.readline.add_history(py3compat.unicode_to_str(cell, + stdin_encoding)) else: for line in cell.splitlines(): self.readline.add_history(py3compat.unicode_to_str(line, - stdin_encoding)) + stdin_encoding)) + last_cell = cell def set_next_input(self, s): """ Sets the 'default' input string for the next command line. @@ -1815,9 +1819,7 @@ class InteractiveShell(SingletonConfigurable, Magic): [D:\ipython]|1> _ip.set_next_input("Hello Word") [D:\ipython]|2> Hello Word_ # cursor is here """ - if isinstance(s, unicode): - s = s.encode(self.stdin_encoding, 'replace') - self.rl_next_input = s + self.rl_next_input = py3compat.cast_bytes_py2(s) # Maybe move this to the terminal subclass? def pre_readline(self): diff --git a/IPython/frontend/qt/console/ipython_widget.py b/IPython/frontend/qt/console/ipython_widget.py index ea14490..ae183ab 100644 --- a/IPython/frontend/qt/console/ipython_widget.py +++ b/IPython/frontend/qt/console/ipython_widget.py @@ -197,7 +197,13 @@ class IPythonWidget(FrontendWidget): # reset retry flag self._retrying_history_request = False history_items = content['history'] - items = [ line.rstrip() for _, _, line in history_items ] + items = [] + last_cell = u"" + for _, _, cell in history_items: + cell = cell.rstrip() + if cell != last_cell: + items.append(cell) + last_cell = cell self._set_history(items) def _handle_pyout(self, msg):