mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-24 21:26:24 +02:00 
			
		
		
		
	Merge branch 'develop-olympus' into develop
* develop-olympus: [ticket/10093] Use correct ANSI code for clearing color. [ticket/10093] Make commit-msg always not fatal by nuking all fatal logic. [ticket/10093] Use color in commit-msg hook warning/error messages. [ticket/10093] Refactor complaining in commit-msg hook for color support. [ticket/10093] Respect phpbb.hooks.commit-msg.fatal on syntax errors. [ticket/10093] Document phpbb.hooks.commit-msg.fatal setting.
This commit is contained in:
		| @@ -11,16 +11,16 @@ | |||||||
| # | # | ||||||
| # ln -s ../../git-tools/hooks/commit-msg \\ | # ln -s ../../git-tools/hooks/commit-msg \\ | ||||||
| #   .git/hooks/commit-msg | #   .git/hooks/commit-msg | ||||||
|  | # | ||||||
|  | # Warning/error messages use color by default if the output is a terminal | ||||||
|  | # ("output" here is normally standard error when you run git commit). | ||||||
|  | # To force or disable the use of color: | ||||||
|  | # | ||||||
|  | # git config phpbb.hooks.commit-msg.color true	(force color output) | ||||||
|  | # git config phpbb.hooks.commit-msg.color false (disable color output) | ||||||
|  |  | ||||||
| config_ns="phpbb.hooks.commit-msg"; | config_ns="phpbb.hooks.commit-msg"; | ||||||
|  |  | ||||||
| if [ "$(git config --bool $config_ns.fatal)" = "false" ] |  | ||||||
| then |  | ||||||
| 	fatal=0; |  | ||||||
| else |  | ||||||
| 	fatal=1; |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| debug_level=$(git config --int $config_ns.debug || echo 0); | debug_level=$(git config --int $config_ns.debug || echo 0); | ||||||
|  |  | ||||||
| # Error codes | # Error codes | ||||||
| @@ -47,11 +47,55 @@ debug() | |||||||
|  |  | ||||||
| quit() | quit() | ||||||
| { | { | ||||||
| 	if [ $1 -gt 0 ] && [ $1 -ne $ERR_UNKNOWN ] && [ $fatal -eq 0 ] | 	# Now we always exit with success, since git will trash | ||||||
|  | 	# entered commit message if commit-msg hook exits with a failure. | ||||||
|  | 	exit 0 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | use_color() | ||||||
|  | { | ||||||
|  | 	if [ -z "$use_color_cached" ] | ||||||
| 	then | 	then | ||||||
| 		exit 0; | 		case $(git config --bool $config_ns.color) | ||||||
|  | 		in | ||||||
|  | 		false) | ||||||
|  | 			use_color_cached=1 | ||||||
|  | 			;; | ||||||
|  | 		true) | ||||||
|  | 			use_color_cached=0 | ||||||
|  | 			;; | ||||||
|  | 		*) | ||||||
|  | 			# tty detection in shell: | ||||||
|  | 			# http://hwi.ath.cx/jsh/list/shext/isatty.sh.html | ||||||
|  | 			tty 0>/dev/stdout >/dev/null 2>&1 | ||||||
|  | 			use_color_cached=$? | ||||||
|  | 			;; | ||||||
|  | 		esac | ||||||
|  | 	fi | ||||||
|  | 	# return value is the flag inverted - | ||||||
|  | 	# if return value is 0, this means use color | ||||||
|  | 	return $use_color_cached | ||||||
|  | } | ||||||
|  |  | ||||||
|  | complain() | ||||||
|  | { | ||||||
|  | 	if use_color | ||||||
|  | 	then | ||||||
|  | 		# Careful: our argument may include arguments to echo like -n | ||||||
|  | 		# ANSI color codes: | ||||||
|  | 		# http://pueblo.sourceforge.net/doc/manual/ansi_color_codes.html | ||||||
|  | 		printf "\033[31m\033[1m" | ||||||
|  | 		if [ "$1" = "-n" ] | ||||||
|  | 		then | ||||||
|  | 			echo "$@" | ||||||
|  | 			printf "\033[0m" | ||||||
|  | 		else | ||||||
|  | 			# This will print one trailing space. | ||||||
|  | 			# Not sure how to avoid this at the moment. | ||||||
|  | 			echo "$@" $(printf "\033[0m") | ||||||
|  | 		fi | ||||||
| 	else | 	else | ||||||
| 		exit $1; | 		echo "$@" | ||||||
| 	fi | 	fi | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -70,9 +114,9 @@ msg=$(grep -v '^#' "$1" |grep -nE '.{81,}') | |||||||
|  |  | ||||||
| if [ $? -eq 0 ] | if [ $? -eq 0 ] | ||||||
| then | then | ||||||
| 	echo "The following lines are greater than 80 characters long:" >&2; | 	complain "The following lines are greater than 80 characters long:" >&2; | ||||||
| 	echo >&2 | 	complain >&2 | ||||||
| 	echo "$msg" >&2; | 	complain "$msg" >&2; | ||||||
|  |  | ||||||
| 	quit $ERR_LENGTH; | 	quit $ERR_LENGTH; | ||||||
| fi | fi | ||||||
| @@ -126,9 +170,9 @@ do | |||||||
| 					# Don't be too strict. | 					# Don't be too strict. | ||||||
| 					# Commits may be temporary, intended to be squashed later. | 					# Commits may be temporary, intended to be squashed later. | ||||||
| 					# Just issue a warning here. | 					# Just issue a warning here. | ||||||
| 					echo "Warning: heading should be a sentence beginning with a capital letter." 1>&2 | 					complain "Warning: heading should be a sentence beginning with a capital letter." 1>&2 | ||||||
| 					echo "You entered:" 1>&2 | 					complain "You entered:" 1>&2 | ||||||
| 					echo "$line" 1>&2 | 					complain "$line" 1>&2 | ||||||
| 				fi | 				fi | ||||||
| 				# restore exit code | 				# restore exit code | ||||||
| 				(exit $result) | 				(exit $result) | ||||||
| @@ -160,7 +204,7 @@ do | |||||||
| 				echo "$line" | grep -Eq "^#"; | 				echo "$line" | grep -Eq "^#"; | ||||||
| 			;; | 			;; | ||||||
| 			*) | 			*) | ||||||
| 				echo "Unrecognised token $expect" >&2; | 				complain "Unrecognised token $expect" >&2; | ||||||
| 				quit $err; | 				quit $err; | ||||||
| 			;; | 			;; | ||||||
| 		esac | 		esac | ||||||
| @@ -231,7 +275,7 @@ do | |||||||
| 				expecting="eof"; | 				expecting="eof"; | ||||||
| 			;; | 			;; | ||||||
| 			*) | 			*) | ||||||
| 				echo "Unrecognised token $expect" >&2; | 				complain "Unrecognised token $expect" >&2; | ||||||
| 				quit 254; | 				quit 254; | ||||||
| 			;; | 			;; | ||||||
| 		esac | 		esac | ||||||
| @@ -245,11 +289,11 @@ do | |||||||
| 	else | 	else | ||||||
| 		# None of the expected line formats matched | 		# None of the expected line formats matched | ||||||
| 		# Guess we'll call it a day here then | 		# Guess we'll call it a day here then | ||||||
| 		echo "Syntax error on line $i:" >&2; | 		complain "Syntax error on line $i:" >&2; | ||||||
| 		echo ">> $line" >&2; | 		complain ">> $line" >&2; | ||||||
| 		echo -n "Expecting: " >&2; | 		complain -n "Expecting: " >&2; | ||||||
| 		echo "$expecting" | sed 's/ /, /g' >&2; | 		complain "$expecting" | sed 's/ /, /g' >&2; | ||||||
| 		exit $err; | 		quit $err; | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| 	i=$(( $i + 1 )); | 	i=$(( $i + 1 )); | ||||||
| @@ -258,7 +302,7 @@ done | |||||||
| # If EOF is expected exit cleanly | # If EOF is expected exit cleanly | ||||||
| echo "$expecting" | grep -q "eof" || ( | echo "$expecting" | grep -q "eof" || ( | ||||||
| 	# Unexpected EOF, error | 	# Unexpected EOF, error | ||||||
| 	echo "Unexpected EOF encountered" >&2; | 	complain "Unexpected EOF encountered" >&2; | ||||||
| 	quit $ERR_EOF; | 	quit $ERR_EOF; | ||||||
| ) && ( | ) && ( | ||||||
| 	# Do post scan checks | 	# Do post scan checks | ||||||
| @@ -269,8 +313,8 @@ echo "$expecting" | grep -q "eof" || ( | |||||||
|  |  | ||||||
| 		if [ ! -z "$dupes" ] | 		if [ ! -z "$dupes" ] | ||||||
| 		then | 		then | ||||||
| 			echo "The following tickets are repeated:" >&2; | 			complain "The following tickets are repeated:" >&2; | ||||||
| 			echo "$dupes" | sed 's/ /\n/g;s/^/* /g' >&2; | 			complain "$dupes" | sed 's/ /\n/g;s/^/* /g' >&2; | ||||||
| 			quit $ERR_FOOTER; | 			quit $ERR_FOOTER; | ||||||
| 		fi | 		fi | ||||||
| 	fi | 	fi | ||||||
| @@ -278,8 +322,8 @@ echo "$expecting" | grep -q "eof" || ( | |||||||
| 	if [ $ticket -gt 0 ] | 	if [ $ticket -gt 0 ] | ||||||
| 	then | 	then | ||||||
| 		echo "$tickets" | grep -Eq "\bPHPBB3-$ticket\b" || ( | 		echo "$tickets" | grep -Eq "\bPHPBB3-$ticket\b" || ( | ||||||
| 			echo "Ticket ID [$ticket] of branch missing from list of tickets:" >&2; | 			complain "Ticket ID [$ticket] of branch missing from list of tickets:" >&2; | ||||||
| 			echo "$tickets" | sed 's/ /\n/g;s/^/* /g' >&2; | 			complain "$tickets" | sed 's/ /\n/g;s/^/* /g' >&2; | ||||||
| 			quit $ERR_FOOTER; | 			quit $ERR_FOOTER; | ||||||
| 		) || exit $?; | 		) || exit $?; | ||||||
| 	fi | 	fi | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user