From 0dc0ff9d372afb560daec81166e9e53ed3da5bd6 Mon Sep 17 00:00:00 2001 From: Thomas Jentzsch Date: Fri, 14 May 2021 09:32:03 +0200 Subject: [PATCH] fixed history scrolling --- src/debugger/gui/PromptWidget.cxx | 15 ++++++--------- src/debugger/gui/PromptWidget.hxx | 2 +- 2 files changed, 7 insertions(+), 10 deletions(-) diff --git a/src/debugger/gui/PromptWidget.cxx b/src/debugger/gui/PromptWidget.cxx index ef055e817..3f34ce52e 100644 --- a/src/debugger/gui/PromptWidget.cxx +++ b/src/debugger/gui/PromptWidget.cxx @@ -556,15 +556,13 @@ void PromptWidget::textPaste() } // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -int PromptWidget::historyDir(int& index, int direction, bool promptSpace) +int PromptWidget::historyDir(int& index, int direction) { - int historySize = int(_history.size()) + (promptSpace ? 1 : 0); - index += direction; if(index < 0) - index += historySize; + index += int(_history.size()); else - index %= historySize; + index %= int(_history.size()); return index; } @@ -620,13 +618,12 @@ bool PromptWidget::historyScroll(int direction) if(_history.size() == 0) return false; + // add current input temporarily to history if(_historyLine == 0) - { historyAdd(getLine()); - } // Advance to the next/prev line in the history - historyDir(_historyLine, direction, _history.size() < kHistorySize); + historyDir(_historyLine, direction); // Search the history using the original input do @@ -639,7 +636,7 @@ bool PromptWidget::historyScroll(int direction) break; // Advance to the next/prev line in the history - historyDir(_historyLine, direction, _history.size() < kHistorySize); + historyDir(_historyLine, direction); } while(_historyLine); // If _historyLine == 0, nothing was found diff --git a/src/debugger/gui/PromptWidget.hxx b/src/debugger/gui/PromptWidget.hxx index 852c8fd85..8536c1e80 100644 --- a/src/debugger/gui/PromptWidget.hxx +++ b/src/debugger/gui/PromptWidget.hxx @@ -133,7 +133,7 @@ class PromptWidget : public Widget, public CommandSender bool _firstTime{true}; bool _exitedEarly{false}; - int historyDir(int& index, int direction, bool promptSpace = false); + int historyDir(int& index, int direction); void historyAdd(const string& entry); private: