]> git.wh0rd.org - home.git/blame - .bin/vcs-url
vcs-url: add gcc support
[home.git] / .bin / vcs-url
CommitLineData
149dcd4d
MF
1#!/bin/bash
2
3err() { echo "error: $*" >&2; exit 1; }
4
5_cvs_url() {
6 [[ $# -gt 1 ]] && err "accepted args: <file>[:rev1[:rev2]]"
7
8 # spec has the form file:rev1[:rev2]
9 # rev2 defaults to rev1-1
10 export IFS=:
11 set -- $1
12 unset IFS
13
14 local file=$1
15 if [[ ! -e ${file} ]] ; then
16 echo "file '${file}' does not exist"
17 return 1
18 fi
19 local dir="."
20 [[ ${file} == */* ]] && dir=${file%/*}
21 file=${file##*/}
22
23 local rev2=$2
24 if [[ -z ${rev2} ]] ; then
25 rev2=$(
26 cd ${dir}
27 export IFS=/
28 set -- $(grep /${file}/ CVS/Entries)
29 unset IFS
30 echo $3
31 )
32 if [[ ${rev2} == "0" ]] ; then
33 # new file
34 rev2="1.1"
35 else
36 # existing file, bump rev automatically
37 rev2="1.$((${rev2#1.}+1))"
38 fi
39 fi
40 local rev2r=${rev2#1.}
41 local rev1=${3:-1.$((rev2r - 1))}
42
43 local cvsroot=$(<${dir}/CVS/Repository)
44 if [[ ${cvsroot} == gentoo-x86* ]] ; then
45 cvsroot=${cvsroot#gentoo-x86}
46 cvsroot=${cvsroot#/}
47 fi
48
49 local urirev
50 [[ ${rev2} == "1.1" || ${rev1} == "${rev2}" ]] \
51 && urirev="?rev=${rev2}" \
52 || urirev="?r1=${rev1}&r2=${rev2}"
225a775d 53 echo "https://sources.gentoo.org/${cvsroot}/${file}${urirev}"
149dcd4d
MF
54}
55cvs_url() {
56 local f
57 for f in "$@" ; do
58 _cvs_url "${f}"
59 done
60}
61
62git_url() {
02b192ca 63 [[ $# -gt 1 ]] && err "accepted args: <rev>"
149dcd4d
MF
64
65 local repo url
66 local remote=$(git config remote.origin.url)
a1826e38
MF
67
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")
b6a56800
MF
74 else
75 # Still try harder.
76 local remotes=$(git config --get-regexp 'remote\..*\.url')
77 if [[ -n ${remotes} ]]; then
78 remote=$(echo "${remotes}" | awk '{print $2; exit}')
79 fi
a1826e38
MF
80 fi
81 fi
82
149dcd4d
MF
83 case ${remote} in
84 *://uclibc.org/*|*://git.uclibc.org/*|\
85 *://busybox.net/*|*://git.busybox.net/*|\
86 *://buildroot.org/*|*://git.buildroot.org/*|\
87 *://buildroot.net/*|*://git.buildroot.net/*)
88 repo=$(echo "${remote}" | sed -e 's,^[^:]*://[^/]*/,,' -e 's:[.]git$::')
621075aa
MF
89 url="https://git."
90 case ${repo} in
91 uclibc) url+="uclibc.org" ;;
92 buildroot) url+="buildroot.org" ;;
93 *) url+="busybox.net" ;;
94 esac
95 url+="/${repo}/commit/?id="
149dcd4d
MF
96 ;;
97 *://git@git.gentoo.org/*|\
98 *://anongit.gentoo.org/*)
99 repo=$(echo "${remote}" | sed 's:.*git[.a-z]*.gentoo.org/::')
225a775d 100 url="https://gitweb.gentoo.org/${repo}/commit/?id="
149dcd4d 101 ;;
a23d5466 102 git@github.com[:/]*|\
149dcd4d 103 *://github.com/*)
a23d5466 104 repo=$(echo "${remote}" | sed -e 's,^git@github.com[:/],,' -e 's,^https://github.com/,,' -e 's,^git://github.com/,,' -e 's:[.]git$::')
149dcd4d
MF
105 url="https://github.com/${repo}/commit/"
106 ;;
a7e8a010
MF
107 git@gitlab.com[:/]*|\
108 *://gitlab.com/*)
109 repo=$(echo "${remote}" | sed -e 's,^git@gitlab.com[:/],,' -e 's,^https://gitlab.com/,,' -e 's,^git://gitlab.com/,,' -e 's:[.]git$::')
110 url="https://gitlab.com/${repo}/commit/"
111 ;;
afcb1683
MF
112 git://git.sv.gnu.org/*|git://git.savannah.gnu.org/*)
113 repo=$(echo "${remote}" | sed -r -e 's,^git://git.(sv|savannah).gnu.org/,,' -e 's:[.]git$::')
ed2392be
MF
114 url="http://git.savannah.gnu.org/cgit/${repo}.git/commit/?h="
115 ;;
b5612fc0
MF
116 git://git.sv.nongnu.org/*|git://git.savannah.nongnu.org/*)
117 repo=$(echo "${remote}" | sed -r -e 's,^git://git.(sv|savannah).nongnu.org/,,' -e 's:[.]git$::')
118 url="http://git.savannah.nongnu.org/cgit/${repo}.git/commit/?h="
119 ;;
97f084d1
MF
120 git://git.code.sf.net/p/*|ssh://*@git.code.sf.net/p/*)
121 repo=$(echo "${remote}" | sed -r -e 's,(git://|ssh://([^@]*@)?)git.code.sf.net/p/([^/]*)/.*,\3,')
122 url="https://sourceforge.net/p/${repo}/code/ci/"
225a775d 123 ;;
50ad3abc
MF
124 *://sourceware.org/*)
125 repo=$(echo "${remote}" | sed -e 's,.*/,,' -e 's,[.]git$,,')
126 url="https://sourceware.org/git/?p=${repo}.git;a=commit;h="
127 ;;
dd6b7ff9
MF
128 *://gcc.gnu.org/*)
129 repo=$(echo "${remote}" | sed -e 's,.*/,,' -e 's,[.]git$,,')
130 url="https://gcc.gnu.org/git/?p=${repo}.git;a=commit;h="
131 ;;
50ad3abc
MF
132 *.googlesource.com/*)
133 url="${remote%.git}/+/"
134 ;;
a23d5466
MF
135 *://git.enlightenment.org/*)
136 repo=$(echo "${remote}" | sed -e 's,^[^/]*//[^/]*/,,' -e 's,[.]git$,,')
137 url="https://git.enlightenment.org/${repo}.git/commit/?id="
138 ;;
afcb1683
MF
139 *://git.qemu.org/*)
140 repo=$(echo "${remote}" | sed -e 's,^[^/]*//[^/]*/,,' -e 's,[.]git$,,')
b5612fc0
MF
141 url="https://git.qemu.org/?p=${repo}.git;a=commit;h="
142 ;;
143 *://git.kernel.org/*)
144 repo=$(echo "${remote}" | sed -e 's,^[^/]*//[^/]*/,,' -e 's,[.]git$,,')
145 url="https://git.kernel.org/${repo}.git/commit/?id="
afcb1683 146 ;;
149dcd4d 147 *)
b6a56800 148 echo "Unknown remote: '${remote}'"
149dcd4d
MF
149 exit 1
150 ;;
151 esac
152
153 git log -n3 ${1:-HEAD} | sed "s,^commit ,${url},"
154}
155
156svn_url() {
157 if [[ $# -eq 0 ]] ; then
158 svn info | \
159 awk '{
160 if ($1 == "URL:") {
9430565d 161 URL = "http://sources.gentoo.org/" gensub(/.*svnroot\/([^/]*).*/, "\\1", 1);
149dcd4d
MF
162 } else if ($1 == "Revision:") {
163 rev = $2
164 URL = URL "?rev=" (rev + 1) "&view=rev"
165 }
166 }
167 END { print URL }'
168 return 0
169 fi
170
171 local f
172 for f in "$@" ; do
173 svn info "${f}" | \
174 awk '{
175 if ($1 == "URL:") {
176 sub(/.*svnroot/,"")
177 URL = "http://sources.gentoo.org" $1 "?"
178 } else if ($1 == "Revision:") {
179 rev = $2
180 URL = URL "r1=" rev "&r2=" (rev + 1)
181 }
182 }
183 END { print URL }'
184 done
185}
186
187usage() {
188 exec cat <<-EOF
189 Usage: $0 [options] [args]
190
191 Options:
192 -c CVS URL
193 -g GIT URL (default)
194 -s SVN URL
195 -x Trace the script
196 -h Help
197 EOF
198}
199
200main() {
afcb1683 201 local vcs="auto"
149dcd4d
MF
202 while [[ $# -gt 0 ]] ; do
203 case $1 in
204 -c) vcs="cvs";;
205 -s) vcs="svn";;
206 -g) vcs="git";;
207 -x) set -x;;
208 -h) usage;;
209 --) shift; break;;
210 -*) usage;;
211 *) break;;
212 esac
213 shift
214 done
215
afcb1683
MF
216 if [[ ${vcs} == "auto" ]] ; then
217 if [[ -d CVS ]] ; then
218 vcs="cvs"
219 elif svn info >&/dev/null ; then
220 vcs="svn"
221 else
222 vcs="git"
223 fi
224 fi
225
149dcd4d
MF
226 case ${vcs} in
227 cvs) cvs_url "$@";;
228 git) git_url "$@";;
229 svn) svn_url "$@";;
230 esac
231}
232main "$@"