Commit | Line | Data |
---|---|---|
2ea4288a | 1 | #!/bin/bash |
2385300a | 2 | # Desc: Template to report seconds until beginning of next day |
2ea4288a SBS |
3 | |
4 | #==BEGIN Define script parameters== | |
5 | #===BEGIN Declare local script functions=== | |
5ef33b04 SBS |
6 | yell() { echo "$0: $*" >&2; } # Yell, Die, Try Three-Fingered Claw technique; # Ref/Attrib: https://stackoverflow.com/a/25515370 |
7 | die() { yell "$*"; exit 111; } | |
8 | try() { "$@" || die "cannot $*"; } | |
2385300a SBS |
9 | timeUntilNextDay(){ |
10 | # Desc: Report seconds until next day. | |
ccf85e7b | 11 | # Version: 1.0.1 |
2385300a | 12 | # Output: stdout: integer seconds until next day |
5ef33b04 | 13 | # Output: exit code 0 if stdout > 0; 1 if stdout = 0; 2 if stdout < 0 |
2385300a SBS |
14 | # Usage: timeUntilNextDay |
15 | # Usage: if ! myTTL="$(timeUntilNextDay)"; then yell "ERROR in if statement"; exit 1; fi | |
96716339 SBS |
16 | # Depends: date 8, echo 8, yell, try |
17 | ||
ccf85e7b | 18 | local returnState timeCurrent timeNextDay secondsUntilNextDay |
96716339 | 19 | |
ccf85e7b SBS |
20 | timeCurrent="$(date --iso-8601=seconds)" ; # Produce `date`-parsable current timestamp with resolution of 1 second. |
21 | timeNextDay="$(date -d "$timeCurrent next day" --iso-8601=date)"; # Produce timestamp of beginning of tomorrow with resolution of 1 second. | |
22 | secondsUntilNextDay="$(( $(date +%s -d "$timeNextDay") - $(date +%s -d "$timeCurrent") ))" ; # Calculate seconds until closest future midnight (res. 1 second). | |
23 | if [[ "$secondsUntilNextDay" -gt 0 ]]; then | |
5ef33b04 | 24 | returnState="true"; |
ccf85e7b | 25 | elif [[ "$secondsUntilNextDay" -eq 0 ]]; then |
96716339 | 26 | returnState="warning_zero"; |
2385300a | 27 | yell "WARNING:Reported time until next day exactly zero."; |
ccf85e7b | 28 | elif [[ "$secondsUntilNextDay" -lt 0 ]]; then |
96716339 | 29 | returnState="warning_negative"; |
2385300a | 30 | yell "WARNING:Reported time until next day is negative."; |
5ef33b04 SBS |
31 | fi |
32 | ||
ccf85e7b | 33 | try echo "$secondsUntilNextDay"; # Report |
5ef33b04 | 34 | |
96716339 | 35 | # Determine function return code |
5ef33b04 SBS |
36 | if [[ "$returnState" = "true" ]]; then |
37 | return 0; | |
96716339 | 38 | elif [[ "$returnState" = "warning_zero" ]]; then |
5ef33b04 | 39 | return 1; |
96716339 | 40 | elif [[ "$returnState" = "warning_negative" ]]; then |
5ef33b04 SBS |
41 | return 2; |
42 | fi | |
df807a6c | 43 | } # Report seconds until next day |
2ea4288a SBS |
44 | #===END Declare local script functions=== |
45 | #==END Define script parameters== | |
46 | ||
47 | ||
48 | #==BEGIN sample code== | |
2385300a | 49 | try echo "Time until next day (seconds):$(timeUntilNextDay)" # simple report |
5ef33b04 | 50 | |
2385300a | 51 | if ! myTTL="$(timeUntilNextDay)"; then yell "ERROR in if statement for myTTL:$myTTL"; exit 1; fi # Use of exit code to exit early if time <= 0. |
2ea4288a | 52 | #==END sample code== |
96716339 SBS |
53 | |
54 | # Author: Steven Baltaktei Sandoval | |
55 | # License: GPLv3+ |