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

Diff of /eclass/subversion.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.47 Revision 1.82
1# Copyright 1999-2008 Gentoo Foundation 1# Copyright 1999-2012 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/subversion.eclass,v 1.47 2008/02/20 17:55:27 cardoe Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/subversion.eclass,v 1.82 2012/07/29 05:38:42 hattya Exp $
4 4
5# @ECLASS: subversion.eclass 5# @ECLASS: subversion.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Akinori Hattori <hattya@gentoo.org> 7# Akinori Hattori <hattya@gentoo.org>
8# Bo ├śrsted Andresen <zlin@gentoo.org> 8# @AUTHOR:
9#
10# Original Author: Akinori Hattori <hattya@gentoo.org> 9# Original Author: Akinori Hattori <hattya@gentoo.org>
11#
12# @BLURB: The subversion eclass is written to fetch software sources from subversion repositories 10# @BLURB: The subversion eclass is written to fetch software sources from subversion repositories
13# @DESCRIPTION: 11# @DESCRIPTION:
14# The subversion eclass provides functions to fetch, patch and bootstrap 12# The subversion eclass provides functions to fetch, patch and bootstrap
15# software sources from subversion repositories. 13# software sources from subversion repositories.
16#
17# You must define the ESVN_REPO_URI variable before inheriting this eclass.
18 14
19inherit eutils 15inherit eutils
20 16
21ESVN="${ECLASS}" 17ESVN="${ECLASS}"
22 18
19case "${EAPI:-0}" in
20 0|1)
23EXPORT_FUNCTIONS src_unpack 21 EXPORT_FUNCTIONS src_unpack pkg_preinst
24
25DESCRIPTION="Based on the ${ECLASS} eclass"
26
27DEPEND="dev-util/subversion 22 DEPEND="dev-vcs/subversion"
28 net-misc/rsync" 23 ;;
24 *)
25 EXPORT_FUNCTIONS src_unpack src_prepare pkg_preinst
26 DEPEND="|| ( dev-vcs/subversion[webdav-neon] dev-vcs/subversion[webdav-serf] )"
27 ;;
28esac
29
30DEPEND+=" net-misc/rsync"
29 31
30# @ECLASS-VARIABLE: ESVN_STORE_DIR 32# @ECLASS-VARIABLE: ESVN_STORE_DIR
31# @DESCRIPTION: 33# @DESCRIPTION:
32# subversion sources store directory. Users may override this in /etc/make.conf 34# subversion sources store directory. Users may override this in /etc/make.conf
33[[ -z ${ESVN_STORE_DIR} ]] && ESVN_STORE_DIR="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}/svn-src" 35[[ -z ${ESVN_STORE_DIR} ]] && ESVN_STORE_DIR="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}/svn-src"
39 41
40# @ECLASS-VARIABLE: ESVN_UPDATE_CMD 42# @ECLASS-VARIABLE: ESVN_UPDATE_CMD
41# @DESCRIPTION: 43# @DESCRIPTION:
42# subversion update command 44# subversion update command
43ESVN_UPDATE_CMD="svn update" 45ESVN_UPDATE_CMD="svn update"
46
47# @ECLASS-VARIABLE: ESVN_SWITCH_CMD
48# @DESCRIPTION:
49# subversion switch command
50ESVN_SWITCH_CMD="svn switch"
44 51
45# @ECLASS-VARIABLE: ESVN_OPTIONS 52# @ECLASS-VARIABLE: ESVN_OPTIONS
46# @DESCRIPTION: 53# @DESCRIPTION:
47# the options passed to checkout or update. If you want a specific revision see 54# the options passed to checkout or update. If you want a specific revision see
48# ESVN_REPO_URI instead of using -rREV. 55# ESVN_REPO_URI instead of using -rREV.
71# to a specific revision 78# to a specific revision
72# 79#
73# Note: This should never be set in an ebuild! 80# Note: This should never be set in an ebuild!
74ESVN_REVISION="${ESVN_REVISION:-}" 81ESVN_REVISION="${ESVN_REVISION:-}"
75 82
83# @ECLASS-VARIABLE: ESVN_USER
84# @DESCRIPTION:
85# User name
86ESVN_USER="${ESVN_USER:-}"
87
88# @ECLASS-VARIABLE: ESVN_PASSWORD
89# @DESCRIPTION:
90# Password
91ESVN_PASSWORD="${ESVN_PASSWORD:-}"
92
76# @ECLASS-VARIABLE: ESVN_PROJECT 93# @ECLASS-VARIABLE: ESVN_PROJECT
77# @DESCRIPTION: 94# @DESCRIPTION:
78# project name of your ebuild (= name space) 95# project name of your ebuild (= name space)
79# 96#
80# subversion eclass will check out the subversion repository like: 97# subversion eclass will check out the subversion repository like:
116# this should be a space delimited list of subversion eclass features to 133# this should be a space delimited list of subversion eclass features to
117# restrict. 134# restrict.
118# export) 135# export)
119# don't export the working copy to S. 136# don't export the working copy to S.
120ESVN_RESTRICT="${ESVN_RESTRICT:-}" 137ESVN_RESTRICT="${ESVN_RESTRICT:-}"
138
139# @ECLASS-VARIABLE: ESVN_OFFLINE
140# @DESCRIPTION:
141# Set this variable to a non-empty value to disable the automatic updating of
142# an svn source tree. This is intended to be set outside the subversion source
143# tree by users.
144ESVN_OFFLINE="${ESVN_OFFLINE:-${EVCS_OFFLINE}}"
145
146# @ECLASS-VARIABLE: ESVN_UMASK
147# @DESCRIPTION:
148# Set this variable to a custom umask. This is intended to be set by users.
149# By setting this to something like 002, it can make life easier for people
150# who do development as non-root (but are in the portage group), and then
151# switch over to building with FEATURES=userpriv. Or vice-versa. Shouldn't
152# be a security issue here as anyone who has portage group write access
153# already can screw the system over in more creative ways.
154ESVN_UMASK="${ESVN_UMASK:-${EVCS_UMASK}}"
155
156# @ECLASS-VARIABLE: ESVN_UP_FREQ
157# @DESCRIPTION:
158# Set the minimum number of hours between svn up'ing in any given svn module. This is particularly
159# useful for split KDE ebuilds where we want to ensure that all submodules are compiled for the same
160# revision. It should also be kept user overrideable.
161ESVN_UP_FREQ="${ESVN_UP_FREQ:=}"
162
163# @ECLASS-VARIABLE: ESCM_LOGDIR
164# @DESCRIPTION:
165# User configuration variable. If set to a path such as e.g. /var/log/scm any
166# package inheriting from subversion.eclass will record svn revision to
167# ${CATEGORY}/${PN}.log in that path in pkg_preinst. This is not supposed to be
168# set by ebuilds/eclasses. It defaults to empty so users need to opt in.
169ESCM_LOGDIR="${ESCM_LOGDIR:=}"
121 170
122# @FUNCTION: subversion_fetch 171# @FUNCTION: subversion_fetch
123# @USAGE: [repo_uri] [destination] 172# @USAGE: [repo_uri] [destination]
124# @DESCRIPTION: 173# @DESCRIPTION:
125# Wrapper function to fetch sources from subversion via svn checkout or svn update, 174# Wrapper function to fetch sources from subversion via svn checkout or svn update,
131subversion_fetch() { 180subversion_fetch() {
132 local repo_uri="$(subversion__get_repository_uri "${1:-${ESVN_REPO_URI}}")" 181 local repo_uri="$(subversion__get_repository_uri "${1:-${ESVN_REPO_URI}}")"
133 local revision="$(subversion__get_peg_revision "${1:-${ESVN_REPO_URI}}")" 182 local revision="$(subversion__get_peg_revision "${1:-${ESVN_REPO_URI}}")"
134 local S_dest="${2}" 183 local S_dest="${2}"
135 184
185 if [[ -z ${repo_uri} ]]; then
186 die "${ESVN}: ESVN_REPO_URI (or specified URI) is empty."
187 fi
188
136 [[ -n "${ESVN_REVISION}" ]] && revision="${ESVN_REVISION}" 189 [[ -n "${ESVN_REVISION}" ]] && revision="${ESVN_REVISION}"
137 190
138 # check for the protocol 191 # check for the protocol
139 local protocol="${repo_uri%%:*}" 192 local protocol="${repo_uri%%:*}"
140
141 case "${protocol}" in 193 case "${protocol}" in
142 http|https) 194 http|https)
143 if built_with_use dev-util/subversion nowebdav; then
144 echo
145 eerror "In order to emerge this package, you need to"
146 eerror "re-emerge subversion with USE=-nowebdav"
147 echo
148 die "${ESVN}: please run 'USE=-nowebdav emerge subversion'"
149 fi
150 ;; 195 ;;
151 svn|svn+ssh) 196 svn|svn+ssh)
152 ;; 197 ;;
153 *) 198 *)
154 die "${ESVN}: fetch from '${protocol}' is not yet implemented." 199 die "${ESVN}: fetch from '${protocol}' is not yet implemented."
156 esac 201 esac
157 202
158 addread "/etc/subversion" 203 addread "/etc/subversion"
159 addwrite "${ESVN_STORE_DIR}" 204 addwrite "${ESVN_STORE_DIR}"
160 205
206 if [[ -n "${ESVN_UMASK}" ]]; then
207 eumask_push "${ESVN_UMASK}"
208 fi
209
161 if [[ ! -d ${ESVN_STORE_DIR} ]]; then 210 if [[ ! -d ${ESVN_STORE_DIR} ]]; then
162 debug-print "${FUNCNAME}: initial checkout. creating subversion directory" 211 debug-print "${FUNCNAME}: initial checkout. creating subversion directory"
163 mkdir -p "${ESVN_STORE_DIR}" || die "${ESVN}: can't mkdir ${ESVN_STORE_DIR}." 212 mkdir -m 775 -p "${ESVN_STORE_DIR}" || die "${ESVN}: can't mkdir ${ESVN_STORE_DIR}."
164 fi 213 fi
165 214
166 cd "${ESVN_STORE_DIR}" || die "${ESVN}: can't chdir to ${ESVN_STORE_DIR}" 215 pushd "${ESVN_STORE_DIR}" >/dev/null || die "${ESVN}: can't chdir to ${ESVN_STORE_DIR}"
167 216
168 local wc_path="$(subversion__get_wc_path "${repo_uri}")" 217 local wc_path="$(subversion__get_wc_path "${repo_uri}")"
169 local options="${ESVN_OPTIONS} --config-dir ${ESVN_STORE_DIR}/.subversion" 218 local options="${ESVN_OPTIONS} --config-dir ${ESVN_STORE_DIR}/.subversion"
170 219
171 [[ -n "${revision}" ]] && options="${options} -r ${revision}" 220 [[ -n "${revision}" ]] && options="${options} -r ${revision}"
173 if [[ "${ESVN_OPTIONS}" = *-r* ]]; then 222 if [[ "${ESVN_OPTIONS}" = *-r* ]]; then
174 ewarn "\${ESVN_OPTIONS} contains -r, this usage is unsupported. Please" 223 ewarn "\${ESVN_OPTIONS} contains -r, this usage is unsupported. Please"
175 ewarn "see \${ESVN_REPO_URI}" 224 ewarn "see \${ESVN_REPO_URI}"
176 fi 225 fi
177 226
227 if has_version ">=dev-vcs/subversion-1.6.0"; then
228 options="${options} --config-option=config:auth:password-stores="
229 fi
230
178 debug-print "${FUNCNAME}: wc_path = \"${wc_path}\"" 231 debug-print "${FUNCNAME}: wc_path = \"${wc_path}\""
179 debug-print "${FUNCNAME}: ESVN_OPTIONS = \"${ESVN_OPTIONS}\"" 232 debug-print "${FUNCNAME}: ESVN_OPTIONS = \"${ESVN_OPTIONS}\""
180 debug-print "${FUNCNAME}: options = \"${options}\"" 233 debug-print "${FUNCNAME}: options = \"${options}\""
181 234
182 if [[ ! -d ${wc_path}/.svn ]]; then 235 if [[ ! -d ${wc_path}/.svn ]]; then
236 if [[ -n ${ESVN_OFFLINE} ]]; then
237 ewarn "ESVN_OFFLINE cannot be used when there is no existing checkout."
238 fi
183 # first check out 239 # first check out
184 einfo "subversion check out start -->" 240 einfo "subversion check out start -->"
185 einfo " repository: ${repo_uri}${revision:+@}${revision}" 241 einfo " repository: ${repo_uri}${revision:+@}${revision}"
186 242
187 debug-print "${FUNCNAME}: ${ESVN_FETCH_CMD} ${options} ${repo_uri}" 243 debug-print "${FUNCNAME}: ${ESVN_FETCH_CMD} ${options} ${repo_uri}"
188 244
189 mkdir -p "${ESVN_PROJECT}" || die "${ESVN}: can't mkdir ${ESVN_PROJECT}." 245 mkdir -m 775 -p "${ESVN_PROJECT}" || die "${ESVN}: can't mkdir ${ESVN_PROJECT}."
190 cd "${ESVN_PROJECT}" || die "${ESVN}: can't chdir to ${ESVN_PROJECT}" 246 cd "${ESVN_PROJECT}" || die "${ESVN}: can't chdir to ${ESVN_PROJECT}"
247 if [[ -n "${ESVN_USER}" ]]; then
248 ${ESVN_FETCH_CMD} ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
249 else
191 ${ESVN_FETCH_CMD} ${options} "${repo_uri}" || die "${ESVN}: can't fetch from ${repo_uri}." 250 ${ESVN_FETCH_CMD} ${options} "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
251 fi
192 252
253 elif [[ -n ${ESVN_OFFLINE} ]]; then
254 svn upgrade "${wc_path}" &>/dev/null
255 svn cleanup "${wc_path}" &>/dev/null
256 subversion_wc_info "${repo_uri}" || die "${ESVN}: unknown problem occurred while accessing working copy."
257
258 if [[ -n ${ESVN_REVISION} && ${ESVN_REVISION} != ${ESVN_WC_REVISION} ]]; then
259 die "${ESVN}: You requested off-line updating and revision ${ESVN_REVISION} but only revision ${ESVN_WC_REVISION} is available locally."
260 fi
261 einfo "Fetching disabled: Using existing repository copy at revision ${ESVN_WC_REVISION}."
193 else 262 else
263 svn upgrade "${wc_path}" &>/dev/null
264 svn cleanup "${wc_path}" &>/dev/null
194 subversion_wc_info "${repo_uri}" || die "${ESVN}: unknown problem occurred while accessing working copy." 265 subversion_wc_info "${repo_uri}" || die "${ESVN}: unknown problem occurred while accessing working copy."
195 266
196 if [[ ${ESVN_WC_URL} != $(subversion__get_repository_uri "${repo_uri}") ]]; then 267 local esvn_up_freq=
197 die "${ESVN}: ESVN_REPO_URI (or specified URI) and working copy's URL are not matched." 268 if [[ -n ${ESVN_UP_FREQ} ]]; then
269 if [[ -n ${ESVN_UP_FREQ//[[:digit:]]} ]]; then
270 die "${ESVN}: ESVN_UP_FREQ must be an integer value corresponding to the minimum number of hours between svn up."
271 elif [[ -z $(find "${wc_path}/.svn/entries" -mmin "+$((ESVN_UP_FREQ*60))") ]]; then
272 einfo "Fetching disabled since ${ESVN_UP_FREQ} hours has not passed since last update."
273 einfo "Using existing repository copy at revision ${ESVN_WC_REVISION}."
274 esvn_up_freq=no_update
198 fi 275 fi
276 fi
199 277
200 # update working copy 278 if [[ -z ${esvn_up_freq} ]]; then
279 if [[ ${ESVN_WC_UUID} != $(subversion__svn_info "${repo_uri}" "Repository UUID") ]]; then
280 # UUID mismatch. Delete working copy and check out it again.
201 einfo "subversion update start -->" 281 einfo "subversion recheck out start -->"
282 einfo " old UUID: ${ESVN_WC_UUID}"
283 einfo " new UUID: $(subversion__svn_info "${repo_uri}" "Repository UUID")"
202 einfo " repository: ${repo_uri}${revision:+@}${revision}" 284 einfo " repository: ${repo_uri}${revision:+@}${revision}"
203 285
286 rm -fr "${ESVN_PROJECT}" || die
287
204 debug-print "${FUNCNAME}: ${ESVN_UPDATE_CMD} ${options}" 288 debug-print "${FUNCNAME}: ${ESVN_FETCH_CMD} ${options} ${repo_uri}"
205 289
290 mkdir -m 775 -p "${ESVN_PROJECT}" || die "${ESVN}: can't mkdir ${ESVN_PROJECT}."
291 cd "${ESVN_PROJECT}" || die "${ESVN}: can't chdir to ${ESVN_PROJECT}"
292 if [[ -n "${ESVN_USER}" ]]; then
293 ${ESVN_FETCH_CMD} ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
294 else
295 ${ESVN_FETCH_CMD} ${options} "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
296 fi
297 elif [[ ${ESVN_WC_URL} != $(subversion__get_repository_uri "${repo_uri}") ]]; then
298 einfo "subversion switch start -->"
299 einfo " old repository: ${ESVN_WC_URL}@${ESVN_WC_REVISION}"
300 einfo " new repository: ${repo_uri}${revision:+@}${revision}"
301
302 debug-print "${FUNCNAME}: ${ESVN_SWITCH_CMD} ${options} ${repo_uri}"
303
206 cd "${wc_path}" || die "${ESVN}: can't chdir to ${wc_path}" 304 cd "${wc_path}" || die "${ESVN}: can't chdir to ${wc_path}"
305 if [[ -n "${ESVN_USER}" ]]; then
306 ${ESVN_SWITCH_CMD} ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" ${repo_uri} || die "${ESVN}: can't update ${wc_path} from ${repo_uri}."
307 else
308 ${ESVN_SWITCH_CMD} ${options} ${repo_uri} || die "${ESVN}: can't update ${wc_path} from ${repo_uri}."
309 fi
310 else
311 # update working copy
312 einfo "subversion update start -->"
313 einfo " repository: ${repo_uri}${revision:+@}${revision}"
314
315 debug-print "${FUNCNAME}: ${ESVN_UPDATE_CMD} ${options}"
316
317 cd "${wc_path}" || die "${ESVN}: can't chdir to ${wc_path}"
318 if [[ -n "${ESVN_USER}" ]]; then
319 ${ESVN_UPDATE_CMD} ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" || die "${ESVN}: can't update ${wc_path} from ${repo_uri}."
320 else
207 ${ESVN_UPDATE_CMD} ${options} || die "${ESVN}: can't update from ${repo_uri}." 321 ${ESVN_UPDATE_CMD} ${options} || die "${ESVN}: can't update ${wc_path} from ${repo_uri}."
322 fi
323 fi
324 fi
325 fi
208 326
327 if [[ -n "${ESVN_UMASK}" ]]; then
328 eumask_pop
209 fi 329 fi
210 330
211 einfo " working copy: ${wc_path}" 331 einfo " working copy: ${wc_path}"
212 332
213 if ! has "export" ${ESVN_RESTRICT}; then 333 if ! has "export" ${ESVN_RESTRICT}; then
214 cd "${wc_path}" || die "${ESVN}: can't chdir to ${wc_path}" 334 cd "${wc_path}" || die "${ESVN}: can't chdir to ${wc_path}"
215 335
216 local S="${S}/${S_dest}" 336 local S="${S}/${S_dest}"
337 mkdir -p "${S}"
217 338
218 # export to the ${WORKDIR} 339 # export to the ${WORKDIR}
219 #* "svn export" has a bug. see http://bugs.gentoo.org/119236 340 #* "svn export" has a bug. see http://bugs.gentoo.org/119236
220 #* svn export . "${S}" || die "${ESVN}: can't export to ${S}." 341 #* svn export . "${S}" || die "${ESVN}: can't export to ${S}."
221 rsync -rlpgo --exclude=".svn/" . "${S}" || die "${ESVN}: can't export to ${S}." 342 rsync -rlpgo --exclude=".svn/" . "${S}" || die "${ESVN}: can't export to ${S}."
222 fi 343 fi
223 344
345 popd >/dev/null
224 echo 346 echo
225} 347}
226 348
227# @FUNCTION: subversion_bootstrap 349# @FUNCTION: subversion_bootstrap
228# @DESCRIPTION: 350# @DESCRIPTION:
233 fi 355 fi
234 356
235 cd "${S}" 357 cd "${S}"
236 358
237 if [[ -n ${ESVN_PATCHES} ]]; then 359 if [[ -n ${ESVN_PATCHES} ]]; then
360 local patch fpatch
238 einfo "apply patches -->" 361 einfo "apply patches -->"
239
240 local patch fpatch
241
242 for patch in ${ESVN_PATCHES}; do 362 for patch in ${ESVN_PATCHES}; do
243 if [[ -f ${patch} ]]; then 363 if [[ -f ${patch} ]]; then
244 epatch "${patch}" 364 epatch "${patch}"
245
246 else 365 else
247 for fpatch in ${FILESDIR}/${patch}; do 366 for fpatch in ${FILESDIR}/${patch}; do
248 if [[ -f ${fpatch} ]]; then 367 if [[ -f ${fpatch} ]]; then
249 epatch "${fpatch}" 368 epatch "${fpatch}"
250
251 else 369 else
252 die "${ESVN}: ${patch} not found" 370 die "${ESVN}: ${patch} not found"
253
254 fi 371 fi
255 done 372 done
256
257 fi 373 fi
258 done 374 done
259
260 echo 375 echo
261 fi 376 fi
262 377
263 if [[ -n ${ESVN_BOOTSTRAP} ]]; then 378 if [[ -n ${ESVN_BOOTSTRAP} ]]; then
264 einfo "begin bootstrap -->" 379 einfo "begin bootstrap -->"
265
266 if [[ -f ${ESVN_BOOTSTRAP} && -x ${ESVN_BOOTSTRAP} ]]; then 380 if [[ -f ${ESVN_BOOTSTRAP} && -x ${ESVN_BOOTSTRAP} ]]; then
267 einfo " bootstrap with a file: ${ESVN_BOOTSTRAP}" 381 einfo " bootstrap with a file: ${ESVN_BOOTSTRAP}"
268 eval "./${ESVN_BOOTSTRAP}" || die "${ESVN}: can't execute ESVN_BOOTSTRAP." 382 eval "./${ESVN_BOOTSTRAP}" || die "${ESVN}: can't execute ESVN_BOOTSTRAP."
269
270 else 383 else
271 einfo " bootstrap with command: ${ESVN_BOOTSTRAP}" 384 einfo " bootstrap with command: ${ESVN_BOOTSTRAP}"
272 eval "${ESVN_BOOTSTRAP}" || die "${ESVN}: can't eval ESVN_BOOTSTRAP." 385 eval "${ESVN_BOOTSTRAP}" || die "${ESVN}: can't eval ESVN_BOOTSTRAP."
273
274 fi
275 fi 386 fi
276} 387 fi
277
278# @FUNCTION: subversion_src_unpack
279# @DESCRIPTION:
280# default src_unpack. fetch and bootstrap.
281subversion_src_unpack() {
282 subversion_fetch || die "${ESVN}: unknown problem occurred in subversion_fetch."
283 subversion_bootstrap || die "${ESVN}: unknown problem occurred in subversion_bootstrap."
284} 388}
285 389
286# @FUNCTION: subversion_wc_info 390# @FUNCTION: subversion_wc_info
287# @USAGE: [repo_uri] 391# @USAGE: [repo_uri]
288# @RETURN: ESVN_WC_URL, ESVN_WC_ROOT, ESVN_WC_UUID, ESVN_WC_REVISION and ESVN_WC_PATH 392# @RETURN: ESVN_WC_URL, ESVN_WC_ROOT, ESVN_WC_UUID, ESVN_WC_REVISION and ESVN_WC_PATH
290# Get svn info for the specified repo_uri. The default repo_uri is ESVN_REPO_URI. 394# Get svn info for the specified repo_uri. The default repo_uri is ESVN_REPO_URI.
291# 395#
292# The working copy information on the specified repository URI are set to 396# The working copy information on the specified repository URI are set to
293# ESVN_WC_* variables. 397# ESVN_WC_* variables.
294subversion_wc_info() { 398subversion_wc_info() {
295 local repo_uri="$(subversion__get_repository_uri "${1}")" 399 local repo_uri="$(subversion__get_repository_uri "${1:-${ESVN_REPO_URI}}")"
296 local wc_path="$(subversion__get_wc_path "${repo_uri}")" 400 local wc_path="$(subversion__get_wc_path "${repo_uri}")"
297 401
298 debug-print "${FUNCNAME}: repo_uri = ${repo_uri}" 402 debug-print "${FUNCNAME}: repo_uri = ${repo_uri}"
299 debug-print "${FUNCNAME}: wc_path = ${wc_path}" 403 debug-print "${FUNCNAME}: wc_path = ${wc_path}"
300 404
307 export ESVN_WC_UUID="$(subversion__svn_info "${wc_path}" "Repository UUID")" 411 export ESVN_WC_UUID="$(subversion__svn_info "${wc_path}" "Repository UUID")"
308 export ESVN_WC_REVISION="$(subversion__svn_info "${wc_path}" "Revision")" 412 export ESVN_WC_REVISION="$(subversion__svn_info "${wc_path}" "Revision")"
309 export ESVN_WC_PATH="${wc_path}" 413 export ESVN_WC_PATH="${wc_path}"
310} 414}
311 415
416# @FUNCTION: subversion_src_unpack
417# @DESCRIPTION:
418# Default src_unpack. Fetch and, in older EAPIs, bootstrap.
419subversion_src_unpack() {
420 subversion_fetch || die "${ESVN}: unknown problem occurred in subversion_fetch."
421 if has "${EAPI:-0}" 0 1; then
422 subversion_bootstrap || die "${ESVN}: unknown problem occurred in subversion_bootstrap."
423 fi
424}
425
426# @FUNCTION: subversion_src_prepare
427# @DESCRIPTION:
428# Default src_prepare. Bootstrap.
429subversion_src_prepare() {
430 subversion_bootstrap || die "${ESVN}: unknown problem occurred in subversion_bootstrap."
431}
432
433# @FUNCTION: subversion_pkg_preinst
434# @USAGE: [repo_uri]
435# @DESCRIPTION:
436# Log the svn revision of source code. Doing this in pkg_preinst because we
437# want the logs to stick around if packages are uninstalled without messing with
438# config protection.
439subversion_pkg_preinst() {
440 local pkgdate=$(date "+%Y%m%d %H:%M:%S")
441 subversion_wc_info "${1}"
442 if [[ -n ${ESCM_LOGDIR} ]]; then
443 local dir="${ROOT}/${ESCM_LOGDIR}/${CATEGORY}"
444 if [[ ! -d ${dir} ]]; then
445 mkdir -p "${dir}" || eerror "Failed to create '${dir}' for logging svn revision"
446 fi
447 local logmessage="svn: ${pkgdate} - ${PF}:${SLOT} was merged at revision ${ESVN_WC_REVISION}"
448 if [[ -d ${dir} ]]; then
449 echo "${logmessage}" >>"${dir}/${PN}.log"
450 else
451 eerror "Could not log the message '${logmessage}' to '${dir}/${PN}.log'"
452 fi
453 fi
454}
455
312## -- Private Functions 456## -- Private Functions
313 457
314## -- subversion__svn_info() ------------------------------------------------- # 458## -- subversion__svn_info() ------------------------------------------------- #
315# 459#
316# param $1 - a target. 460# param $1 - a target.
318# 462#
319subversion__svn_info() { 463subversion__svn_info() {
320 local target="${1}" 464 local target="${1}"
321 local key="${2}" 465 local key="${2}"
322 466
323 env LC_ALL=C svn info "${target}" | grep -i "^${key}" | cut -d" " -f2- 467 env LC_ALL=C svn info ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" "${target}" \
468 | grep -i "^${key}" \
469 | cut -d" " -f2-
324} 470}
325 471
326## -- subversion__get_repository_uri() --------------------------------------- # 472## -- subversion__get_repository_uri() --------------------------------------- #
327# 473#
328# param $1 - a repository URI. 474# param $1 - a repository URI.
329subversion__get_repository_uri() { 475subversion__get_repository_uri() {
330 local repo_uri="${1}" 476 local repo_uri="${1}"
331 477
332 debug-print "${FUNCNAME}: repo_uri = ${repo_uri}" 478 debug-print "${FUNCNAME}: repo_uri = ${repo_uri}"
333
334 if [[ -z ${repo_uri} ]]; then 479 if [[ -z ${repo_uri} ]]; then
335 die "${ESVN}: ESVN_REPO_URI (or specified URI) is empty." 480 die "${ESVN}: ESVN_REPO_URI (or specified URI) is empty."
336 fi 481 fi
337
338 # delete trailing slash 482 # delete trailing slash
339 if [[ -z ${repo_uri##*/} ]]; then 483 if [[ -z ${repo_uri##*/} ]]; then
340 repo_uri="${repo_uri%/}" 484 repo_uri="${repo_uri%/}"
341 fi 485 fi
342
343 repo_uri="${repo_uri%@*}" 486 repo_uri="${repo_uri%@*}"
344 487
345 echo "${repo_uri}" 488 echo "${repo_uri}"
346} 489}
347 490
359## -- subversion__get_peg_revision() ----------------------------------------- # 502## -- subversion__get_peg_revision() ----------------------------------------- #
360# 503#
361# param $1 - a repository URI. 504# param $1 - a repository URI.
362subversion__get_peg_revision() { 505subversion__get_peg_revision() {
363 local repo_uri="${1}" 506 local repo_uri="${1}"
507 local peg_rev=
364 508
365 debug-print "${FUNCNAME}: repo_uri = ${repo_uri}" 509 debug-print "${FUNCNAME}: repo_uri = ${repo_uri}"
366
367 # repo_uri has peg revision ? 510 # repo_uri has peg revision?
368 if [[ ${repo_uri} != *@* ]]; then 511 if [[ ${repo_uri} = *@* ]]; then
512 peg_rev="${repo_uri##*@}"
513 debug-print "${FUNCNAME}: peg_rev = ${peg_rev}"
514 else
369 debug-print "${FUNCNAME}: repo_uri does not have a peg revision." 515 debug-print "${FUNCNAME}: repo_uri does not have a peg revision."
370 fi 516 fi
371
372 local peg_rev=
373 [[ ${repo_uri} = *@* ]] && peg_rev="${repo_uri##*@}"
374
375 debug-print "${FUNCNAME}: peg_rev = ${peg_rev}"
376 517
377 echo "${peg_rev}" 518 echo "${peg_rev}"
378} 519}

Legend:
Removed from v.1.47  
changed lines
  Added in v.1.82

  ViewVC Help
Powered by ViewVC 1.1.20