-
Notifications
You must be signed in to change notification settings - Fork 227
/
Copy pathgsl-libs.sh
148 lines (119 loc) · 3.41 KB
/
gsl-libs.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
#!/bin/bash
set -Eeuo pipefail
: "${dockerfile:=Dockerfile}"
: "${variantAppendOrder:=postfix}" # "postfix" or "prefix" ("tianon/foo:1.2.3-bar" vs "tianon/foo:bar-1.2.3")
declare -a extraCommitFiles
# 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"
local files
files="$(git show HEAD:"./$dockerfile" | awk '
toupper($1) == "COPY" {
for (i = 2; i < NF; i++) {
if ($i ~ /^--from=/) {
next
}
print $i
}
}
')"
fileCommit "$dockerfile" $files "${extraCommitFiles[@]}"
)
}
# prints "$2$1$3$1...$N"
join() {
local sep="$1"; shift
local out; printf -v out "${sep//%/%%}%s" "$@"
echo "${out#$sep}"
}
globalEntry() {
cat <<-EOH
Maintainers: Tianon Gravi <tianon@tianon.xyz> (@tianon)
GitRepo: https://github.com/${2:-tianon}/${1:-dockerfiles}.git
EOH
}
tagsEntry() {
local dir="$1"; shift
local tags=( "$@" )
local commit; commit="$(dirCommit "$dir")"
cat <<-EOE
Tags: $(join ', ' "${tags[@]}")
GitCommit: $commit
EOE
if [ "$dir" != '.' ]; then
echo "Directory: $dir"
fi
if [ "$dockerfile" != 'Dockerfile' ]; then
echo "File: $dockerfile"
fi
}
_versionAliasesHelper() {
local fullVersion="$1"; shift
# replace "~" with "-"
local tilde='~'
fullVersion="${fullVersion//$tilde/-}"
# remove any leading "v"
fullVersion="${fullVersion#v}"
versionAliases=()
while [ "${fullVersion%[.-]*}" != "$fullVersion" ]; do
versionAliases+=( "$fullVersion" )
fullVersion="${fullVersion%[.-]*}"
done
versionAliases+=( "$fullVersion" )
}
versionedTagsEntry() {
local dir="$1"; shift
local fullVersion="$1"; shift
local aliases=( "$@" )
_versionAliasesHelper "$fullVersion"
versionAliases+=( "${aliases[@]}" )
tagsEntry "$dir" "${versionAliases[@]}"
}
_versionEnvHelper() {
local dir="$1"; shift
local fullVersionEnv="$1"; shift
local commit="$(dirCommit "$dir")"
local fullVersion="$(git -C "$dir" show "$commit":"./$dockerfile" | awk '$1 == "ENV" && $2 == "'"$fullVersionEnv"'" { print $3; exit }')"
[ -n "$fullVersion" ]
echo "$fullVersion"
}
versionedEnvTagsEntry() {
local dir="$1"; shift
local fullVersionEnv="$1"; shift
local aliases=( "$@" )
local fullVersion; fullVersion="$(_versionEnvHelper "$dir" "$fullVersionEnv")"
[ -n "$fullVersion" ]
versionedTagsEntry "$dir" "$fullVersion" "${aliases[@]}"
}
# for variants whose version number comes from the variant Dockerfile (openjdk:alpine)
versionedVariantEntry() {
local dir="$1"; shift
local variant="$1"; shift
local fullVersion="$1"; shift
local aliases=( "$@" )
_versionAliasesHelper "$fullVersion"
if [ "$variantAppendOrder" = 'postfix' ]; then
variantAliases=( "${versionAliases[@]/%/-$variant}" )
else
variantAliases=( "${versionAliases[@]/#/$variant-}" )
fi
#variantAliases=( "${variantAliases[@]//latest-/}" )
variantAliases+=( "${aliases[@]}" )
tagsEntry "$dir" "${variantAliases[@]}"
}
# for variants whose version number comes from the variant Dockerfile (openjdk:alpine)
versionedEnvVariantEntry() {
local dir="$1"; shift
local variant="$1"; shift
local fullVersionEnv="$1"; shift
local aliases=( "$@" )
local fullVersion; fullVersion="$(_versionEnvHelper "$dir" "$fullVersionEnv")"
[ -n "$fullVersion" ]
versionedVariantEntry "$dir" "$variant" "$fullVersion" "${aliases[@]}"
}