diff options
author | 2020-03-20 22:24:15 +0530 | |
---|---|---|
committer | 2020-03-20 22:24:49 +0530 | |
commit | 0c55977465f1c9aafa50d1131e0570a77d0eeb73 (patch) | |
tree | f0ac0085f64a9c318aa5d23b2766abc3d7c2b2e8 | |
parent | f4786da9bc012ef7929106b1f22c39730519fd09 (diff) | |
download | nnn-0c55977465f1c9aafa50d1131e0570a77d0eeb73.tar.gz |
Fix #496: option -f to use readline history file
-rw-r--r-- | misc/auto-completion/bash/nnn-completion.bash | 1 | ||||
-rw-r--r-- | misc/auto-completion/fish/nnn.fish | 1 | ||||
-rw-r--r-- | misc/auto-completion/zsh/_nnn | 1 | ||||
-rw-r--r-- | nnn.1 | 4 | ||||
-rw-r--r-- | src/nnn.c | 25 |
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]' @@ -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 @@ -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) { |