]> git.wh0rd.org Git - home.git/blob - .bin/vcs-url
vcs-url: add gcc support
[home.git] / .bin / vcs-url
1 #!/bin/bash
2
3 err() { 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}"
53         echo "https://sources.gentoo.org/${cvsroot}/${file}${urirev}"
54 }
55 cvs_url() {
56         local f
57         for f in "$@" ; do
58                 _cvs_url "${f}"
59         done
60 }
61
62 git_url() {
63         [[ $# -gt 1 ]] && err "accepted args: <rev>"
64
65         local repo url
66         local remote=$(git config remote.origin.url)
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")
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
80                 fi
81         fi
82
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$::')
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="
96                 ;;
97         *://git@git.gentoo.org/*|\
98         *://anongit.gentoo.org/*)
99                 repo=$(echo "${remote}" | sed 's:.*git[.a-z]*.gentoo.org/::')
100                 url="https://gitweb.gentoo.org/${repo}/commit/?id="
101                 ;;
102         git@github.com[:/]*|\
103         *://github.com/*)
104                 repo=$(echo "${remote}" | sed -e 's,^git@github.com[:/],,' -e 's,^https://github.com/,,' -e 's,^git://github.com/,,' -e 's:[.]git$::')
105                 url="https://github.com/${repo}/commit/"
106                 ;;
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                 ;;
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$::')
114                 url="http://git.savannah.gnu.org/cgit/${repo}.git/commit/?h="
115                 ;;
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                 ;;
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/"
123                 ;;
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                 ;;
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                 ;;
132         *.googlesource.com/*)
133                 url="${remote%.git}/+/"
134                 ;;
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                 ;;
139         *://git.qemu.org/*)
140                 repo=$(echo "${remote}" | sed -e 's,^[^/]*//[^/]*/,,' -e 's,[.]git$,,')
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="
146                 ;;
147         *)
148                 echo "Unknown remote: '${remote}'"
149                 exit 1
150                 ;;
151         esac
152
153         git log -n3 ${1:-HEAD} | sed "s,^commit ,${url},"
154 }
155
156 svn_url() {
157         if [[ $# -eq 0 ]] ; then
158                 svn info | \
159                 awk '{
160                         if ($1 == "URL:") {
161                                 URL = "http://sources.gentoo.org/" gensub(/.*svnroot\/([^/]*).*/, "\\1", 1);
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
187 usage() {
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
200 main() {
201         local vcs="auto"
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
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
226         case ${vcs} in
227         cvs) cvs_url "$@";;
228         git) git_url "$@";;
229         svn) svn_url "$@";;
230         esac
231 }
232 main "$@"