| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- #!/bin/bash
- set -e
- cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
- repos=( "$@" )
- if [ ${#repos[@]} -eq 0 ]; then
- repos=( */ )
- fi
- repos=( "${repos[@]%/}" )
- replace_field() {
- repo="$1"
- field="$2"
- content="$3"
- extraSed="${4:-}"
- sed_escaped_value="$(echo "$content" | sed 's/[\/&]/\\&/g')"
- sed_escaped_value="${sed_escaped_value//$'\n'/\\n}"
- sed -ri "s/${extraSed}%%${field}%%${extraSed}/$sed_escaped_value/g" "$repo/README.md"
- }
- for repo in "${repos[@]}"; do
- if [ -x "$repo/update.sh" ]; then
- ( set -x; "$repo/update.sh" )
- fi
- case "$repo" in
- perl)
- gitRepo='https://github.com/Perl/docker-perl'
- ;;
- hylang)
- gitRepo='https://github.com/hylang/hy'
- ;;
- clojure)
- gitRepo='https://github.com/Quantisan/docker-clojure'
- ;;
- *)
- gitRepo="https://github.com/docker-library/$repo"
- ;;
- esac
- if [ -e "$repo/content.md" ]; then
- mailingList="$(cat "$repo/mailing-list.md" 2>/dev/null || true)"
- if [ "$mailingList" ]; then
- mailingList=" $mailingList "
- else
- mailingList=' '
- fi
- license="$(cat "$repo/license.md" 2>/dev/null || true)"
- if [ "$license" ]; then
- license=$'\n\n''# License'$'\n\n'"$license"
- fi
-
- cp -v README-template.md "$repo/README.md"
-
- echo ' TAGS => ./generate-dockerfile-links-partial.sh'
- replace_field "$repo" 'TAGS' "$(./generate-dockerfile-links-partial.sh "$repo")"
-
- echo ' CONTENT => '"$repo"'/content.md'
- replace_field "$repo" 'CONTENT' "$(cat "$repo/content.md")"
-
- echo ' LICENSE => '"$repo"'/license.md'
- replace_field "$repo" 'LICENSE' "$license"
-
- echo ' MAILING_LIST => "'"$mailingList"'"'
- replace_field "$repo" 'MAILING_LIST' "$mailingList" '\s*'
-
- echo ' REPO => "'"$gitRepo"'"'
- replace_field "$repo" 'REPO' "$gitRepo"
-
- echo
- else
- echo >&2 "skipping $repo: missing repo/content.md"
- fi
- done
|