aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Arun Prakash Jana <engineerarun@gmail.com>2020-03-20 22:24:15 +0530
committerGravatar Arun Prakash Jana <engineerarun@gmail.com>2020-03-20 22:24:49 +0530
commit0c55977465f1c9aafa50d1131e0570a77d0eeb73 (patch)
treef0ac0085f64a9c318aa5d23b2766abc3d7c2b2e8
parentf4786da9bc012ef7929106b1f22c39730519fd09 (diff)
downloadnnn-0c55977465f1c9aafa50d1131e0570a77d0eeb73.tar.gz
Fix #496: option -f to use readline history file
-rw-r--r--misc/auto-completion/bash/nnn-completion.bash1
-rw-r--r--misc/auto-completion/fish/nnn.fish1
-rw-r--r--misc/auto-completion/zsh/_nnn1
-rw-r--r--nnn.14
-rw-r--r--src/nnn.c25
5 files changed, 27 insertions, 5 deletions
diff --git a/misc/auto-completion/bash/nnn-completion.bash b/misc/auto-completion/bash/nnn-completion.bash
index df37a84..fa5cab3 100644
--- a/misc/auto-completion/bash/nnn-completion.bash
+++ b/misc/auto-completion/bash/nnn-completion.bash
@@ -19,6 +19,7 @@ _nnn ()
-d
-e
-E
+ -f
-g
-H
-K
diff --git a/misc/auto-completion/fish/nnn.fish b/misc/auto-completion/fish/nnn.fish
index 5cb3171..3a7f10c 100644
--- a/misc/auto-completion/fish/nnn.fish
+++ b/misc/auto-completion/fish/nnn.fish
@@ -18,6 +18,7 @@ complete -c nnn -s c -d 'cli-only opener'
complete -c nnn -s d -d 'start in detail mode'
complete -c nnn -s e -d 'open text files in $VISUAL/$EDITOR/vi'
complete -c nnn -s E -d 'use EDITOR for undetached edits'
+complete -c nnn -s f -d 'use readline history file'
complete -c nnn -s g -d 'regex filters'
complete -c nnn -s H -d 'show hidden files'
complete -c nnn -s K -d 'detect key collision'
diff --git a/misc/auto-completion/zsh/_nnn b/misc/auto-completion/zsh/_nnn
index 2a486be..bdbd555 100644
--- a/misc/auto-completion/zsh/_nnn
+++ b/misc/auto-completion/zsh/_nnn
@@ -16,6 +16,7 @@ args=(
'(-d)-d[start in detail mode]'
'(-e)-e[open text files in $VISUAL/$EDITOR/vi]'
'(-E)-E[use EDITOR for undetached edits]'
+ '(-f)-f[use readline history file]'
'(-g)-g[regex filters]'
'(-H)-H[show hidden files]'
'(-K)-K[detect key collision]'
diff --git a/nnn.1 b/nnn.1
index f843d7a..84b184c 100644
--- a/nnn.1
+++ b/nnn.1
@@ -13,6 +13,7 @@
.Op Ar -d
.Op Ar -e
.Op Ar -E
+.Op Ar -f
.Op Ar -g
.Op Ar -H
.Op Ar -K
@@ -73,6 +74,9 @@ supports the following options:
.Fl E
use $EDITOR for internal undetached edits
.Pp
+.Fl f
+ use readline history file
+.Pp
.Fl g
use regex filters instead of substring match
.Pp
diff --git a/src/nnn.c b/src/nnn.c
index 8ca8757..c47c0c5 100644
--- a/src/nnn.c
+++ b/src/nnn.c
@@ -6477,6 +6477,9 @@ static void usage(void)
" -d detail mode\n"
" -e text in $VISUAL ($EDITOR/vi)\n"
" -E use EDITOR for undetached edits\n"
+#ifndef NORL
+ " -f use readline history file\n"
+#endif
" -g regex filters [default: string]\n"
" -H show hidden files\n"
" -K detect key collision\n"
@@ -6635,10 +6638,13 @@ int main(int argc, char *argv[])
#endif
const char* const env_opts = xgetenv(env_cfg[NNN_OPTS], NULL);
int env_opts_id = env_opts ? (int)strlen(env_opts) : -1;
+#ifndef NORL
+ bool rlhist = FALSE;
+#endif
while ((opt = (env_opts_id > 0
? env_opts[--env_opts_id]
- : getopt(argc, argv, "aAb:cdeEgHKnop:QrRs:St:T:Vxh"))) != -1) {
+ : getopt(argc, argv, "aAb:cdeEfgHKnop:QrRs:St:T:Vxh"))) != -1) {
switch (opt) {
case 'a':
cfg.mtime = 0;
@@ -6666,6 +6672,11 @@ int main(int argc, char *argv[])
case 'E':
cfg.waitedit = 1;
break;
+ case 'f':
+#ifndef NORL
+ rlhist = TRUE;
+#endif
+ break;
case 'g':
cfg.regex = 1;
filterfn = &visible_re;
@@ -6926,8 +6937,10 @@ int main(int argc, char *argv[])
#else
rl_bind_key('\t', rl_complete);
#endif
- mkpath(cfgdir, ".history", g_buf);
- read_history(g_buf);
+ if (rlhist) {
+ mkpath(cfgdir, ".history", g_buf);
+ read_history(g_buf);
+ }
#endif
#ifndef NOMOUSE
@@ -6952,8 +6965,10 @@ int main(int argc, char *argv[])
exitcurses();
#ifndef NORL
- mkpath(cfgdir, ".history", g_buf);
- write_history(g_buf);
+ if (rlhist) {
+ mkpath(cfgdir, ".history", g_buf);
+ write_history(g_buf);
+ }
#endif
if (cfg.pickraw) {