#!/usr/bin/env bash if git rev-parse --verify HEAD >/dev/null 2>&1; then against=HEAD else # Initial commit: diff against an empty tree object against=$(${git}/bin/git hash-object -t tree /dev/null) fi diff="git diff-index --name-only --cached $against --diff-filter d" all_files=($($diff)) # Format staged files. if ((${#all_files[@]} != 0)); then treefmt "${all_files[@]}" && git add "${all_files[@]}" fi # check editorconfig if ((${#all_files[@]} != 0)); then if ! editorconfig-checker -- "${all_files[@]}"; then printf "%b\n" \ "\nCode is not aligned with .editorconfig" \ "Review the output and commit your fixes" >&2 exit 1 fi fi