mirror of https://github.com/docker/compose.git
Merge pull request #2745 from albers/completion-services
Fix computation of service lists in bash completion
This commit is contained in:
commit
40d69675f3
|
@ -17,6 +17,10 @@
|
||||||
# . ~/.docker-compose-completion.sh
|
# . ~/.docker-compose-completion.sh
|
||||||
|
|
||||||
|
|
||||||
|
__docker_compose_q() {
|
||||||
|
docker-compose 2>/dev/null ${compose_file:+-f $compose_file} ${compose_project:+-p $compose_project} "$@"
|
||||||
|
}
|
||||||
|
|
||||||
# suppress trailing whitespace
|
# suppress trailing whitespace
|
||||||
__docker_compose_nospace() {
|
__docker_compose_nospace() {
|
||||||
# compopt is not available in ancient bash versions
|
# compopt is not available in ancient bash versions
|
||||||
|
@ -39,7 +43,7 @@ __docker_compose_compose_file() {
|
||||||
|
|
||||||
# Extracts all service names from the compose file.
|
# Extracts all service names from the compose file.
|
||||||
___docker_compose_all_services_in_compose_file() {
|
___docker_compose_all_services_in_compose_file() {
|
||||||
awk -F: '/^[a-zA-Z0-9]/{print $1}' "${compose_file:-$(__docker_compose_compose_file)}" 2>/dev/null
|
__docker_compose_q config --services
|
||||||
}
|
}
|
||||||
|
|
||||||
# All services, even those without an existing container
|
# All services, even those without an existing container
|
||||||
|
@ -49,8 +53,12 @@ __docker_compose_services_all() {
|
||||||
|
|
||||||
# All services that have an entry with the given key in their compose_file section
|
# All services that have an entry with the given key in their compose_file section
|
||||||
___docker_compose_services_with_key() {
|
___docker_compose_services_with_key() {
|
||||||
# flatten sections to one line, then filter lines containing the key and return section name.
|
# flatten sections under "services" to one line, then filter lines containing the key and return section name
|
||||||
awk '/^[a-zA-Z0-9]/{printf "\n"};{printf $0;next;}' "${compose_file:-$(__docker_compose_compose_file)}" 2>/dev/null | awk -F: -v key=": +$1:" '$0 ~ key {print $1}'
|
__docker_compose_q config \
|
||||||
|
| sed -n -e '/^services:/,/^[^ ]/p' \
|
||||||
|
| sed -n 's/^ //p' \
|
||||||
|
| awk '/^[a-zA-Z0-9]/{printf "\n"};{printf $0;next;}' \
|
||||||
|
| awk -F: -v key=": +$1:" '$0 ~ key {print $1}'
|
||||||
}
|
}
|
||||||
|
|
||||||
# All services that are defined by a Dockerfile reference
|
# All services that are defined by a Dockerfile reference
|
||||||
|
@ -67,11 +75,9 @@ __docker_compose_services_from_image() {
|
||||||
# by a boolean expression passed in as argument.
|
# by a boolean expression passed in as argument.
|
||||||
__docker_compose_services_with() {
|
__docker_compose_services_with() {
|
||||||
local containers names
|
local containers names
|
||||||
containers="$(docker-compose 2>/dev/null ${compose_file:+-f $compose_file} ${compose_project:+-p $compose_project} ps -q)"
|
containers="$(__docker_compose_q ps -q)"
|
||||||
names=( $(docker 2>/dev/null inspect --format "{{if ${1:-true}}} {{ .Name }} {{end}}" $containers) )
|
names=$(docker 2>/dev/null inspect -f "{{if ${1:-true}}}{{range \$k, \$v := .Config.Labels}}{{if eq \$k \"com.docker.compose.service\"}}{{\$v}}{{end}}{{end}}{{end}}" $containers)
|
||||||
names=( ${names[@]%_*} ) # strip trailing numbers
|
COMPREPLY=( $(compgen -W "$names" -- "$cur") )
|
||||||
names=( ${names[@]#*_} ) # strip project name
|
|
||||||
COMPREPLY=( $(compgen -W "${names[*]}" -- "$cur") )
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# The services for which at least one paused container exists
|
# The services for which at least one paused container exists
|
||||||
|
|
Loading…
Reference in New Issue