1#!/bin/sh -e 2# Copyright 2005, Ryan Anderson <ryan@michonline.com> 3# 4# This file is licensed under the GPL v2, or a later version 5# at the discretion of Linus Torvalds. 6 7USAGE='<start> <url> [<end>]' 8LONG_USAGE='Summarizes the changes between two commits to the standard output, 9and includes the given URL in the generated summary.' 10SUBDIRECTORY_OK='Yes' 11OPTIONS_KEEPDASHDASH= 12OPTIONS_SPEC='git request-pull [options] start url [end] 13-- 14p show patch text as well 15' 16 17. git-sh-setup 18. git-parse-remote 19 20GIT_PAGER= 21export GIT_PAGER 22 23patch= 24while case"$#"in0)break;;esac 25do 26case"$1"in 27-p) 28patch=-p;; 29--) 30shift;break;; 31-*) 32 usage ;; 33*) 34break;; 35esac 36shift 37done 38 39base=$1 40url=$2 41head=${3-HEAD} 42 43["$base"] || usage 44["$url"] || usage 45 46baserev=`git rev-parse --verify "$base"^0`&& 47headrev=`git rev-parse --verify "$head"^0`||exit 48 49merge_base=`git merge-base$baserev$headrev`|| 50die "fatal: No commits in common between$baseand$head" 51 52branch=$(git ls-remote"$url" \ 53|sed-n -e"/^$headrevrefs.heads./{ 54 s/^.* refs.heads.// 55 p 56 q 57 }") 58url=$(get_remote_url "$url") 59if[-z"$branch"];then 60echo"warn: No branch of$urlis at:">&2 61 git log --max-count=1--pretty='tformat:warn: %h: %s'$headrev>&2 62echo"warn: Are you sure you pushed$headthere?">&2 63echo>&2 64echo>&2 65 branch=..BRANCH.NOT.VERIFIED.. 66 status=1 67fi 68 69echo"The following changes since commit$baserev:" 70git shortlog --max-count=1$baserev|sed-e's/^\(.\)/ \1/' 71 72echo"are available in the git repository at:" 73echo 74echo"$url$branch" 75echo 76 77git shortlog ^$baserev $headrev 78git diff-M --stat --summary$patch $merge_base..$headrev 79exit$status