1
0
Fork 0
mirror of https://github.com/docker-library/ruby.git synced 2022-11-09 11:41:34 -05:00
docker-library--ruby/generate-stackbrew-library.sh
Tianon Gravi bb5c7101e1 Add 2.3/alpine3.8 and 2.6-rc/alpine3.8
Alpine 3.8 for 2.4 and 2.5 need to wait for https://bugs.ruby-lang.org/issues/14754 backports to be released (should be 2.4.5+ and 2.5.2+ respectively).
2018-09-13 10:30:25 -07:00

131 lines
3.5 KiB
Bash
Executable file

#!/usr/bin/env bash
set -Eeuo pipefail
declare -A aliases=(
[2.5]='2 latest'
[2.6-rc]='rc'
)
defaultDebianSuite='stretch'
defaultAlpineVersion='3.8'
declare -A alpineVersion=(
# "openssl_missing.h:196:22: error: static declaration of 'EVP_PKEY_get0_RSA' follows non-static declaration" (and friends)
# https://github.com/docker-library/ruby/issues/228 / https://bugs.ruby-lang.org/issues/14754
[2.4]='3.7' # TODO remove this (and add Alpine 3.8) once 2.4.5+ is released
[2.5]='3.7' # TODO remove this (and add Alpine 3.8) once 2.5.2+ is released
)
self="$(basename "$BASH_SOURCE")"
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
versions=( */ )
versions=( "${versions[@]%/}" )
# sort version numbers with highest first
IFS=$'\n'; versions=( $(echo "${versions[*]}" | sort -rV) ); unset IFS
# 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
}
}
')
)
}
getArches() {
local repo="$1"; shift
local officialImagesUrl='https://github.com/docker-library/official-images/raw/master/library/'
eval "declare -g -A parentRepoToArches=( $(
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'
cat <<-EOH
# this file is generated via https://github.com/docker-library/ruby/blob/$(fileCommit "$self")/$self
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}"
}
for version in "${versions[@]}"; do
for v in \
{stretch,jessie}{,/slim} \
alpine{3.8,3.7,3.6} \
; do
dir="$version/$v"
variant="$(basename "$v")"
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
[ -f "$dir/Dockerfile" ] || continue
commit="$(dirCommit "$dir")"
fullVersion="$(git show "$commit":"$dir/Dockerfile" | awk '$1 == "ENV" && $2 == "RUBY_VERSION" { print $3; exit }')"
versionAliases=(
$fullVersion
$version
${aliases[$version]:-}
)
variantAliases=( "${versionAliases[@]/%/-$variant}" )
case "$variant" in
"$defaultDebianSuite")
variantAliases+=( "${versionAliases[@]}" )
;;
*-"$defaultDebianSuite")
variantAliases+=( "${versionAliases[@]/%/-${variant%-$defaultDebianSuite}}" )
;;
"alpine${alpineVersion[$version]:-$defaultAlpineVersion}")
variantAliases+=( "${versionAliases[@]/%/-alpine}" )
;;
esac
variantAliases=( "${variantAliases[@]//latest-/}" )
variantParent="$(awk 'toupper($1) == "FROM" { print $2 }' "$dir/Dockerfile")"
variantArches="${parentRepoToArches[$variantParent]}"
echo
cat <<-EOE
Tags: $(join ', ' "${variantAliases[@]}")
Architectures: $(join ', ' $variantArches)
GitCommit: $commit
Directory: $dir
EOE
done
done