generated from actions/container-action
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtimegroup.sh
executable file
·42 lines (40 loc) · 1.26 KB
/
timegroup.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
#!/bin/sh
# Author: Erik Martin-Dorel, 2020
endGroup() {
# This function unsets the env var 'startTime'.
{ init_opts="$-"; set +x; } 2>/dev/null
# local endTime
if [ -n "$startTime" ]; then
# endTime=$(TZ=UTC+0 printf '%(%s)T\n' '-1') # not POSIX
endTime=$(date -u +%s)
echo "::endgroup::"
# TZ=UTC-0 printf '↳ %(%-Hh %-Mm %-Ss)T\n' "$((endTime - startTime))" # not POSIX
printf "↳ "; date -u -d "@$((endTime - startTime))" '+%-Hh %-Mm %-Ss'; echo
# Assume the time difference < 24h
unset startTime
else
echo 'Error: missing startGroup command.'
case "$init_opts" in *x*) set -x; esac
return 1
fi
case "$init_opts" in *x*) set -x; esac
}
startGroup() {
# This function sets the env var 'startTime'.
{ init_opts="$-"; set +x; } 2>/dev/null
# Nesting groups is not supported; call 'endGroup' if need be.
if [ -n "$startTime" ]; then
endGroup
fi
# local groupTitle
if [ $# -ge 1 ]; then
groupTitle="$*"
else
groupTitle="Unnamed group"
fi
echo
echo "::group::$groupTitle"
# startTime=$(TZ=UTC-0 printf '%(%s)T\n' '-1') # not POSIX
startTime=$(date -u +%s)
case "$init_opts" in *x*) set -x; esac
}