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. | |
0f6236dd | 11 | # Version: 1.0.3 |
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 | ||
0f6236dd | 18 | local returnState timeCurrent timeNextDay secondsUntilNextDay |
ccf85e7b SBS |
19 | timeCurrent="$(date --iso-8601=seconds)" ; # Produce `date`-parsable current timestamp with resolution of 1 second. |
20 | timeNextDay="$(date -d "$timeCurrent next day" --iso-8601=date)"; # Produce timestamp of beginning of tomorrow with resolution of 1 second. | |
21 | secondsUntilNextDay="$(( $(date +%s -d "$timeNextDay") - $(date +%s -d "$timeCurrent") ))" ; # Calculate seconds until closest future midnight (res. 1 second). | |
22 | if [[ "$secondsUntilNextDay" -gt 0 ]]; then | |
5ef33b04 | 23 | returnState="true"; |
ccf85e7b | 24 | elif [[ "$secondsUntilNextDay" -eq 0 ]]; then |
96716339 | 25 | returnState="warning_zero"; |
2385300a | 26 | yell "WARNING:Reported time until next day exactly zero."; |
ccf85e7b | 27 | elif [[ "$secondsUntilNextDay" -lt 0 ]]; then |
96716339 | 28 | returnState="warning_negative"; |
2385300a | 29 | yell "WARNING:Reported time until next day is negative."; |
5ef33b04 SBS |
30 | fi |
31 | ||
ccf85e7b | 32 | try echo "$secondsUntilNextDay"; # Report |
5ef33b04 | 33 | |
96716339 | 34 | # Determine function return code |
5ef33b04 SBS |
35 | if [[ "$returnState" = "true" ]]; then |
36 | return 0; | |
96716339 | 37 | elif [[ "$returnState" = "warning_zero" ]]; then |
5ef33b04 | 38 | return 1; |
96716339 | 39 | elif [[ "$returnState" = "warning_negative" ]]; then |
5ef33b04 SBS |
40 | return 2; |
41 | fi | |
df807a6c | 42 | } # Report seconds until next day |
2ea4288a SBS |
43 | #===END Declare local script functions=== |
44 | #==END Define script parameters== | |
45 | ||
46 | ||
47 | #==BEGIN sample code== | |
2385300a | 48 | try echo "Time until next day (seconds):$(timeUntilNextDay)" # simple report |
5ef33b04 | 49 | |
2385300a | 50 | 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 | 51 | #==END sample code== |
96716339 SBS |
52 | |
53 | # Author: Steven Baltaktei Sandoval | |
54 | # License: GPLv3+ |