3 err() { echo "error: $*" >&2; exit 1; }
6 [[ $# -gt 1 ]] && err "accepted args: <file>[:rev1[:rev2]]"
8 # spec has the form file:rev1[:rev2]
9 # rev2 defaults to rev1-1
15 if [[ ! -e ${file} ]] ; then
16 echo "file '${file}' does not exist"
20 [[ ${file} == */* ]] && dir=${file%/*}
24 if [[ -z ${rev2} ]] ; then
28 set -- $(grep /${file}/ CVS/Entries)
32 if [[ ${rev2} == "0" ]] ; then
36 # existing file, bump rev automatically
37 rev2="1.$((${rev2#1.}+1))"
40 local rev2r=${rev2#1.}
41 local rev1=${3:-1.$((rev2r - 1))}
43 local cvsroot=$(<${dir}/CVS/Repository)
44 if [[ ${cvsroot} == gentoo-x86* ]] ; then
45 cvsroot=${cvsroot#gentoo-x86}
50 [[ ${rev2} == "1.1" || ${rev1} == "${rev2}" ]] \
51 && urirev="?rev=${rev2}" \
52 || urirev="?r1=${rev1}&r2=${rev2}"
53 echo "https://sources.gentoo.org/${cvsroot}/${file}${urirev}"
63 [[ $# -gt 1 ]] && err "accepted args: <rev>"
66 local remote=$(git config remote.origin.url)
68 if [[ -z ${remote} ]] ; then
69 # Maybe the repo doesn't use "origin". Try harder.
70 local branch=$(git rev-parse --abbrev-ref HEAD)
71 remote=$(git config "branch.${branch}.remote")
72 if [[ -n ${remote} ]] ; then
73 remote=$(git config "remote.${remote}.url")
78 *://uclibc.org/*|*://git.uclibc.org/*|\
79 *://busybox.net/*|*://git.busybox.net/*|\
80 *://buildroot.org/*|*://git.buildroot.org/*|\
81 *://buildroot.net/*|*://git.buildroot.net/*)
82 repo=$(echo "${remote}" | sed -e 's,^[^:]*://[^/]*/,,' -e 's:[.]git$::')
85 uclibc) url+="uclibc.org" ;;
86 buildroot) url+="buildroot.org" ;;
87 *) url+="busybox.net" ;;
89 url+="/${repo}/commit/?id="
91 *://git@git.gentoo.org/*|\
92 *://anongit.gentoo.org/*)
93 repo=$(echo "${remote}" | sed 's:.*git[.a-z]*.gentoo.org/::')
94 url="https://gitweb.gentoo.org/${repo}/commit/?id="
98 repo=$(echo "${remote}" | sed -e 's,^git@github.com[:/],,' -e 's,^https://github.com/,,' -e 's,^git://github.com/,,' -e 's:[.]git$::')
99 url="https://github.com/${repo}/commit/"
101 git@gitlab.com[:/]*|\
103 repo=$(echo "${remote}" | sed -e 's,^git@gitlab.com[:/],,' -e 's,^https://gitlab.com/,,' -e 's,^git://gitlab.com/,,' -e 's:[.]git$::')
104 url="https://gitlab.com/${repo}/commit/"
106 git://git.sv.gnu.org/*|git://git.savannah.gnu.org/*)
107 repo=$(echo "${remote}" | sed -r -e 's,^git://git.(sv|savannah).gnu.org/,,' -e 's:[.]git$::')
108 url="http://git.savannah.gnu.org/cgit/${repo}.git/commit/?h="
110 git://git.sv.nongnu.org/*|git://git.savannah.nongnu.org/*)
111 repo=$(echo "${remote}" | sed -r -e 's,^git://git.(sv|savannah).nongnu.org/,,' -e 's:[.]git$::')
112 url="http://git.savannah.nongnu.org/cgit/${repo}.git/commit/?h="
114 git://git.code.sf.net/p/*|ssh://*@git.code.sf.net/p/*)
115 repo=$(echo "${remote}" | sed -r -e 's,(git://|ssh://([^@]*@)?)git.code.sf.net/p/([^/]*)/.*,\3,')
116 url="https://sourceforge.net/p/${repo}/code/ci/"
118 *://sourceware.org/*)
119 repo=$(echo "${remote}" | sed -e 's,.*/,,' -e 's,[.]git$,,')
120 url="https://sourceware.org/git/?p=${repo}.git;a=commit;h="
122 *.googlesource.com/*)
123 url="${remote%.git}/+/"
125 *://git.enlightenment.org/*)
126 repo=$(echo "${remote}" | sed -e 's,^[^/]*//[^/]*/,,' -e 's,[.]git$,,')
127 url="https://git.enlightenment.org/${repo}.git/commit/?id="
130 repo=$(echo "${remote}" | sed -e 's,^[^/]*//[^/]*/,,' -e 's,[.]git$,,')
131 url="https://git.qemu.org/?p=${repo}.git;a=commit;h="
133 *://git.kernel.org/*)
134 repo=$(echo "${remote}" | sed -e 's,^[^/]*//[^/]*/,,' -e 's,[.]git$,,')
135 url="https://git.kernel.org/${repo}.git/commit/?id="
138 echo "Unknown remote: ${remote}"
143 git log -n3 ${1:-HEAD} | sed "s,^commit ,${url},"
147 if [[ $# -eq 0 ]] ; then
151 URL = "http://sources.gentoo.org/" gensub(/.*svnroot\/([^/]*).*/, "\\1", 1);
152 } else if ($1 == "Revision:") {
154 URL = URL "?rev=" (rev + 1) "&view=rev"
167 URL = "http://sources.gentoo.org" $1 "?"
168 } else if ($1 == "Revision:") {
170 URL = URL "r1=" rev "&r2=" (rev + 1)
179 Usage: $0 [options] [args]
192 while [[ $# -gt 0 ]] ; do
206 if [[ ${vcs} == "auto" ]] ; then
207 if [[ -d CVS ]] ; then
209 elif svn info >&/dev/null ; then