2020-12-15 14:40:49 +01:00
|
|
|
# Copyright 2020 Martine S. Lenders <m.lenders@fu-berlin.sh>
|
|
|
|
#
|
|
|
|
# This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
# General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
# directory for more details.
|
|
|
|
|
|
|
|
LOG=cat
|
|
|
|
LOGFILE=
|
|
|
|
OUTFILE=github_annotate_outfile.log
|
|
|
|
ECHO_ESC=echo
|
|
|
|
|
|
|
|
if ps -p $$ | grep -q '\<bash\>'; then
|
|
|
|
# workaround when included in bash to escape newlines and carriage returns
|
|
|
|
# properly in _escape
|
|
|
|
ECHO_ESC='echo -e'
|
|
|
|
fi
|
|
|
|
|
|
|
|
github_annotate_setup() {
|
|
|
|
if [ -n "${GITHUB_RUN_ID}" ]; then
|
|
|
|
LOGFILE=run-${GITHUB_RUN_ID}.log
|
|
|
|
LOG="tee -a ${LOGFILE}"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
github_annotate_is_on() {
|
|
|
|
test -n "${LOGFILE}"
|
|
|
|
return $?
|
|
|
|
}
|
|
|
|
|
|
|
|
_escape() {
|
|
|
|
# see https://stackoverflow.com/a/1252191/11921757
|
|
|
|
${ECHO_ESC} "$1" | sed -e ':a' -e 'N' -e '$!ba' \
|
|
|
|
-e 's/%/%25/g' -e 's/\r/%0D/g' -e 's/\n/%0A/g'
|
|
|
|
}
|
|
|
|
|
2020-12-17 15:57:19 +01:00
|
|
|
_github_annotate() {
|
|
|
|
MESSAGE="$(_escape "${1}")"
|
|
|
|
LEVEL="${2:-error}"
|
|
|
|
OPTS="${3:-}"
|
|
|
|
echo "::${LEVEL} ${OPTS}::${DETAILS}" >> ${OUTFILE}
|
|
|
|
}
|
|
|
|
|
2020-12-15 14:40:49 +01:00
|
|
|
github_annotate_error() {
|
|
|
|
if [ -n "${GITHUB_RUN_ID}" ]; then
|
|
|
|
FILENAME="${1}"
|
|
|
|
LINENUM="${2}"
|
2020-12-17 15:57:19 +01:00
|
|
|
DETAILS="${3}"
|
|
|
|
_github_annotate "${DETAILS}" error "file=${FILENAME},line=${LINENUM}"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
github_annotate_error_no_file() {
|
|
|
|
if [ -n "${GITHUB_RUN_ID}" ]; then
|
|
|
|
DETAILS="${1}"
|
|
|
|
_github_annotate "${DETAILS}" error
|
2020-12-15 14:40:49 +01:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
github_annotate_warning() {
|
|
|
|
if [ -n "${GITHUB_RUN_ID}" ]; then
|
|
|
|
FILENAME="${1}"
|
|
|
|
LINENUM="${2}"
|
|
|
|
DETAILS="$(_escape "${3}")"
|
2020-12-17 15:57:19 +01:00
|
|
|
_github_annotate "${DETAILS}" warning "file=${FILENAME},line=${LINENUM}"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
github_annotate_warning_no_file() {
|
|
|
|
if [ -n "${GITHUB_RUN_ID}" ]; then
|
|
|
|
DETAILS="${1}"
|
|
|
|
_github_annotate "${DETAILS}" warning
|
2020-12-15 14:40:49 +01:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
github_annotate_parse_log_default() {
|
|
|
|
ANNOTATE_FUNC="${1:-github_annotate_error}"
|
|
|
|
|
|
|
|
if github_annotate_is_on; then
|
|
|
|
PATTERN='^.\+:[0-9]\+:'
|
|
|
|
|
|
|
|
grep "${PATTERN}" "${LOGFILE}" | while read line; do
|
|
|
|
FILENAME=$(echo "${line}" | cut -d: -f1)
|
|
|
|
LINENUM=$(echo "${line}" | cut -d: -f2)
|
|
|
|
DETAILS=$(echo "${line}" | cut -d: -f3- |
|
|
|
|
sed -e 's/^[ \t]*//' -e 's/[ \t]*$//')
|
|
|
|
${ANNOTATE_FUNC} "${FILENAME}" "${LINENUM}" "${DETAILS}"
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
github_annotate_teardown() {
|
|
|
|
if [ -n "${LOGFILE}" ]; then
|
|
|
|
rm -f ${LOGFILE}
|
|
|
|
LOGFILE=
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
github_annotate_report_last_run() {
|
|
|
|
if [ -n "${GITHUB_RUN_ID}" -a -f "${OUTFILE}" ]; then
|
|
|
|
# de-duplicate errors
|
|
|
|
sort -u ${OUTFILE} >&2
|
|
|
|
fi
|
|
|
|
rm -f ${OUTFILE}
|
|
|
|
}
|