zsh: more enhancements to todo()
This commit is contained in:
parent
b942b31f2a
commit
c9b000765e
1 changed files with 9 additions and 7 deletions
16
.zshrc
16
.zshrc
|
@ -171,22 +171,24 @@
|
|||
todo() {
|
||||
( # subshell to protect against directory changes
|
||||
todo_dir="$(dirname "$(realpath ~/todo)")"
|
||||
todo_file="$(realpath ~/todo)"
|
||||
if [ -z "$@" ];then
|
||||
cd "$(dirname "$(realpath ~/todo)")"
|
||||
cd "$todo_dir"
|
||||
|
||||
# pull the latest commits
|
||||
git rev-parse &&
|
||||
git pull
|
||||
|
||||
"$EDITOR" ~/todo
|
||||
# open the file
|
||||
"$EDITOR" "$todo_file"
|
||||
|
||||
# commit and push the file if it's in a git repo
|
||||
git rev-parse &&
|
||||
git commit "$(realpath ~/todo)" -m 'todo' &&
|
||||
# commit and push the file if it's in a git repo and the file has changed
|
||||
if git rev-parse && ! git diff --exit-code "$todo_file"; then
|
||||
git commit "$todo_file" -m 'todo' &&
|
||||
git push
|
||||
fi
|
||||
else
|
||||
cd "$todo_dir"
|
||||
git $@
|
||||
git -C "$todo_dir" $@
|
||||
fi
|
||||
)
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue