bash
set completion-ignore-case on
in ~/.inputrc
(o bind 'set completion-ignore-case on'
in ~/.bashrc
) sarebbe la mia raccomandazione. Se hai intenzione di digitare il nome completo, perché lasciar perdere a poche pressioni del Shifttasto?
Ma se lo vuoi davvero, ecco un wrapper cd
che cerca una corrispondenza esatta e, se non ce n'è, cerca una corrispondenza senza distinzione tra maiuscole e minuscole e la esegue se è unica. Utilizza l' nocaseglob
opzione shell per il globbing senza distinzione tra maiuscole e minuscole e trasforma l'argomento in un glob aggiungendo @()
(che non corrisponde a nulla e richiede extglob
). L' extglob
opzione deve essere attivata durante la definizione della funzione, altrimenti bash non può nemmeno analizzarla. Questa funzione non supporta CDPATH
.
shopt -s extglob
cd () {
builtin cd "$@" 2>/dev/null && return
local options_to_unset=; local -a matches
[[ :$BASHOPTS: = *:extglob:* ]] || options_to_unset="$options_to_unset extglob"
[[ :$BASHOPTS: = *:nocaseglob:* ]] || options_to_unset="$options_to_unset nocaseglob"
[[ :$BASHOPTS: = *:nullglob:* ]] || options_to_unset="$options_to_unset nullglob"
shopt -s extglob nocaseglob nullglob
matches=("${!#}"@()/)
shopt -u $options_to_unset
case ${#matches[@]} in
0) # There is no match, even case-insensitively. Let cd display the error message.
builtin cd "$@";;
1)
matches=("$@" "${matches[0]}")
unset "matches[$(($#-1))]"
builtin cd "${matches[@]}";;
*)
echo "Ambiguous case-insensitive directory match:" >&2
printf "%s\n" "${matches[@]}" >&2
return 3;;
esac
}
ksh
Mentre ci sono, ecco una funzione simile per ksh93. La ~(i)
modifica per la corrispondenza senza distinzione tra maiuscole e minuscole sembra essere incompatibile con il /
suffisso per abbinare solo le directory (questo potrebbe essere un bug nella mia versione di ksh). Quindi uso una strategia diversa per eliminare le non-directory.
cd () {
command cd "$@" 2>/dev/null && return
typeset -a args; typeset previous target; typeset -i count=0
args=("$@")
for target in ~(Ni)"${args[$(($#-1))]}"; do
[[ -d $target ]] || continue
if ((count==1)); then printf "Ambiguous case-insensitive directory match:\n%s\n" "$previous" >&2; fi
if ((count)); then echo "$target"; fi
((++count))
previous=$target
done
((count <= 1)) || return 3
args[$(($#-1))]=$target
command cd "${args[@]}"
}
zsh
Infine, ecco una versione zsh. Ancora una volta, consentire il completamento senza distinzione tra maiuscole e minuscole è probabilmente l'opzione migliore. La seguente impostazione ritorna al globbing senza distinzione tra maiuscole e minuscole se non esiste una corrispondenza esatta del caso:
zstyle ':completion:*' '' matcher-list 'm:{a-z}={A-Z}'
Rimuovi ''
per mostrare tutte le corrispondenze senza distinzione tra maiuscole e minuscole anche se esiste una corrispondenza tra maiuscole e minuscole. Puoi impostarlo dall'interfaccia del menu di compinstall
.
cd () {
builtin cd "$@" 2>/dev/null && return
emulate -L zsh
setopt local_options extended_glob
local matches
matches=( (#i)${(P)#}(N/) )
case $#matches in
0) # There is no match, even case-insensitively. Try cdpath.
if ((#cdpath)) &&
[[ ${(P)#} != (|.|..)/* ]] &&
matches=( $^cdpath/(#i)${(P)#}(N/) ) &&
((#matches==1))
then
builtin cd $@[1,-2] $matches[1]
return
fi
# Still nothing. Let cd display the error message.
builtin cd "$@";;
1)
builtin cd $@[1,-2] $matches[1];;
*)
print -lr -- "Ambiguous case-insensitive directory match:" $matches >&2
return 3;;
esac
}
backUP
ebackUp
come,backup
no, in quale directory vuoi andare?