Fiz algo que mudou a forma como o preenchimento automático do TAB funciona, mas apenas para o comando more.
Todos os outros comandos listam as conclusões possíveis, mas more agora lista TODAS as possibilidades entre aspas simples.
Então, em /etc, se eu digitar
more pass<TAB>
O resultado é
$ more 'passwdqc.conf
passwd
passwd-'
Digitando
less pass<TAB>
Resulta em
$ less passwd
passwd passwd- passwdqc.conf
Como posso redefini-lo para que more
o preenchimento automático se comporte mais como less
?
Editar:
$ shopt -u
autocd off
cdable_vars off
cdspell off
checkhash off
checkjobs off
compat31 off
compat32 off
compat40 off
compat41 off
direxpand off
dirspell off
dotglob off
execfail off
extdebug off
failglob off
globstar off
gnu_errfmt off
histreedit off
histverify off
hostcomplete off
huponexit off
lastpipe off
lithist off
login_shell off
mailwarn off
no_empty_cmd_completion off
nocaseglob off
nocasematch off
nullglob off
restricted_shell off
shift_verbose off
xpg_echo off
$ set -o
allexport off
braceexpand on
emacs on
errexit off
errtrace off
functrace off
hashall on
histexpand on
history on
ignoreeof off
interactive-comments on
keyword off
monitor on
noclobber off
noexec off
noglob off
nolog off
notify off
nounset off
onecmd off
physical off
pipefail off
posix off
privileged off
verbose off
vi off
xtrace off
Responder1
Posso reproduzir:
_comp_foo() { compopt -o filenames -o nospace; COMPREPLY=("$(compgen -f -- "$2")"); }
complete -F _comp_foo foo
cd /etc
Tipo foo pass
, Tab. Você deverá ver algo assim:
foo 'passwd
passwd-'
:)
Como posso redefini-lo para que o preenchimento automático de mais se comporte mais como menos?
Você pode redefinir uma conclusão do bash NAME
comcomplete -r NAME
help complete
diz:
-r – remove uma especificação de conclusão para cada NOME ou, se nenhum NOME for fornecido, todas as especificações de conclusão
Você pode reutilizar uma conclusão existente:
_completion_loader less 2>/dev/null # for bash-completion >= 1.9, bash >= 4.1
eval $(complete -p less | sed 's/ less$/ more/')
Veja também:como reutilizar a conclusão existente com a conclusão recente do bash