如何从`commit-msg` git hook中打开终端编辑器

时间:2016-08-19 13:33:50

标签: git bash githooks

我有一个commit-msg挂钩,用于验证提交消息的内容。

如果检查失败,我想重新打开我的终端编辑器的提交消息文件,以便我可以纠正错误。

我有以下内容,当验证失败时会提示用户。

#!/usr/bin/env bash

COMMIT_MSG_FILE="$1"

# If we have a STDIN, use it, otherwise get one
if tty >/dev/null 2>&1; then
  TTY=$(tty)
else
  TTY=/dev/tty
fi

while true; do

  # read lines from file
  COMMIT_MSG_LINES=()
  while IFS= read -r; do
    COMMIT_MSG_LINES+=("$REPLY")
  done < <(cat $COMMIT_MSG_FILE)

  # validate - limit the subject to 50 characters
  test "${#COMMIT_MSG_LINES[0]}" -le 50 && break;

  echo -n "Validation failed. Proceed with commit [y/n]? "
  read REPLY < "$TTY"

  case "$REPLY" in
    Y*|y*) exit 0 ;;
    N*|n*) exit 1 ;;
    *)     $EDITOR $COMMIT_MSG_FILE; continue ;;
  esac

done

YyNn以外的任何回复都应该重新打开编辑器。

但是,我收到了以下错误:

Received SIGHUP or SIGTERM

当我手动调用钩子时,脚本正常工作,所以我认为这与调用钩子的上下文有关。

如何从这样的commit-msg钩子中打开编辑器?

1 个答案:

答案 0 :(得分:0)

解决了它。明确地将TTY重定向到$EDITOR似乎有效。

替换:

$EDITOR $COMMIT_MSG_FILE

使用:

$EDITOR $COMMIT_MSG_FILE < "$TTY"