2014-08-20 17:50:02 -06:00
|
|
|
#!/bin/bash
|
2016-06-09 11:56:08 -07:00
|
|
|
set -eu
|
2014-08-20 17:50:02 -06:00
|
|
|
|
2017-10-11 16:36:32 -07:00
|
|
|
defaultDebianSuite='stretch'
|
2017-10-11 15:44:38 -07:00
|
|
|
declare -A debianSuite=(
|
|
|
|
[5.6]='jessie'
|
|
|
|
[7.0]='jessie'
|
|
|
|
[7.1]='jessie'
|
|
|
|
)
|
2017-12-09 19:47:51 -08:00
|
|
|
defaultAlpineVersion='3.7'
|
2017-10-11 15:44:38 -07:00
|
|
|
declare -A alpineVersion=(
|
|
|
|
[5.6]='3.4'
|
|
|
|
[7.0]='3.4'
|
|
|
|
[7.1]='3.4'
|
2017-12-09 19:47:51 -08:00
|
|
|
[7.2]='3.6'
|
2017-10-11 15:44:38 -07:00
|
|
|
)
|
|
|
|
|
2016-06-09 10:34:11 -07:00
|
|
|
declare -A aliases=(
|
2015-12-02 22:43:41 +08:00
|
|
|
[5.6]='5'
|
2017-11-30 12:18:43 -08:00
|
|
|
[7.2]='7 latest'
|
|
|
|
[7.3-rc]='rc'
|
2014-08-20 17:50:02 -06:00
|
|
|
)
|
|
|
|
|
2016-06-09 11:56:08 -07:00
|
|
|
self="$(basename "$BASH_SOURCE")"
|
2014-08-20 17:50:02 -06:00
|
|
|
cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
|
|
|
|
|
|
|
|
versions=( */ )
|
|
|
|
versions=( "${versions[@]%/}" )
|
|
|
|
|
2016-06-09 11:56:08 -07:00
|
|
|
# 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
|
|
|
|
}
|
|
|
|
}
|
|
|
|
')
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-06-16 15:05:37 -07:00
|
|
|
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 'php'
|
|
|
|
|
2016-06-09 11:56:08 -07:00
|
|
|
cat <<-EOH
|
|
|
|
# this file is generated via https://github.com/docker-library/php/blob/$(fileCommit "$self")/$self
|
|
|
|
|
|
|
|
Maintainers: Tianon Gravi <admwiggin@gmail.com> (@tianon),
|
|
|
|
Joseph Ferguson <yosifkit@gmail.com> (@yosifkit)
|
|
|
|
GitRepo: https://github.com/docker-library/php.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-20 17:50:02 -06:00
|
|
|
|
|
|
|
for version in "${versions[@]}"; do
|
2016-06-09 11:56:08 -07:00
|
|
|
|
|
|
|
versionAliases=(
|
|
|
|
$version
|
|
|
|
${aliases[$version]:-}
|
|
|
|
)
|
|
|
|
|
2017-10-11 15:44:38 -07:00
|
|
|
# order here controls the order of the library/ file
|
|
|
|
for suite in \
|
2017-10-11 16:36:32 -07:00
|
|
|
stretch \
|
2017-10-11 15:44:38 -07:00
|
|
|
jessie \
|
2017-12-09 19:47:51 -08:00
|
|
|
alpine{3.7,3.6,3.4} \
|
2016-03-18 14:37:47 -07:00
|
|
|
; do
|
2017-10-11 15:44:38 -07:00
|
|
|
for variant in \
|
|
|
|
cli \
|
|
|
|
apache \
|
|
|
|
fpm \
|
|
|
|
zts \
|
|
|
|
; do
|
|
|
|
dir="$version/$suite/$variant"
|
|
|
|
[ -f "$dir/Dockerfile" ] || continue
|
|
|
|
|
|
|
|
commit="$(dirCommit "$dir")"
|
|
|
|
versionSuite="${debianSuite[$version]:-$defaultDebianSuite}"
|
|
|
|
fullVersion="$(git show "$commit":"$dir/Dockerfile" | awk '$1 == "ENV" && $2 == "PHP_VERSION" { print $3; exit }')"
|
|
|
|
|
|
|
|
baseAliases=( $fullVersion "${versionAliases[@]}" )
|
|
|
|
variantAliases=( "${baseAliases[@]/%/-$variant}" )
|
|
|
|
variantAliases=( "${variantAliases[@]//latest-/}" )
|
|
|
|
|
|
|
|
if [ "$variant" = 'cli' ]; then
|
|
|
|
variantAliases+=( "${baseAliases[@]}" )
|
|
|
|
fi
|
2017-10-11 16:36:32 -07:00
|
|
|
|
|
|
|
suiteVariantAliases=( "${variantAliases[@]/%/-$suite}" )
|
|
|
|
if [ "${suite#alpine}" = "${alpineVersion[$version]:-$defaultAlpineVersion}" ] ; then
|
|
|
|
variantAliases=( "${variantAliases[@]/%/-alpine}" )
|
|
|
|
elif [ "$suite" != "$versionSuite" ]; then
|
|
|
|
variantAliases=()
|
2017-10-11 15:44:38 -07:00
|
|
|
fi
|
2017-12-12 17:55:00 -08:00
|
|
|
variantAliases=( "${suiteVariantAliases[@]}" ${variantAliases[@]+"${variantAliases[@]}"} )
|
2017-10-11 16:06:34 -07:00
|
|
|
variantAliases=( "${variantAliases[@]//latest-/}" )
|
2017-10-11 15:44:38 -07:00
|
|
|
|
|
|
|
variantParent="$(awk 'toupper($1) == "FROM" { print $2 }' "$dir/Dockerfile")"
|
|
|
|
variantArches="${parentRepoToArches[$variantParent]}"
|
|
|
|
|
|
|
|
# 7.2 no longer supports s390x
|
2017-11-30 14:26:03 -08:00
|
|
|
# #error "Not yet implemented"
|
|
|
|
# https://github.com/docker-library/php/pull/487#issue-254755661
|
2017-10-11 15:44:38 -07:00
|
|
|
if [[ "$version" = 7.* ]] && [ "$version" != '7.0' ] && [ "$version" != '7.1' ]; then
|
|
|
|
variantArches="$(echo " $variantArches " | sed -r -e 's/ s390x//g')"
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo
|
|
|
|
cat <<-EOE
|
|
|
|
Tags: $(join ', ' "${variantAliases[@]}")
|
|
|
|
Architectures: $(join ', ' $variantArches)
|
|
|
|
GitCommit: $commit
|
|
|
|
Directory: $dir
|
|
|
|
EOE
|
|
|
|
done
|
2014-08-20 17:50:02 -06:00
|
|
|
done
|
|
|
|
done
|