mirror of https://github.com/adamdruppe/arsd.git
history recall options
This commit is contained in:
parent
7c13c57c57
commit
6ee52d53f0
110
terminal.d
110
terminal.d
|
@ -4567,8 +4567,55 @@ class LineGetter {
|
||||||
return finishGettingLine();
|
return finishGettingLine();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/++
|
||||||
|
Set in [historyRecallFilterMethod].
|
||||||
|
|
||||||
|
History:
|
||||||
|
Added November 27, 2020.
|
||||||
|
+/
|
||||||
|
enum HistoryRecallFilterMethod {
|
||||||
|
/++
|
||||||
|
Goes through history in simple chronological order.
|
||||||
|
Your existing command entry is not considered as a filter.
|
||||||
|
+/
|
||||||
|
chronological,
|
||||||
|
/++
|
||||||
|
Goes through history filtered with only those that begin with your current command entry.
|
||||||
|
|
||||||
|
So, if you entered "animal", "and", "bad", "cat" previously, then enter
|
||||||
|
"a" and pressed up, it would jump to "and", then up again would go to "animal".
|
||||||
|
+/
|
||||||
|
prefixed,
|
||||||
|
/++
|
||||||
|
Goes through history filtered with only those that $(B contain) your current command entry.
|
||||||
|
|
||||||
|
So, if you entered "animal", "and", "bad", "cat" previously, then enter
|
||||||
|
"n" and pressed up, it would jump to "and", then up again would go to "animal".
|
||||||
|
+/
|
||||||
|
containing,
|
||||||
|
/++
|
||||||
|
Goes through history to fill in your command at the cursor. It filters to only entries
|
||||||
|
that start with the text before your cursor and ends with text after your cursor.
|
||||||
|
|
||||||
|
So, if you entered "animal", "and", "bad", "cat" previously, then enter
|
||||||
|
"ad" and pressed left to position the cursor between the a and d, then pressed up
|
||||||
|
it would jump straight to "and".
|
||||||
|
+/
|
||||||
|
sandwiched,
|
||||||
|
}
|
||||||
|
/++
|
||||||
|
Controls what happens when the user presses the up key, etc., to recall history entries. See [HistoryRecallMethod] for the options.
|
||||||
|
|
||||||
|
This has no effect on the history search user control (default key: F3 or ctrl+r), which always searches through a "containing" method.
|
||||||
|
|
||||||
|
History:
|
||||||
|
Added November 27, 2020.
|
||||||
|
+/
|
||||||
|
HistoryRecallFilterMethod historyRecallFilterMethod = HistoryRecallFilterMethod.chronological;
|
||||||
|
|
||||||
private int currentHistoryViewPosition = 0;
|
private int currentHistoryViewPosition = 0;
|
||||||
private dchar[] uncommittedHistoryCandidate;
|
private dchar[] uncommittedHistoryCandidate;
|
||||||
|
private int uncommitedHistoryCursorPosition;
|
||||||
void loadFromHistory(int howFarBack) {
|
void loadFromHistory(int howFarBack) {
|
||||||
if(howFarBack < 0)
|
if(howFarBack < 0)
|
||||||
howFarBack = 0;
|
howFarBack = 0;
|
||||||
|
@ -4585,21 +4632,76 @@ class LineGetter {
|
||||||
uncommittedHistoryCandidate[0 .. line.length] = line[];
|
uncommittedHistoryCandidate[0 .. line.length] = line[];
|
||||||
uncommittedHistoryCandidate = uncommittedHistoryCandidate[0 .. line.length];
|
uncommittedHistoryCandidate = uncommittedHistoryCandidate[0 .. line.length];
|
||||||
uncommittedHistoryCandidate.assumeSafeAppend();
|
uncommittedHistoryCandidate.assumeSafeAppend();
|
||||||
|
uncommitedHistoryCursorPosition = cursorPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
currentHistoryViewPosition = howFarBack;
|
|
||||||
|
|
||||||
if(howFarBack == 0) {
|
if(howFarBack == 0) {
|
||||||
|
zero:
|
||||||
line.length = uncommittedHistoryCandidate.length;
|
line.length = uncommittedHistoryCandidate.length;
|
||||||
line.assumeSafeAppend();
|
line.assumeSafeAppend();
|
||||||
line[] = uncommittedHistoryCandidate[];
|
line[] = uncommittedHistoryCandidate[];
|
||||||
} else {
|
} else {
|
||||||
line = line[0 .. 0];
|
line = line[0 .. 0];
|
||||||
line.assumeSafeAppend();
|
line.assumeSafeAppend();
|
||||||
foreach(dchar ch; history[$ - howFarBack])
|
|
||||||
line ~= ch;
|
string selection;
|
||||||
|
|
||||||
|
final switch(historyRecallFilterMethod) with(HistoryRecallFilterMethod) {
|
||||||
|
case chronological:
|
||||||
|
selection = history[$ - howFarBack];
|
||||||
|
break;
|
||||||
|
case prefixed:
|
||||||
|
case containing:
|
||||||
|
import std.algorithm;
|
||||||
|
int count;
|
||||||
|
foreach_reverse(item; history) {
|
||||||
|
if(
|
||||||
|
(historyRecallFilterMethod == prefixed && item.startsWith(uncommittedHistoryCandidate))
|
||||||
|
||
|
||||||
|
(historyRecallFilterMethod == containing && item.canFind(uncommittedHistoryCandidate))
|
||||||
|
)
|
||||||
|
{
|
||||||
|
selection = item;
|
||||||
|
count++;
|
||||||
|
if(count == howFarBack)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
howFarBack = count;
|
||||||
|
break;
|
||||||
|
case sandwiched:
|
||||||
|
import std.algorithm;
|
||||||
|
int count;
|
||||||
|
foreach_reverse(item; history) {
|
||||||
|
if(
|
||||||
|
(item.startsWith(uncommittedHistoryCandidate[0 .. uncommitedHistoryCursorPosition]))
|
||||||
|
&&
|
||||||
|
(item.endsWith(uncommittedHistoryCandidate[uncommitedHistoryCursorPosition .. $]))
|
||||||
|
)
|
||||||
|
{
|
||||||
|
selection = item;
|
||||||
|
count++;
|
||||||
|
if(count == howFarBack)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
howFarBack = count;
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(howFarBack == 0)
|
||||||
|
goto zero;
|
||||||
|
|
||||||
|
int i;
|
||||||
|
line.length = selection.length;
|
||||||
|
foreach(dchar ch; selection)
|
||||||
|
line[i++] = ch;
|
||||||
|
line = line[0 .. i];
|
||||||
|
line.assumeSafeAppend();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
currentHistoryViewPosition = howFarBack;
|
||||||
cursorPosition = cast(int) line.length;
|
cursorPosition = cast(int) line.length;
|
||||||
scrollToEnd();
|
scrollToEnd();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue