summaryrefslogtreecommitdiff
path: root/plugins/git-commit
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/git-commit')
-rw-r--r--plugins/git-commit/README.md15
-rw-r--r--plugins/git-commit/git-commit.plugin.zsh47
2 files changed, 47 insertions, 15 deletions
diff --git a/plugins/git-commit/README.md b/plugins/git-commit/README.md
index 91cc73b44..f812ee23f 100644
--- a/plugins/git-commit/README.md
+++ b/plugins/git-commit/README.md
@@ -1,6 +1,8 @@
# git-commit plugin
-The git-commit plugin adds several [git aliases](https://www.git-scm.com/docs/git-config#Documentation/git-config.txt-alias) for [conventional commit](https://www.conventionalcommits.org/en/v1.0.0/#summary) messages.
+The git-commit plugin adds several
+[git aliases](https://www.git-scm.com/docs/git-config#Documentation/git-config.txt-alias) for
+[conventional commit](https://www.conventionalcommits.org/en/v1.0.0/#summary) messages.
To use it, add `git-commit` to the plugins array in your zshrc file:
@@ -11,11 +13,9 @@ plugins=(... git-commit)
## Syntax
```zsh
-git <type> [(-s, --scope) "<scope>"] "<message>"
+git <type> [(-s, --scope) "<scope>"] [(-a, --attention)] "<message>"
```
-> ⚠️ Single/Double quotes around the scope and message are required
-
Where `type` is one of the following:
- `build`
@@ -29,14 +29,19 @@ Where `type` is one of the following:
- `rev`
- `style`
- `test`
+- `wip`
-> NOTE: the alias for `revert` type is `rev`, as otherwise it conflicts with the git command of the same name.
+> NOTE: the alias for `revert` type is `rev`, as otherwise it conflicts with the git command of the same name.
> It will still generate a commit message in the format `revert: <message>`
+> ⚠️ Enabling this plugin will (potentially) overwrite all `alias.<type>` that you manually set. Use with
+> care!
+
## Examples
| Git alias | Command |
| --------------------------------------------- | ---------------------------------------------------- |
| `git style "remove trailing whitespace"` | `git commit -m "style: remove trailing whitespace"` |
+| `git wip "work in progress"` | `git commit -m "work in progress"` |
| `git fix -s "router" "correct redirect link"` | `git commit -m "fix(router): correct redirect link"` |
| `git rev -s "api" "rollback v2"` | `git commit -m "revert(api): rollback v2"` |
diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh
index 72cecb1d6..c4df77c80 100644
--- a/plugins/git-commit/git-commit.plugin.zsh
+++ b/plugins/git-commit/git-commit.plugin.zsh
@@ -1,3 +1,9 @@
+local _rev="$(git -C $ZSH rev-parse HEAD 2> /dev/null)"
+if [[ $_rev == $(git config --global --get oh-my-zsh.git-commit-alias 2> /dev/null) ]]; then
+ return
+fi
+git config --global oh-my-zsh.git-commit-alias "$_rev"
+
local -a _git_commit_aliases
_git_commit_aliases=(
'build'
@@ -11,21 +17,42 @@ _git_commit_aliases=(
'revert'
'style'
'test'
+ 'wip'
)
-local alias type
-for type in "${_git_commit_aliases[@]}"; do
+local _alias _type
+for _type in "${_git_commit_aliases[@]}"; do
# an alias can't be named "revert" because the git command takes precedence
# https://stackoverflow.com/a/3538791
- case "$type" in
- revert) alias=rev ;;
- *) alias=$type ;;
+ case "$_type" in
+ revert) _alias=rev ;;
+ *) _alias=$_type ;;
esac
- local func='!a() { if [ "$1" = "-s" ] || [ "$1" = "--scope" ]; then local scope="$2"; shift 2; git commit -m "'$type'(${scope}): ${@}"; else git commit -m "'$type': ${@}"; fi }; a'
- if ! git config --global --get-all alias.${alias} >/dev/null 2>&1; then
- git config --global alias.${alias} "$func"
- fi
+ local _func='!a() {
+local _scope _attention _message
+while [ $# -ne 0 ]; do
+case $1 in
+ -s | --scope )
+ if [ -z $2 ]; then
+ echo "Missing scope!"
+ return 1
+ fi
+ _scope="$2"
+ shift 2
+ ;;
+ -a | --attention )
+ _attention="!"
+ shift 1
+ ;;
+ * )
+ _message="${_message} $1"
+ shift 1
+ ;;
+esac
done
+git commit -m "'$_type'${_scope:+(${_scope})}${_attention}:${_message}"
+}; a'
-unset _git_commit_aliases alias type func
+ git config --global alias.$_alias "$_func"
+done