Blame gen_chlog.sh

Packit 13e616
#!/bin/sh
Packit 13e616
Packit 13e616
usage()
Packit 13e616
{
Packit 13e616
	echo "Usage: $0 [--spec]"
Packit 13e616
	exit 2
Packit 13e616
}
Packit 13e616
Packit 13e616
if [ "$1" = "--spec" ] ; then
Packit 13e616
	spec_format=1
Packit 13e616
fi
Packit 13e616
Packit 13e616
GIT_DIR=`git rev-parse --git-dir 2>/dev/null`
Packit 13e616
Packit 13e616
test -z "$GIT_DIR" && usage
Packit 13e616
Packit 13e616
Packit 13e616
export GIT_DIR
Packit 13e616
export GIT_PAGER=""
Packit 13e616
export PAGER=""
Packit 13e616
Packit 13e616
Packit 13e616
mkchlog()
Packit 13e616
{
Packit 13e616
	format=$1
Packit 13e616
Packit 13e616
	prev_tag=""
Packit 13e616
Packit 13e616
	for tag in `git tag -l '*' | sort -V` ; do
Packit 13e616
		obj=`git describe $tag`
Packit 13e616
		base=`git merge-base $obj HEAD`
Packit 13e616
		if [ -z "$base" -o "$base" != $obj ] ; then
Packit 13e616
			continue
Packit 13e616
		fi
Packit 13e616
		all_vers="$prev_tag$tag $all_vers"
Packit 13e616
		prev_tag=$tag..
Packit 13e616
	done
Packit 13e616
Packit 13e616
	if [ -z "$prev_tag" ] ; then
Packit 13e616
		all_vers=HEAD
Packit 13e616
	else
Packit 13e616
		all_vers="${prev_tag}HEAD $all_vers"
Packit 13e616
	fi
Packit 13e616
Packit 13e616
	for ver in $all_vers ; do
Packit 13e616
		log_out=`git log $ver -- ./`
Packit 13e616
		if [ -z "$log_out" ] ; then
Packit 13e616
			continue
Packit 13e616
		fi
Packit 13e616
		ver_name=`echo $ver | sed -e 's/^.*\.\.//'`
Packit 13e616
		echo ""
Packit 13e616
		echo "** Version: $ver_name"
Packit 13e616
		echo ""
Packit 13e616
		git log --no-merges "${format}" $ver -- ./
Packit 13e616
		prev_t=$tag..
Packit 13e616
	done
Packit 13e616
}
Packit 13e616
Packit 13e616
Packit 13e616
if [ -z "$spec_format" ] ; then
Packit 13e616
	mkchlog --pretty=format:"%ad %an%n%H%n%n* %s%n" \
Packit 13e616
		| sed -e 's/^\* /\t* /'
Packit 13e616
else
Packit 13e616
	echo "%changelog"
Packit 13e616
	mkchlog --pretty=format:"- %ad %an: %s"
Packit 13e616
	echo ""
Packit 13e616
fi