[libcamera-devel] [PATCH v2] utils: hooks: Add pre-push commit hook

Niklas Söderlund niklas.soderlund at ragnatech.se
Wed Apr 15 00:02:30 CEST 2020


Hi Laurent,

Thanks for your work.

On 2020-03-26 15:48:21 +0200, Laurent Pinchart wrote:
> Add a pre-push commit hooks to prevent unintentional push of patches
> containing local changelogs to the master branch.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

Finally found to test this patch, nice work it will relive some anxiety 
when I try to improve my workflow by writing more changelogs.

Reviewed-by: Niklas Söderlund <niklas.soderlund at ragnatech.se>

> ---
> Changes since v1:
> 
> - Fix shellcheck issues
> - Rewrite the description in the top comment
> - Remove dead or useless code
> ---
>  utils/hooks/pre-push | 43 +++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 43 insertions(+)
>  create mode 100755 utils/hooks/pre-push
> 
> diff --git a/utils/hooks/pre-push b/utils/hooks/pre-push
> new file mode 100755
> index 000000000000..099441b82ea6
> --- /dev/null
> +++ b/utils/hooks/pre-push
> @@ -0,0 +1,43 @@
> +#!/bin/sh
> +
> +# A hook script to prevent pushing unsuitable commits to the master branch.
> +# Unsuitable commits are commits that contain a local changelog below a '---'
> +# line. The criteria may get extended later.
> +#
> +# Information about the commits which are being pushed is supplied as lines to
> +# the standard input in the form:
> +#
> +#   <local ref> <local sha1> <remote ref> <remote sha1>
> +
> +z40=0000000000000000000000000000000000000000
> +
> +while read -r local_ref local_sha remote_ref remote_sha
> +do
> +	if [ "$remote_ref" != refs/heads/master ]
> +	then
> +		continue
> +	fi
> +
> +	# The remote master branch should never get deleted by this push, so we
> +	# can assume that local_sha is not 0's. We may however be creating the
> +	# remote branch, when pushing to a new empty repository for instance.
> +	if [ "$remote_sha" = $z40 ]
> +	then
> +		# New branch, examine all commits
> +		range="$local_sha"
> +	else
> +		# Update to existing branch, examine new commits
> +		range="$remote_sha..$local_sha"
> +	fi
> +
> +	# Find invalid commits.
> +	commit=$(git rev-list -n 1 --grep '^---' "$range")
> +	if [ -n "$commit" ]
> +	then
> +		echo >&2 "Found local changelog in $local_ref, not pushing"
> +		echo >&2 "Check commit $commit"
> +		exit 1
> +	fi
> +done
> +
> +exit 0
> -- 
> Regards,
> 
> Laurent Pinchart
> 
> _______________________________________________
> libcamera-devel mailing list
> libcamera-devel at lists.libcamera.org
> https://lists.libcamera.org/listinfo/libcamera-devel

-- 
Regards,
Niklas Söderlund


More information about the libcamera-devel mailing list