Improve history

Also adds partial history completion, like zsh
This commit is contained in:
Florian Bruhin 2014-01-21 11:59:01 +01:00
parent 485c7a6316
commit 133e4c4b61

View File

@ -147,6 +147,7 @@ class StatusCommand(QLineEdit):
bar = None # The status bar object bar = None # The status bar object
esc_pressed = pyqtSignal() # Emitted when escape is pressed esc_pressed = pyqtSignal() # Emitted when escape is pressed
history = [] # The command history, with newer commands at the bottom history = [] # The command history, with newer commands at the bottom
_tmphist = []
_histpos = None _histpos = None
def __init__(self, bar): def __init__(self, bar):
@ -167,7 +168,7 @@ class StatusCommand(QLineEdit):
def process_cmd(self): def process_cmd(self):
"""Handle the command in the status bar""" """Handle the command in the status bar"""
self._histpos = None self._histbrowse_stop()
text = self.text().lstrip(':') text = self.text().lstrip(':')
if not self.history or text != self.history[-1]: if not self.history or text != self.history[-1]:
self.history.append(text) self.history.append(text)
@ -184,6 +185,7 @@ class StatusCommand(QLineEdit):
if e.reason() in [Qt.MouseFocusReason, Qt.TabFocusReason, if e.reason() in [Qt.MouseFocusReason, Qt.TabFocusReason,
Qt.BacktabFocusReason, Qt.OtherFocusReason]: Qt.BacktabFocusReason, Qt.OtherFocusReason]:
self.setText('') self.setText('')
self._histbrowse_stop()
super().focusOutEvent(e) super().focusOutEvent(e)
def focusInEvent(self, e): def focusInEvent(self, e):
@ -191,26 +193,41 @@ class StatusCommand(QLineEdit):
self.bar.clear_error() self.bar.clear_error()
super().focusInEvent(e) super().focusInEvent(e)
def _histbrowse_start(self):
pre = self.text().strip().lstrip(':')
logging.debug('Preset text: "{}"'.format(pre))
if pre:
self._tmphist = [e for e in self.history if e.startswith(pre)]
else:
self._tmphist = self.history
self._histpos = len(self._tmphist) - 1
def _histbrowse_stop(self):
self._histpos = None
def key_up_handler(self): def key_up_handler(self):
logging.debug("history up: {} / len {} / pos {}".format( logging.debug("history up [pre]: pos {}".format(self._histpos))
self.history, len(self.history), self._histpos)) if self._histpos is None:
if self._histpos == 0 or not self.history: self._histbrowse_start()
elif self._histpos <= 0 or not self._tmphist:
return return
elif self._histpos is None:
self._histpos = len(self.history) - 1
else: else:
self._histpos -= 1 self._histpos -= 1
self.setText(':' + self.history[self._histpos]) logging.debug("history up: {} / len {} / pos {}".format(
self._tmphist, len(self._tmphist), self._histpos))
self.set_cmd(':' + self._tmphist[self._histpos])
def key_down_handler(self): def key_down_handler(self):
logging.debug("history down: {} / len {} / pos {}".format( logging.debug("history up [pre]: pos {}".format(self._histpos,
self.history, len(self.history), self._histpos)) self._tmphist, len(self._tmphist), self._histpos))
if (self._histpos is None or if (self._histpos is None or
self._histpos >= len(self.history) - 1 or self._histpos >= len(self._tmphist) - 1 or
not self.history): not self._tmphist):
return return
self._histpos += 1 self._histpos += 1
self.setText(':' + self.history[self._histpos]) logging.debug("history up: {} / len {} / pos {}".format(
self._tmphist, len(self._tmphist), self._histpos))
self.set_cmd(':' + self._tmphist[self._histpos])
def key_tab_handler(self): def key_tab_handler(self):
# TODO implement tab completion # TODO implement tab completion