Skip to content

Commit 48ad4b7

Browse files
committed
Add explicit multiarch support in "generate-stackbrew-library.sh"
1 parent c5693b2 commit 48ad4b7

File tree

1 file changed

+29
-0
lines changed

1 file changed

+29
-0
lines changed

generate-stackbrew-library.sh

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -33,6 +33,22 @@ dirCommit() {
3333
)
3434
}
3535

36+
getArches() {
37+
local repo="$1"; shift
38+
local officialImagesUrl='https://github.com/docker-library/official-images/raw/master/library/'
39+
40+
eval "declare -A -g parentRepoToArches=( $(
41+
find -name 'Dockerfile' -exec awk '
42+
toupper($1) == "FROM" && $2 !~ /^('"$repo"'|scratch|microsoft\/[^:]+)(:|$)/ {
43+
print "'"$officialImagesUrl"'" $2
44+
}
45+
' '{}' + \
46+
| sort -u \
47+
| xargs bashbrew cat --format '[{{ .RepoName }}:{{ .TagName }}]="{{ join " " .TagEntry.Architectures }}"'
48+
) )"
49+
}
50+
getArches 'ruby'
51+
3652
cat <<-EOH
3753
# this file is generated via https://github.com/docker-library/ruby/blob/$(fileCommit "$self")/$self
3854
@@ -51,6 +67,9 @@ join() {
5167
for version in "${versions[@]}"; do
5268
commit="$(dirCommit "$version")"
5369

70+
parent="$(awk 'toupper($1) == "FROM" { print $2 }' "$version/Dockerfile")"
71+
arches="${parentRepoToArches[$parent]}"
72+
5473
fullVersion="$(git show "$commit":"$version/Dockerfile" | awk '$1 == "ENV" && $2 == "RUBY_VERSION" { print $3; exit }')"
5574

5675
versionAliases=(
@@ -62,6 +81,7 @@ for version in "${versions[@]}"; do
6281
echo
6382
cat <<-EOE
6483
Tags: $(join ', ' "${versionAliases[@]}")
84+
Architectures: $(join ', ' $arches)
6585
GitCommit: $commit
6686
Directory: $version
6787
EOE
@@ -74,9 +94,18 @@ for version in "${versions[@]}"; do
7494
variantAliases=( "${versionAliases[@]/%/-$variant}" )
7595
variantAliases=( "${variantAliases[@]//latest-/}" )
7696

97+
case "$variant" in
98+
onbuild) variantArches="$arches" ;;
99+
*)
100+
variantParent="$(awk 'toupper($1) == "FROM" { print $2 }' "$version/$variant/Dockerfile")"
101+
variantArches="${parentRepoToArches[$variantParent]}"
102+
;;
103+
esac
104+
77105
echo
78106
cat <<-EOE
79107
Tags: $(join ', ' "${variantAliases[@]}")
108+
Architectures: $(join ', ' $variantArches)
80109
GitCommit: $commit
81110
Directory: $version/$variant
82111
EOE

0 commit comments

Comments
 (0)