aboutsummaryrefslogtreecommitdiffstats
path: root/timelog.sh
diff options
context:
space:
mode:
authorMatthew Lemon <matt@matthewlemon.com>2022-07-10 20:17:32 +0100
committerMatthew Lemon <matt@matthewlemon.com>2022-07-10 20:17:32 +0100
commitc4f3f980fc7f374c3ce31991011f118dbd8487b7 (patch)
treea1265344a881f8160b5f6b176b3cbe76706802f1 /timelog.sh
parente578633a77934fb70bbf0e41e5f21bcc89520e7b (diff)
added a new timelog script for logging time with ledger
Diffstat (limited to 'timelog.sh')
-rwxr-xr-xtimelog.sh75
1 files changed, 75 insertions, 0 deletions
diff --git a/timelog.sh b/timelog.sh
new file mode 100755
index 0000000..e898ef1
--- /dev/null
+++ b/timelog.sh
@@ -0,0 +1,75 @@
+#!/usr/local/bin/bash
+
+# ripping off https://github.com/colindean/hejmo/blob/master/scripts/t
+
+timelog="/home/lemon/Documents/Budget/ledger/2021/timetracking.ledger"
+
+# clock in
+_t_in() {
+ printf "\ni %s %s\n" "$(date '+%Y-%m-%d %H:%M:%S')" "$*" >> "$timelog"
+}
+
+# clock out
+_t_out() {
+ printf "o %s %s\n" "$(date '+%Y-%m-%d %H:%M:%S')" "$*" >> "$timelog"
+}
+
+_t_cur() {
+ sed -e '/^i/!d;$!d' "${timelog}"
+}
+
+_t_bal() {
+ ledger -f "${timelog}" bal
+}
+
+_t_reg() {
+ ledger -f "${timelog}" reg
+}
+
+# this doesn't work in OpenBSD because of the date issue
+# look for another way to calcuate relative dates
+_t_start() {
+ if [[ ! -z "$(_t_cur)" ]]; then
+ echo "Cannot add an entry when one is checked out. Run '$(basename $0) out' to check out first."
+ exit 1
+ fi
+ local start_date="$(date --date "${1}" '+%Y-%m-%d %H:%M:%S')"
+ if [[ -z "${start_date}" ]]; then
+ exit 1 #rely on date to have shown the error
+ fi
+ echo i "${start_date}" "${2}" >> "${timelog}"
+}
+
+# this doesn't work in OpenBSD because of the date issue
+# look for another way to calcuate relative dates
+_t_end() {
+ local end_date
+ if [[ -z "${1}" ]]; then
+ _t_out "${@}"
+ return 0
+ fi
+ end_date="$(date --date "${1}" '+%Y-%m-%d %H:%M:%S')"
+ if [[ -z "${end_date}" ]]; then
+ exit 1 #rely on date to have shown the error
+ fi
+ echo o "${end_date}" >> "${timelog}"
+}
+
+# Explicitly log a start and end
+_t_log() {
+ _t_start "${1}" "${3}"
+ _t_end "${2}"
+}
+
+action=$1; shift
+
+case "$action" in
+ in) _t_in "$@";;
+ out) _t_out "$@";;
+ cur) _t_cur "$@";;
+ bal) _t_bal "$@";;
+ reg) _t_reg "$@";;
+# log) _t_log "$@";;
+esac
+
+exit 0