side_menu_doc/bin/changelog-generator

162 lines
3.6 KiB
Plaintext
Raw Normal View History

2023-02-15 17:53:48 +01:00
#!/bin/sh
usage() {
2024-01-23 23:46:17 +01:00
printf "Usage: %s [-l DEBUG_LEVEL] [-h] [-f /path/to/CHANGELOG.md] [-u https://example.com/CHANGELOG.md]\n" "$0"
2023-02-15 17:53:48 +01:00
}
help() {
cat << EOH
SYNOPSIS
2024-01-23 23:46:17 +01:00
$0 [-l DEBUG_LEVEL] [-h] [-f /path/to/CHANGELOG.md] [-u https://example.com/CHANGELOG.md]
2023-02-15 17:53:48 +01:00
DESCRIPTION
$0 generates a markdown content of a changelog file.
OPTIONS
-h Show this help
-f FILE
2023-05-25 13:49:27 +02:00
Path to changelog
2024-01-23 23:46:17 +01:00
-u URL
URL of the changelog
2023-05-25 13:49:27 +02:00
-l debug|info|notice|warning|error
Debug level
2023-02-15 17:53:48 +01:00
EOH
}
on_interrupt() {
2023-05-25 13:49:27 +02:00
print "Process aborted!\n"
2023-02-15 17:53:48 +01:00
2023-05-25 13:49:27 +02:00
exit 130
2023-02-15 17:53:48 +01:00
}
main() {
CHANGELOG_FILE="${CHANGELOG_FILE:-}"
CHANGELOG_URL="${CHANGELOG_URL:-}"
LOG_VERBOSE="${CHANGELOG_FILE:-info}"
while getopts "l:hf:u:" option; do
2023-05-25 13:49:27 +02:00
case "${option}" in
h) help; exit 0;;
f) CHANGELOG_FILE="$OPTARG";;
u) CHANGELOG_URL="$OPTARG";;
2023-05-25 13:49:27 +02:00
l) LOG_VERBOSE="$OPTARG";;
?) log -l error "$(usage)"; exit 1;;
esac
done
temp_directory="$(mktemp -d)"
2023-05-25 13:49:27 +02:00
version=
is_first=1
if [ -n "$CHANGELOG_FILE" ]; then
if [ ! -f "$CHANGELOG_FILE" ]; then
log -l error "No such file: $CHANGELOG_FILE"
else
log -l info "File used: $CHANGELOG_FILE"
fi
elif [ -n "$CHANGELOG_URL" ]; then
log -l debug "URL used: $CHANGELOG_URL"
CHANGELOG_FILE="$temp_directory/_changelog"
curl -sS -o "$CHANGELOG_FILE" "$CHANGELOG_URL" || exit 0
else
log -l error "You must define a file or an url"
exit 1
fi
2023-05-25 13:49:27 +02:00
cat << EOF
2023-02-15 17:53:48 +01:00
---
2024-01-23 23:46:17 +01:00
sidebar_position: 7
2023-02-15 17:53:48 +01:00
---
2023-02-15 19:05:30 +01:00
# Changelog
2023-02-15 19:04:45 +01:00
2023-02-15 17:53:48 +01:00
EOF
2023-05-25 13:49:27 +02:00
while read -r line; do
if printf "%s" "$line" | grep -q -E '^## '; then
version="$(printf "%s" "$line" | sed 's/^## //')"
if [ "$version" = "[Unreleased]" ]; then
version=""
fi
elif [ -n "$version" ]; then
printf "%s\n" "$line" >> "$temp_directory/$version"
fi
done < "$CHANGELOG_FILE"
while read -r line; do
if printf "%s" "$line" | grep -q -E '^## '; then
version="$(printf "%s" "$line" | sed 's/^## //')"
if [ "$version" != "[Unreleased]" ]; then
log -l info "Version detected: $version"
2024-01-23 23:46:17 +01:00
printf "## %s\n" "$version"
2023-05-25 13:49:27 +02:00
sed \
2024-01-23 23:46:17 +01:00
-e 's/### \(.*\)/\n**\1**\n/g' \
2023-05-25 13:49:27 +02:00
"$temp_directory/$version"
fi
fi
done < "$CHANGELOG_FILE"
exit 0
}
2023-02-15 17:53:48 +01:00
2023-05-25 13:49:27 +02:00
log() {
LOG_VERBOSE="${LOG_VERBOSE:-info}"
LEVEL=info
TIME=
while getopts "tl:" option; do
case "${option}" in
l) LEVEL="$OPTARG"; shift $((OPTIND-1));;
t) TIME="$(printf "[%s] " "$(date +'%Y-%m-%dT%H:%M:%S.%s')")"; shift $((OPTIND-1));;
*) exit 1;;
esac
done
if [ -t 2 ] && [ -z "${NO_COLOR-}" ]; then
case "${LEVEL}" in
debug) COLOR="$(tput setaf 3)";;
notice) COLOR="$(tput setaf 4)";;
warning) COLOR="$(tput setaf 5)";;
error) COLOR="$(tput setaf 1)";;
*) COLOR="$(tput sgr0)";;
esac
fi
case "${LEVEL}" in
debug) LEVEL=100;;
notice) LEVEL=250;;
warning) LEVEL=300;;
error) LEVEL=400;;
*) LEVEL=200;;
esac
case "${LOG_VERBOSE}" in
debug) LOG_VERBOSE_VALUE=100;;
notice) LOG_VERBOSE_VALUE=250;;
warning) LOG_VERBOSE_VALUE=300;;
error) LOG_VERBOSE_VALUE=400;;
*) LOG_VERBOSE_VALUE=200;;
esac
if [ $LEVEL -ge $LOG_VERBOSE_VALUE ]; then
printf "%s\n" "$*" | while IFS='' read -r LINE; do
printf "%s%s%s%s\n" "${COLOR:-}" "${TIME:-}" "$LINE" "$(tput init)" >&2
2023-05-25 13:49:27 +02:00
done
fi
2023-02-15 17:53:48 +01:00
}
trap on_interrupt INT
main "$@"