hook global BufCreate .*(COMMIT_EDITMSG|MERGE_MSG) %{
    set buffer filetype git-commit
}

hook -group git-commit-highlight global WinSetOption filetype=git-commit %{
    add-highlighter group git-commit-highlight
    add-highlighter -group git-commit-highlight regex "^\h*#[^\n]*\n" 0:cyan,default
    add-highlighter -group git-commit-highlight regex "\b(?:(modified)|(deleted)|(new file)|(renamed|copied)):([^\n]*)\n" 1:yellow 2:red 3:green 4:blue 5:magenta
    add-highlighter -group git-commit-highlight ref diff # highlight potential diffs from the -v option
}

hook -group git-commit-highlight global WinSetOption filetype=(?!git-commit).* %{ remove-highlighter git-commit-highlight }

hook global BufCreate .*git-rebase-todo %{
    set buffer filetype git-rebase
}

hook -group git-rebase-highlight global WinSetOption filetype=git-rebase %{
    add-highlighter group git-rebase-highlight
    add-highlighter -group git-rebase-highlight regex "#[^\n]*\n" 0:cyan,default
    add-highlighter -group git-rebase-highlight regex "^(pick|edit|reword|squash|fixup|exec|[persfx]) (\w+)" 1:green 2:magenta
}

hook -group git-rebase-highlight global WinSetOption filetype=(?!git-rebase).* %{ remove-highlighter git-rebase-highlight }