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

Diff of /eclass/subversion.eclass

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

Revision 1.63 Revision 1.73
1# Copyright 1999-2009 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.63 2009/04/26 02:18:09 arfrever Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/subversion.eclass,v 1.73 2012/02/02 03:17:56 floppym 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# Bo ├śrsted Andresen <zlin@gentoo.org>
9# Arfrever Frehtes Taifersar Arahesis <arfrever@gentoo.org> 9# Arfrever Frehtes Taifersar Arahesis <arfrever@gentoo.org>
10# 10# @AUTHOR:
11# Original Author: Akinori Hattori <hattya@gentoo.org> 11# Original Author: Akinori Hattori <hattya@gentoo.org>
12#
13# @BLURB: The subversion eclass is written to fetch software sources from subversion repositories 12# @BLURB: The subversion eclass is written to fetch software sources from subversion repositories
14# @DESCRIPTION: 13# @DESCRIPTION:
15# The subversion eclass provides functions to fetch, patch and bootstrap 14# The subversion eclass provides functions to fetch, patch and bootstrap
16# software sources from subversion repositories. 15# software sources from subversion repositories.
17 16
18inherit eutils 17inherit eutils
19 18
20ESVN="${ECLASS}" 19ESVN="${ECLASS}"
21 20
21case "${EAPI:-0}" in
22 0|1)
22EXPORT_FUNCTIONS src_unpack pkg_preinst 23 EXPORT_FUNCTIONS src_unpack pkg_preinst
24 ;;
25 *)
26 EXPORT_FUNCTIONS src_unpack src_prepare pkg_preinst
27 ;;
28esac
23 29
24DESCRIPTION="Based on the ${ECLASS} eclass" 30DESCRIPTION="Based on the ${ECLASS} eclass"
25 31
26DEPEND="dev-util/subversion 32SUBVERSION_DEPEND="dev-vcs/subversion
27 net-misc/rsync" 33 net-misc/rsync"
34
35if [[ -z "${ESVN_DISABLE_DEPENDENCIES}" ]]; then
36 DEPEND="${SUBVERSION_DEPEND}"
37fi
28 38
29# @ECLASS-VARIABLE: ESVN_STORE_DIR 39# @ECLASS-VARIABLE: ESVN_STORE_DIR
30# @DESCRIPTION: 40# @DESCRIPTION:
31# subversion sources store directory. Users may override this in /etc/make.conf 41# subversion sources store directory. Users may override this in /etc/make.conf
32[[ -z ${ESVN_STORE_DIR} ]] && ESVN_STORE_DIR="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}/svn-src" 42[[ -z ${ESVN_STORE_DIR} ]] && ESVN_STORE_DIR="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}/svn-src"
131# restrict. 141# restrict.
132# export) 142# export)
133# don't export the working copy to S. 143# don't export the working copy to S.
134ESVN_RESTRICT="${ESVN_RESTRICT:-}" 144ESVN_RESTRICT="${ESVN_RESTRICT:-}"
135 145
146# @ECLASS-VARIABLE: ESVN_DISABLE_DEPENDENCIES
147# @DESCRIPTION:
148# Set this variable to a non-empty value to disable the automatic inclusion of
149# Subversion in dependencies.
150ESVN_DISABLE_DEPENDENCIES="${ESVN_DISABLE_DEPENDENCIES:-}"
151
136# @ECLASS-VARIABLE: ESVN_OFFLINE 152# @ECLASS-VARIABLE: ESVN_OFFLINE
137# @DESCRIPTION: 153# @DESCRIPTION:
138# Set this variable to a non-empty value to disable the automatic updating of 154# Set this variable to a non-empty value to disable the automatic updating of
139# an svn source tree. This is intended to be set outside the subversion source 155# an svn source tree. This is intended to be set outside the subversion source
140# tree by users. 156# tree by users.
141ESVN_OFFLINE="${ESVN_OFFLINE:-${ESCM_OFFLINE}}" 157ESVN_OFFLINE="${ESVN_OFFLINE:-${ESCM_OFFLINE}}"
158
159# @ECLASS-VARIABLE: ESVN_UMASK
160# @DESCRIPTION:
161# Set this variable to custom umask.
162# This is intended to be set by users.
163ESVN_UMASK="${ESVN_UMASK:-${EVCS_UMASK}}"
142 164
143# @ECLASS-VARIABLE: ESVN_UP_FREQ 165# @ECLASS-VARIABLE: ESVN_UP_FREQ
144# @DESCRIPTION: 166# @DESCRIPTION:
145# Set the minimum number of hours between svn up'ing in any given svn module. This is particularly 167# Set the minimum number of hours between svn up'ing in any given svn module. This is particularly
146# useful for split KDE ebuilds where we want to ensure that all submodules are compiled for the same 168# useful for split KDE ebuilds where we want to ensure that all submodules are compiled for the same
178 # check for the protocol 200 # check for the protocol
179 local protocol="${repo_uri%%:*}" 201 local protocol="${repo_uri%%:*}"
180 202
181 case "${protocol}" in 203 case "${protocol}" in
182 http|https) 204 http|https)
183 if ! built_with_use --missing true -o dev-util/subversion webdav-neon webdav-serf || \ 205 if ! built_with_use -o dev-vcs/subversion webdav-neon webdav-serf; then
184 built_with_use --missing false dev-util/subversion nowebdav; then
185 echo 206 echo
186 eerror "In order to emerge this package, you need to" 207 eerror "In order to emerge this package, you need to"
187 eerror "reinstall Subversion with support for WebDAV." 208 eerror "reinstall Subversion with support for WebDAV."
188 eerror "Subversion requires either Neon or Serf to support WebDAV." 209 eerror "Subversion requires either Neon or Serf to support WebDAV."
189 echo 210 echo
198 esac 219 esac
199 220
200 addread "/etc/subversion" 221 addread "/etc/subversion"
201 addwrite "${ESVN_STORE_DIR}" 222 addwrite "${ESVN_STORE_DIR}"
202 223
224 if [[ -n "${ESVN_UMASK}" ]]; then
225 eumask_push "${ESVN_UMASK}"
226 fi
227
203 if [[ ! -d ${ESVN_STORE_DIR} ]]; then 228 if [[ ! -d ${ESVN_STORE_DIR} ]]; then
204 debug-print "${FUNCNAME}: initial checkout. creating subversion directory" 229 debug-print "${FUNCNAME}: initial checkout. creating subversion directory"
205 mkdir -p "${ESVN_STORE_DIR}" || die "${ESVN}: can't mkdir ${ESVN_STORE_DIR}." 230 mkdir -m 775 -p "${ESVN_STORE_DIR}" || die "${ESVN}: can't mkdir ${ESVN_STORE_DIR}."
206 fi 231 fi
207 232
208 cd "${ESVN_STORE_DIR}" || die "${ESVN}: can't chdir to ${ESVN_STORE_DIR}" 233 pushd "${ESVN_STORE_DIR}" > /dev/null || die "${ESVN}: can't chdir to ${ESVN_STORE_DIR}"
209 234
210 local wc_path="$(subversion__get_wc_path "${repo_uri}")" 235 local wc_path="$(subversion__get_wc_path "${repo_uri}")"
211 local options="${ESVN_OPTIONS} --config-dir ${ESVN_STORE_DIR}/.subversion" 236 local options="${ESVN_OPTIONS} --config-dir ${ESVN_STORE_DIR}/.subversion"
212 237
213 [[ -n "${revision}" ]] && options="${options} -r ${revision}" 238 [[ -n "${revision}" ]] && options="${options} -r ${revision}"
215 if [[ "${ESVN_OPTIONS}" = *-r* ]]; then 240 if [[ "${ESVN_OPTIONS}" = *-r* ]]; then
216 ewarn "\${ESVN_OPTIONS} contains -r, this usage is unsupported. Please" 241 ewarn "\${ESVN_OPTIONS} contains -r, this usage is unsupported. Please"
217 ewarn "see \${ESVN_REPO_URI}" 242 ewarn "see \${ESVN_REPO_URI}"
218 fi 243 fi
219 244
220 if has_version ">=dev-util/subversion-1.6.0"; then 245 if has_version ">=dev-vcs/subversion-1.6.0"; then
221 options="${options} --config-option=config:auth:password-stores=" 246 options="${options} --config-option=config:auth:password-stores="
222 fi 247 fi
223 248
224 debug-print "${FUNCNAME}: wc_path = \"${wc_path}\"" 249 debug-print "${FUNCNAME}: wc_path = \"${wc_path}\""
225 debug-print "${FUNCNAME}: ESVN_OPTIONS = \"${ESVN_OPTIONS}\"" 250 debug-print "${FUNCNAME}: ESVN_OPTIONS = \"${ESVN_OPTIONS}\""
233 einfo "subversion check out start -->" 258 einfo "subversion check out start -->"
234 einfo " repository: ${repo_uri}${revision:+@}${revision}" 259 einfo " repository: ${repo_uri}${revision:+@}${revision}"
235 260
236 debug-print "${FUNCNAME}: ${ESVN_FETCH_CMD} ${options} ${repo_uri}" 261 debug-print "${FUNCNAME}: ${ESVN_FETCH_CMD} ${options} ${repo_uri}"
237 262
238 mkdir -p "${ESVN_PROJECT}" || die "${ESVN}: can't mkdir ${ESVN_PROJECT}." 263 mkdir -m 775 -p "${ESVN_PROJECT}" || die "${ESVN}: can't mkdir ${ESVN_PROJECT}."
239 cd "${ESVN_PROJECT}" || die "${ESVN}: can't chdir to ${ESVN_PROJECT}" 264 cd "${ESVN_PROJECT}" || die "${ESVN}: can't chdir to ${ESVN_PROJECT}"
240 if [[ -n "${ESVN_USER}" ]]; then 265 if [[ -n "${ESVN_USER}" ]]; then
241 ${ESVN_FETCH_CMD} ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}." 266 ${ESVN_FETCH_CMD} ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
242 else 267 else
243 ${ESVN_FETCH_CMD} ${options} "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}." 268 ${ESVN_FETCH_CMD} ${options} "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
244 fi 269 fi
245 270
246 elif [[ -n ${ESVN_OFFLINE} ]]; then 271 elif [[ -n ${ESVN_OFFLINE} ]]; then
272 svn upgrade "${wc_path}" &>/dev/null
247 svn cleanup "${wc_path}" 273 svn cleanup "${wc_path}" &>/dev/null
248 subversion_wc_info "${repo_uri}" || die "${ESVN}: unknown problem occurred while accessing working copy." 274 subversion_wc_info "${repo_uri}" || die "${ESVN}: unknown problem occurred while accessing working copy."
249 if [[ -n ${ESVN_REVISION} && ${ESVN_REVISION} != ${ESVN_WC_REVISION} ]]; then 275 if [[ -n ${ESVN_REVISION} && ${ESVN_REVISION} != ${ESVN_WC_REVISION} ]]; then
250 die "${ESVN}: You requested off-line updating and revision ${ESVN_REVISION} but only revision ${ESVN_WC_REVISION} is available locally." 276 die "${ESVN}: You requested off-line updating and revision ${ESVN_REVISION} but only revision ${ESVN_WC_REVISION} is available locally."
251 fi 277 fi
252 einfo "Fetching disabled: Using existing repository copy at revision ${ESVN_WC_REVISION}." 278 einfo "Fetching disabled: Using existing repository copy at revision ${ESVN_WC_REVISION}."
253 else 279 else
280 svn upgrade "${wc_path}" &>/dev/null
254 svn cleanup "${wc_path}" 281 svn cleanup "${wc_path}" &>/dev/null
255 subversion_wc_info "${repo_uri}" || die "${ESVN}: unknown problem occurred while accessing working copy." 282 subversion_wc_info "${repo_uri}" || die "${ESVN}: unknown problem occurred while accessing working copy."
256 283
257 local esvn_up_freq= 284 local esvn_up_freq=
258 if [[ -n ${ESVN_UP_FREQ} ]]; then 285 if [[ -n ${ESVN_UP_FREQ} ]]; then
259 if [[ -n ${ESVN_UP_FREQ//[[:digit:]]} ]]; then 286 if [[ -n ${ESVN_UP_FREQ//[[:digit:]]} ]]; then
264 esvn_up_freq=no_update 291 esvn_up_freq=no_update
265 fi 292 fi
266 fi 293 fi
267 294
268 if [[ -z ${esvn_up_freq} ]]; then 295 if [[ -z ${esvn_up_freq} ]]; then
296 if [[ ${ESVN_WC_UUID} != $(subversion__svn_info "${repo_uri}" "Repository UUID") ]]; then
297 # UUID mismatch. Delete working copy and check out it again.
298 einfo "subversion recheck out start -->"
299 einfo " old UUID: ${ESVN_WC_UUID}"
300 einfo " new UUID: $(subversion__svn_info "${repo_uri}" "Repository UUID")"
301 einfo " repository: ${repo_uri}${revision:+@}${revision}"
302
303 rm -fr "${ESVN_PROJECT}" || die
304
305 debug-print "${FUNCNAME}: ${ESVN_FETCH_CMD} ${options} ${repo_uri}"
306
307 mkdir -m 775 -p "${ESVN_PROJECT}" || die "${ESVN}: can't mkdir ${ESVN_PROJECT}."
308 cd "${ESVN_PROJECT}" || die "${ESVN}: can't chdir to ${ESVN_PROJECT}"
309 if [[ -n "${ESVN_USER}" ]]; then
310 ${ESVN_FETCH_CMD} ${options} --username "${ESVN_USER}" --password "${ESVN_PASSWORD}" "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
311 else
312 ${ESVN_FETCH_CMD} ${options} "${repo_uri}" || die "${ESVN}: can't fetch to ${wc_path} from ${repo_uri}."
313 fi
269 if [[ ${ESVN_WC_URL} != $(subversion__get_repository_uri "${repo_uri}") ]]; then 314 elif [[ ${ESVN_WC_URL} != $(subversion__get_repository_uri "${repo_uri}") ]]; then
270 einfo "subversion switch start -->" 315 einfo "subversion switch start -->"
271 einfo " old repository: ${ESVN_WC_URL}@${ESVN_WC_REVISION}" 316 einfo " old repository: ${ESVN_WC_URL}@${ESVN_WC_REVISION}"
272 einfo " new repository: ${repo_uri}${revision:+@}${revision}" 317 einfo " new repository: ${repo_uri}${revision:+@}${revision}"
273 318
274 debug-print "${FUNCNAME}: ${ESVN_SWITCH_CMD} ${options} ${repo_uri}" 319 debug-print "${FUNCNAME}: ${ESVN_SWITCH_CMD} ${options} ${repo_uri}"
294 fi 339 fi
295 fi 340 fi
296 fi 341 fi
297 fi 342 fi
298 343
344 if [[ -n "${ESVN_UMASK}" ]]; then
345 eumask_pop
346 fi
347
299 einfo " working copy: ${wc_path}" 348 einfo " working copy: ${wc_path}"
300 349
301 if ! has "export" ${ESVN_RESTRICT}; then 350 if ! has "export" ${ESVN_RESTRICT}; then
302 cd "${wc_path}" || die "${ESVN}: can't chdir to ${wc_path}" 351 cd "${wc_path}" || die "${ESVN}: can't chdir to ${wc_path}"
303 352
308 #* "svn export" has a bug. see http://bugs.gentoo.org/119236 357 #* "svn export" has a bug. see http://bugs.gentoo.org/119236
309 #* svn export . "${S}" || die "${ESVN}: can't export to ${S}." 358 #* svn export . "${S}" || die "${ESVN}: can't export to ${S}."
310 rsync -rlpgo --exclude=".svn/" . "${S}" || die "${ESVN}: can't export to ${S}." 359 rsync -rlpgo --exclude=".svn/" . "${S}" || die "${ESVN}: can't export to ${S}."
311 fi 360 fi
312 361
362 popd > /dev/null
363
313 echo 364 echo
314} 365}
315 366
316# @FUNCTION: subversion_bootstrap 367# @FUNCTION: subversion_bootstrap
317# @DESCRIPTION: 368# @DESCRIPTION:
364 fi 415 fi
365} 416}
366 417
367# @FUNCTION: subversion_src_unpack 418# @FUNCTION: subversion_src_unpack
368# @DESCRIPTION: 419# @DESCRIPTION:
369# default src_unpack. fetch and bootstrap. 420# Default src_unpack. Fetch and, in older EAPIs, bootstrap.
370subversion_src_unpack() { 421subversion_src_unpack() {
371 subversion_fetch || die "${ESVN}: unknown problem occurred in subversion_fetch." 422 subversion_fetch || die "${ESVN}: unknown problem occurred in subversion_fetch."
423 if has "${EAPI:-0}" 0 1; then
424 subversion_bootstrap || die "${ESVN}: unknown problem occurred in subversion_bootstrap."
425 fi
426}
427
428# @FUNCTION: subversion_src_prepare
429# @DESCRIPTION:
430# Default src_prepare. Bootstrap.
431subversion_src_prepare() {
372 subversion_bootstrap || die "${ESVN}: unknown problem occurred in subversion_bootstrap." 432 subversion_bootstrap || die "${ESVN}: unknown problem occurred in subversion_bootstrap."
373} 433}
374 434
375# @FUNCTION: subversion_wc_info 435# @FUNCTION: subversion_wc_info
376# @USAGE: [repo_uri] 436# @USAGE: [repo_uri]

Legend:
Removed from v.1.63  
changed lines
  Added in v.1.73

  ViewVC Help
Powered by ViewVC 1.1.20