/[gentoo-x86]/eclass/subversion.eclass
Gentoo

Contents of /eclass/subversion.eclass

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.34 - (show annotations) (download)
Sun Sep 3 13:01:57 2006 UTC (7 years, 11 months ago) by hattya
Branch: MAIN
Changes since 1.33: +14 -17 lines
fixes bug #143480

1 # Copyright 1999-2006 Gentoo Foundation
2 # Distributed under the terms of the GNU General Public License v2
3 # $Header: /var/cvsroot/gentoo-x86/eclass/subversion.eclass,v 1.33 2006/07/22 13:52:38 hattya Exp $
4
5 ## --------------------------------------------------------------------------- #
6 # Author: Akinori Hattori <hattya@gentoo.org>
7 #
8 # The subversion eclass is written to fetch the software sources from
9 # subversion repositories like the cvs eclass.
10 #
11 #
12 # Description:
13 # If you use this eclass, the ${S} is ${WORKDIR}/${P}.
14 # It is necessary to define the ESVN_REPO_URI variable at least.
15 #
16 ## --------------------------------------------------------------------------- #
17
18 inherit eutils
19
20 ESVN="subversion.eclass"
21
22 EXPORT_FUNCTIONS src_unpack
23
24 HOMEPAGE="http://subversion.tigris.org/"
25 DESCRIPTION="Based on the ${ECLASS} eclass"
26
27
28 ## -- add subversion in DEPEND
29 #
30 DEPEND="dev-util/subversion"
31
32
33 ## -- ESVN_STORE_DIR: subversion sources store directory
34 #
35 ESVN_STORE_DIR="${PORTAGE_ACTUAL_DISTDIR-${DISTDIR}}/svn-src"
36
37
38 ## -- ESVN_FETCH_CMD: subversion fetch command
39 #
40 ESVN_FETCH_CMD="svn checkout"
41
42 ## -- ESVN_UPDATE_CMD: subversion update command
43 #
44 ESVN_UPDATE_CMD="svn update"
45
46
47 ## -- ESVN_OPTIONS:
48 #
49 # the options passed to checkout or update.
50 #
51 : ESVN_OPTIONS=${ESVN_OPTIONS:=}
52
53
54 ## -- ESVN_REPO_URI: repository uri
55 #
56 # e.g. http://foo/trunk, svn://bar/trunk
57 #
58 # supported protocols:
59 # http://
60 # https://
61 # svn://
62 # svn+ssh://
63 #
64 : ESVN_REPO_URI=${ESVN_REPO_URI:=}
65
66
67 ## -- ESVN_PROJECT: project name of your ebuild (= name space)
68 #
69 # subversion eclass will check out the subversion repository like:
70 #
71 # ${ESVN_STORE_DIR}/${ESVN_PROJECT}/${ESVN_REPO_URI##*/}
72 #
73 # so if you define ESVN_REPO_URI as http://svn.collab.net/repo/svn/trunk or
74 # http://svn.collab.net/repo/svn/trunk/. and PN is subversion-svn.
75 # it will check out like:
76 #
77 # ${ESVN_STORE_DIR}/subversion/trunk
78 #
79 # this is not used in order to declare the name of the upstream project.
80 # so that you can declare this like:
81 #
82 # # jakarta commons-loggin
83 # ESVN_PROJECT=commons/logging
84 #
85 # default: ${PN/-svn}.
86 #
87 : ESVN_PROJECT=${ESVN_PROJECT:=${PN/-svn}}
88
89
90 ## -- ESVN_BOOTSTRAP:
91 #
92 # bootstrap script or command like autogen.sh or etc..
93 #
94 : ESVN_BOOTSTRAP=${ESVN_BOOTSTRAP:=}
95
96
97 ## -- ESVN_PATCHES:
98 #
99 # subversion eclass can apply pathces in subversion_bootstrap().
100 # you can use regexp in this valiable like *.diff or *.patch or etc.
101 # NOTE: this patches will apply before eval ESVN_BOOTSTRAP.
102 #
103 # the process of applying the patch is:
104 # 1. just epatch it, if the patch exists in the path.
105 # 2. scan it under FILESDIR and epatch it, if the patch exists in FILESDIR.
106 # 3. die.
107 #
108 : ESVN_PATCHES=${ESVN_PATCHES:=}
109
110
111 ## -- ESVN_RESTRICT:
112 #
113 # this should be a space delimited list of subversion eclass features to restrict.
114 # export)
115 # don't export the working copy to S.
116 #
117 : ESVN_RESTRICT=${ESVN_RESTRICT:=}
118
119
120 ## -- subversion_fetch() ----------------------------------------------------- #
121
122 function subversion_fetch() {
123
124 local repo_uri=${1:-${ESVN_REPO_URI}}
125
126 if [[ -z "${repo_uri}" ]]; then
127 die "${ESVN}: ESVN_REPO_URI is empty."
128 fi
129
130 # delete trailing slash
131 if [[ -z "${repo_uri##*/}" ]]; then
132 repo_uri=${repo_uri%/}
133 fi
134
135 # check for the protocol
136 local protocol=${repo_uri%%:*}
137
138 case "${protocol}" in
139 http|https)
140 if built_with_use dev-util/subversion nowebdav; then
141 echo
142 eerror "In order to emerge this package, you need to"
143 eerror "re-emerge subversion with USE=-nowebdav"
144 echo
145 die "${ESVN}: please run 'USE=-nowebdav emerge subversion'"
146 fi
147 ;;
148 svn|svn+ssh)
149 ;;
150 *)
151 die "${ESVN}: fetch from "${protocol}" is not yet implemented."
152 ;;
153 esac
154
155 if [[ ! -d "${ESVN_STORE_DIR}" ]]; then
156 debug-print "${FUNCNAME}: initial checkout. creating subversion directory"
157
158 mkdir -p "${ESVN_STORE_DIR}" || die "${ESVN}: can't mkdir ${ESVN_STORE_DIR}."
159 fi
160
161 cd "${ESVN_STORE_DIR}" || die "${ESVN}: can't chdir to ${ESVN_STORE_DIR}"
162
163 # every time
164 addread "/etc/subversion"
165
166 ESVN_OPTIONS="${ESVN_OPTIONS} --config-dir ${ESVN_STORE_DIR}/.subversion"
167
168 local wc_path=${ESVN_PROJECT}/${repo_uri##*/}
169
170 debug-print "${FUNCNAME}: ESVN_OPTIONS = \"${ESVN_OPTIONS}\""
171
172 if [[ ! -d "${wc_path}/.svn" ]]; then
173 # first check out
174 einfo "subversion check out start -->"
175 einfo " repository: ${repo_uri}"
176
177 mkdir -p "${ESVN_PROJECT}" || die "${ESVN}: can't mkdir ${ESVN_PROJECT}."
178 cd "${ESVN_PROJECT}"
179 ${ESVN_FETCH_CMD} ${ESVN_OPTIONS} "${repo_uri}" || die "${ESVN}: can't fetch from ${repo_uri}."
180
181 else
182 subversion_wc_info || die "${ESVN}: unknown problem occurred while accessing working copy."
183
184 if [[ "${ESVN_WC_URL}" != "${ESVN_REPO_URI}" ]]; then
185 die "${ESVN}: ESVN_REPO_URI and working copy's URL are not matched."
186 fi
187
188 # update working copy
189 einfo "subversion update start -->"
190 einfo " repository: ${repo_uri}"
191
192 cd "${wc_path}"
193 ${ESVN_UPDATE_CMD} ${ESVN_OPTIONS} || die "${ESVN}: can't update from ${repo_uri}."
194
195 fi
196
197 einfo " working copy: ${ESVN_STORE_DIR}/${wc_path}"
198
199 if ! has "export" ${ESVN_RESTRICT}; then
200 cd "${ESVN_STORE_DIR}/${wc_path}"
201
202 # export to the ${WORKDIR}
203 #* "svn export" has a bug. see http://bugs.gentoo.org/119236
204 #* svn export . "${S}" || die "${ESVN}: can't export to ${S}."
205 rsync -rlpgo --exclude=".svn/" . "${S}" || die "${ESVN}: can't export to ${S}."
206 fi
207
208 echo
209
210 }
211
212
213 ## -- subversion_bootstrap() ------------------------------------------------ #
214
215 function subversion_bootstrap() {
216
217 if has "export" ${ESVN_RESTRICT}; then
218 return
219 fi
220
221 cd "${S}"
222
223 if [[ -n "${ESVN_PATCHES}" ]]; then
224 einfo "apply patches -->"
225
226 local p=
227
228 for p in ${ESVN_PATCHES}; do
229 if [[ -f "${p}" ]]; then
230 epatch "${p}"
231
232 else
233 local q=
234
235 for q in ${FILESDIR}/${p}; do
236 if [[ -f "${q}" ]]; then
237 epatch "${q}"
238
239 else
240 die "${ESVN}; ${p} is not found"
241
242 fi
243 done
244 fi
245 done
246
247 echo
248
249 fi
250
251 if [[ -n "${ESVN_BOOTSTRAP}" ]]; then
252 einfo "begin bootstrap -->"
253
254 if [[ -f "${ESVN_BOOTSTRAP}" && -x "${ESVN_BOOTSTRAP}" ]]; then
255 einfo " bootstrap with a file: ${ESVN_BOOTSTRAP}"
256 eval "./${ESVN_BOOTSTRAP}" || die "${ESVN}: can't execute ESVN_BOOTSTRAP."
257
258 else
259 einfo " bootstrap with commands: ${ESVN_BOOTSTRAP}"
260 eval "${ESVN_BOOTSTRAP}" || die "${ESVN}: can't eval ESVN_BOOTSTRAP."
261
262 fi
263 fi
264
265 }
266
267
268 ## -- subversion_src_unpack() ------------------------------------------------ #
269
270 function subversion_src_unpack() {
271
272 subversion_fetch || die "${ESVN}: unknown problem occurred in subversion_fetch."
273 subversion_bootstrap || die "${ESVN}: unknown problem occurred in subversion_bootstrap."
274
275 }
276
277
278 ## -- subversion_wc_info() --------------------------------------------------- #
279
280 function subversion_wc_info() {
281
282 local repo_uri=${ESVN_REPO_URI}
283
284 # delete trailing slash
285 if [[ -z "${repo_uri##*/}" ]]; then
286 repo_uri="${repo_uri%/}"
287 fi
288
289 local wc_path=${ESVN_STORE_DIR}/${ESVN_PROJECT}/${repo_uri##*/}
290
291 if [[ ! -e "${wc_path}" ]]; then
292 return 1
293 fi
294
295 local k=
296
297 for k in url revision; do
298 export ESVN_WC_$(echo "${k}" | tr [a-z] [A-Z])=$(env LANG=C svn info "${wc_path}" | grep -i "^${k}" | cut -d" " -f2)
299 done
300
301 }

  ViewVC Help
Powered by ViewVC 1.1.20