]>
Commit | Line | Data |
---|---|---|
149dcd4d MF |
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}" | |
225a775d | 53 | echo "https://sources.gentoo.org/${cvsroot}/${file}${urirev}" |
149dcd4d MF |
54 | } |
55 | cvs_url() { | |
56 | local f | |
57 | for f in "$@" ; do | |
58 | _cvs_url "${f}" | |
59 | done | |
60 | } | |
61 | ||
62 | git_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 | ||
156 | svn_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 | ||
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() { | |
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 | } | |
232 | main "$@" |