2017-07-31 19:48:09 -04:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
set -Eeuo pipefail
|
2014-08-14 14:58:13 -04:00
|
|
|
|
2016-06-09 13:41:31 -04:00
|
|
|
declare -A aliases=(
|
2016-12-28 17:23:58 -05:00
|
|
|
[2.4]='2 latest'
|
2014-08-14 14:58:13 -04:00
|
|
|
)
|
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
defaultDebianSuite='stretch'
|
|
|
|
declare -A debianSuites=(
|
|
|
|
[2.2]='jessie'
|
|
|
|
[2.3]='jessie'
|
|
|
|
[2.4]='jessie'
|
|
|
|
)
|
|
|
|
defaultAlpineVersion='3.6'
|
|
|
|
declare -A alpineVersions=(
|
|
|
|
[2.2]='3.4'
|
|
|
|
[2.3]='3.4'
|
|
|
|
[2.4]='3.4'
|
|
|
|
)
|
|
|
|
|
2016-06-09 13:41:31 -04:00
|
|
|
self="$(basename "$BASH_SOURCE")"
|
2014-08-14 14:58:13 -04:00
|
|
|
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
|
|
|
|
|
|
|
|
versions=( */ )
|
|
|
|
versions=( "${versions[@]%/}" )
|
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
# sort version numbers with highest first
|
|
|
|
IFS=$'\n'; versions=( $(echo "${versions[*]}" | sort -rV) ); unset IFS
|
|
|
|
|
2016-06-09 13:41:31 -04:00
|
|
|
# get the most recent commit which modified any of "$@"
|
|
|
|
fileCommit() {
|
|
|
|
git log -1 --format='format:%H' HEAD -- "$@"
|
|
|
|
}
|
|
|
|
|
|
|
|
# get the most recent commit which modified "$1/Dockerfile" or any file COPY'd from "$1/Dockerfile"
|
|
|
|
dirCommit() {
|
|
|
|
local dir="$1"; shift
|
|
|
|
(
|
|
|
|
cd "$dir"
|
|
|
|
fileCommit \
|
|
|
|
Dockerfile \
|
|
|
|
$(git show HEAD:./Dockerfile | awk '
|
|
|
|
toupper($1) == "COPY" {
|
|
|
|
for (i = 2; i < NF; i++) {
|
|
|
|
print $i
|
|
|
|
}
|
|
|
|
}
|
|
|
|
')
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-06-15 18:49:20 -04:00
|
|
|
getArches() {
|
|
|
|
local repo="$1"; shift
|
|
|
|
local officialImagesUrl='https://github.com/docker-library/official-images/raw/master/library/'
|
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
eval "declare -g -A parentRepoToArches=( $(
|
2017-06-15 18:49:20 -04:00
|
|
|
find -name 'Dockerfile' -exec awk '
|
|
|
|
toupper($1) == "FROM" && $2 !~ /^('"$repo"'|scratch|microsoft\/[^:]+)(:|$)/ {
|
|
|
|
print "'"$officialImagesUrl"'" $2
|
|
|
|
}
|
|
|
|
' '{}' + \
|
|
|
|
| sort -u \
|
|
|
|
| xargs bashbrew cat --format '[{{ .RepoName }}:{{ .TagName }}]="{{ join " " .TagEntry.Architectures }}"'
|
|
|
|
) )"
|
|
|
|
}
|
|
|
|
getArches 'ruby'
|
|
|
|
|
2016-06-09 13:41:31 -04:00
|
|
|
cat <<-EOH
|
2016-06-09 13:58:26 -04:00
|
|
|
# this file is generated via https://github.com/docker-library/ruby/blob/$(fileCommit "$self")/$self
|
2016-06-09 13:41:31 -04:00
|
|
|
|
|
|
|
Maintainers: Tianon Gravi <admwiggin@gmail.com> (@tianon),
|
|
|
|
Joseph Ferguson <yosifkit@gmail.com> (@yosifkit)
|
|
|
|
GitRepo: https://github.com/docker-library/ruby.git
|
|
|
|
EOH
|
|
|
|
|
|
|
|
# prints "$2$1$3$1...$N"
|
|
|
|
join() {
|
|
|
|
local sep="$1"; shift
|
|
|
|
local out; printf -v out "${sep//%/%%}%s" "$@"
|
|
|
|
echo "${out#$sep}"
|
|
|
|
}
|
2014-08-14 14:58:13 -04:00
|
|
|
|
|
|
|
for version in "${versions[@]}"; do
|
2017-07-31 19:48:09 -04:00
|
|
|
debianSuite="${debianSuites[$version]:-$defaultDebianSuite}"
|
|
|
|
alpineVersion="${alpineVersions[$version]:-$defaultAlpineVersion}"
|
2016-06-09 13:41:31 -04:00
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
for v in \
|
|
|
|
{stretch,jessie}{,/slim,/onbuild} \
|
|
|
|
alpine{3.6,3.4} \
|
|
|
|
; do
|
|
|
|
dir="$version/$v"
|
|
|
|
variant="$(basename "$v")"
|
2017-06-15 18:49:20 -04:00
|
|
|
|
2017-08-03 17:07:41 -04:00
|
|
|
if [ "$variant" = 'slim' ]; then
|
|
|
|
# convert "slim" into "slim-jessie"
|
|
|
|
# https://github.com/docker-library/ruby/pull/142#issuecomment-320012893
|
|
|
|
variant="$variant-$(basename "$(dirname "$v")")"
|
|
|
|
fi
|
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
[ -f "$dir/Dockerfile" ] || continue
|
2016-06-09 13:41:31 -04:00
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
commit="$(dirCommit "$dir")"
|
2016-06-09 13:41:31 -04:00
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
versionDockerfile="$dir/Dockerfile"
|
|
|
|
if [ "$variant" = 'onbuild' ]; then
|
|
|
|
versionDockerfile="$(dirname "$dir")/Dockerfile"
|
|
|
|
fi
|
|
|
|
fullVersion="$(git show "$commit":"$versionDockerfile" | awk '$1 == "ENV" && $2 == "RUBY_VERSION" { print $3; exit }')"
|
2016-06-09 13:41:31 -04:00
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
versionAliases=(
|
|
|
|
$fullVersion
|
|
|
|
$version
|
|
|
|
${aliases[$version]:-}
|
|
|
|
)
|
2016-06-09 13:41:31 -04:00
|
|
|
|
|
|
|
variantAliases=( "${versionAliases[@]/%/-$variant}" )
|
2017-08-03 17:07:41 -04:00
|
|
|
case "$variant" in
|
|
|
|
"$debianSuite")
|
|
|
|
variantAliases+=( "${versionAliases[@]}" )
|
|
|
|
;;
|
|
|
|
*-"$debianSuite")
|
|
|
|
variantAliases+=( "${versionAliases[@]/%/-${variant%-$debianSuite}}" )
|
|
|
|
;;
|
|
|
|
"alpine${alpineVersion}")
|
|
|
|
variantAliases+=( "${versionAliases[@]/%/-alpine}" )
|
|
|
|
;;
|
|
|
|
esac
|
2016-06-09 13:41:31 -04:00
|
|
|
variantAliases=( "${variantAliases[@]//latest-/}" )
|
|
|
|
|
2017-07-31 19:48:09 -04:00
|
|
|
case "$v" in
|
|
|
|
*/onbuild)
|
|
|
|
variantParent="$(awk 'toupper($1) == "FROM" { print $2 }' "$(dirname "$dir")/Dockerfile")"
|
|
|
|
variantArches="${parentRepoToArches[$variantParent]}"
|
|
|
|
;;
|
2017-06-15 18:49:20 -04:00
|
|
|
*)
|
2017-07-31 19:48:09 -04:00
|
|
|
variantParent="$(awk 'toupper($1) == "FROM" { print $2 }' "$dir/Dockerfile")"
|
2017-06-15 18:49:20 -04:00
|
|
|
variantArches="${parentRepoToArches[$variantParent]}"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2014-08-14 14:58:13 -04:00
|
|
|
echo
|
2016-06-09 13:41:31 -04:00
|
|
|
cat <<-EOE
|
|
|
|
Tags: $(join ', ' "${variantAliases[@]}")
|
2017-06-15 18:49:20 -04:00
|
|
|
Architectures: $(join ', ' $variantArches)
|
2016-06-09 13:41:31 -04:00
|
|
|
GitCommit: $commit
|
2017-07-31 19:48:09 -04:00
|
|
|
Directory: $dir
|
2016-06-09 13:41:31 -04:00
|
|
|
EOE
|
2014-08-14 14:58:13 -04:00
|
|
|
done
|
|
|
|
done
|