| 1 | # Copyright 1999-2006 Gentoo Foundation |
1 | # Copyright 1999-2006 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/mercurial.eclass,v 1.4 2009/02/22 13:01:17 nelchael Exp $ |
3 | # $Header: /var/cvsroot/gentoo-x86/eclass/mercurial.eclass,v 1.10 2010/01/17 12:03:48 nelchael Exp $ |
| 4 | |
4 | |
| 5 | # mercurial: Fetch sources from mercurial repositories, similar to cvs.eclass. |
5 | # @ECLASS: mercurial.eclass |
| 6 | # To use this from an ebuild, set EHG_REPO_URI in your ebuild. Then either |
6 | # @MAINTAINER: |
| 7 | # leave the default src_unpack or call mercurial_src_unpack. |
7 | # nelchael@gentoo.org |
|
|
8 | # @BLURB: This eclass provides generic mercurial fetching functions |
|
|
9 | # @DESCRIPTION: |
|
|
10 | # This eclass provides generic mercurial fetching functions. To fetch sources |
|
|
11 | # from mercurial repository just set EHG_REPO_URI to correct repository URI. If |
|
|
12 | # you need to share single repository between several ebuilds set EHG_PROJECT to |
|
|
13 | # project name in all of them. |
| 8 | |
14 | |
| 9 | inherit eutils |
15 | inherit eutils |
| 10 | |
16 | |
| 11 | EXPORT_FUNCTIONS src_unpack |
17 | EXPORT_FUNCTIONS src_unpack |
| 12 | |
18 | |
| 13 | DEPEND="dev-util/mercurial net-misc/rsync" |
19 | DEPEND="dev-util/mercurial" |
| 14 | EHG_STORE_DIR="${PORTAGE_ACTUAL_DISTDIR-${DISTDIR}}/hg-src" |
|
|
| 15 | |
20 | |
| 16 | # This must be set by the ebuild |
21 | # @ECLASS-VARIABLE: EHG_REPO_URI |
| 17 | : ${EHG_REPO_URI:=} # repository uri |
22 | # @DESCRIPTION: |
|
|
23 | # Mercurial repository URI. |
| 18 | |
24 | |
| 19 | # These can be set by the ebuild but are usually fine as-is |
25 | # @ECLASS-VARIABLE: EHG_REVISION |
| 20 | : ${EHG_PROJECT:=$PN} # dir under EHG_STORE_DIR |
26 | # @DESCRIPTION: |
| 21 | : ${EHG_CLONE_CMD:=hg clone --pull} # clone cmd |
27 | # Create working directory for specified revision, defaults to tip. |
| 22 | : ${EHG_PULL_CMD:=hg pull -u} # pull cmd |
28 | # |
|
|
29 | # EHG_REVISION is passed as a value for --rev parameter, so it can be more than |
|
|
30 | # just a revision, please consult `hg help revisions' for more details. |
|
|
31 | [[ -z "${EHG_REVISION}" ]] && EHG_REVISION="tip" |
| 23 | |
32 | |
| 24 | # should be set but blank to prevent using $HOME/.hgrc |
33 | # @ECLASS-VARIABLE: EHG_PROJECT |
| 25 | export HGRCPATH= |
34 | # @DESCRIPTION: |
|
|
35 | # Project name. |
|
|
36 | # |
|
|
37 | # This variable default to $PN, but can be changed to allow repository sharing |
|
|
38 | # between several ebuilds. |
|
|
39 | [[ -z "${EHG_PROJECT}" ]] && EHG_PROJECT="${PN}" |
| 26 | |
40 | |
|
|
41 | # @ECLASS-VARIABLE: EHG_QUIET |
|
|
42 | # @DESCRIPTION: |
|
|
43 | # Suppress some extra noise from mercurial, set it to 'OFF' to be louder. |
|
|
44 | : ${EHG_QUIET:="ON"} |
|
|
45 | [[ "${EHG_QUIET}" == "ON" ]] && EHG_QUIET_CMD_OPT="--quiet" |
|
|
46 | |
|
|
47 | # @ECLASS-VARIABLE: EHG_CLONE_CMD |
|
|
48 | # @DESCRIPTION: |
|
|
49 | # Command used to perform initial repository clone. |
|
|
50 | [[ -z "${EHG_CLONE_CMD}" ]] && EHG_CLONE_CMD="hg clone ${EHG_QUIET_CMD_OPT} --pull --noupdate" |
|
|
51 | |
|
|
52 | # @ECLASS-VARIABLE: EHG_PULL_CMD |
|
|
53 | # @DESCRIPTION: |
|
|
54 | # Command used to update repository. |
|
|
55 | [[ -z "${EHG_PULL_CMD}" ]] && EHG_PULL_CMD="hg pull ${EHG_QUIET_CMD_OPT}" |
|
|
56 | |
|
|
57 | # @ECLASS-VARIABLE: EHG_OFFLINE |
|
|
58 | # @DESCRIPTION: |
|
|
59 | # Set this variable to a non-empty value to disable the automatic updating of |
|
|
60 | # a mercurial source tree. This is intended to be set outside the ebuild by |
|
|
61 | # users. |
|
|
62 | EHG_OFFLINE="${EHG_OFFLINE:-${ESCM_OFFLINE}}" |
|
|
63 | |
|
|
64 | # @FUNCTION: mercurial_fetch |
|
|
65 | # @USAGE: [repository_uri] [module] |
|
|
66 | # @DESCRIPTION: |
|
|
67 | # Clone or update repository. |
|
|
68 | # |
|
|
69 | # If not repository URI is passed it defaults to EHG_REPO_URI, if module is |
|
|
70 | # empty it defaults to basename of EHG_REPO_URI. |
| 27 | function mercurial_fetch { |
71 | function mercurial_fetch { |
| 28 | declare repo=${1:-$EHG_REPO_URI} |
72 | debug-print-function ${FUNCNAME} ${*} |
| 29 | repo=${repo%/} # remove trailing slash |
|
|
| 30 | [[ -n $repo ]] || die "EHG_REPO_URI is empty" |
|
|
| 31 | declare module=${2:-${repo##*/}} |
|
|
| 32 | |
73 | |
| 33 | if [[ ! -d ${EHG_STORE_DIR} ]]; then |
74 | EHG_REPO_URI=${1-${EHG_REPO_URI}} |
| 34 | ebegin "create ${EHG_STORE_DIR}" |
75 | [[ -z "${EHG_REPO_URI}" ]] && die "EHG_REPO_URI is empty" |
| 35 | addwrite / && |
76 | |
| 36 | mkdir -p "${EHG_STORE_DIR}" && |
77 | local hg_src_dir="${PORTAGE_ACTUAL_DISTDIR-${DISTDIR}}/hg-src" |
| 37 | chmod -f g+rw "${EHG_STORE_DIR}" && |
78 | local module="${2-$(basename "${EHG_REPO_URI}")}" |
| 38 | export SANDBOX_WRITE="${SANDBOX_WRITE%:/}" |
79 | |
| 39 | eend $? || die |
80 | # Should be set but blank to prevent using $HOME/.hgrc |
|
|
81 | export HGRCPATH= |
|
|
82 | |
|
|
83 | # Check ${hg_src_dir} directory: |
|
|
84 | addwrite "$(dirname "${hg_src_dir}")" || die "addwrite failed" |
|
|
85 | if [[ ! -d "${hg_src_dir}" ]]; then |
|
|
86 | mkdir -p "${hg_src_dir}" || die "failed to create ${hg_src_dir}" |
|
|
87 | chmod -f g+rw "${hg_src_dir}" || \ |
|
|
88 | die "failed to chown ${hg_src_dir}" |
| 40 | fi |
89 | fi |
| 41 | |
90 | |
| 42 | pushd "${EHG_STORE_DIR}" >/dev/null \ |
91 | # Create project directory: |
| 43 | || die "can't chdir to ${EHG_STORE_DIR}" |
92 | mkdir -p "${hg_src_dir}/${EHG_PROJECT}" || \ |
| 44 | addwrite "$(pwd -P)" |
93 | die "failed to create ${hg_src_dir}/${EHG_PROJECT}" |
|
|
94 | chmod -f g+rw "${hg_src_dir}/${EHG_PROJECT}" || \ |
|
|
95 | echo "Warning: failed to chmod g+rw ${EHG_PROJECT}" |
|
|
96 | cd "${hg_src_dir}/${EHG_PROJECT}" || \ |
|
|
97 | die "failed to cd to ${hg_src_dir}/${EHG_PROJECT}" |
| 45 | |
98 | |
|
|
99 | # Clone/update repository: |
| 46 | if [[ ! -d ${EHG_PROJECT}/${module} ]]; then |
100 | if [[ ! -d "${module}" ]]; then |
| 47 | # first check out |
101 | einfo "Cloning ${EHG_REPO_URI} to ${hg_src_dir}/${EHG_PROJECT}/${module}" |
| 48 | ebegin "${EHG_CLONE_CMD} ${repo}" |
|
|
| 49 | mkdir -p "${EHG_PROJECT}" && |
|
|
| 50 | chmod -f g+rw "${EHG_PROJECT}" && |
|
|
| 51 | cd "${EHG_PROJECT}" && |
|
|
| 52 | ${EHG_CLONE_CMD} "${repo}" "${module}" && |
102 | ${EHG_CLONE_CMD} "${EHG_REPO_URI}" "${module}" || { |
|
|
103 | rm -rf "${module}" |
|
|
104 | die "failed to clone ${EHG_REPO_URI}" |
|
|
105 | } |
| 53 | cd "${module}" |
106 | cd "${module}" |
| 54 | eend $? || die |
107 | elif [[ -z "${EHG_OFFLINE}" ]]; then |
| 55 | else |
108 | einfo "Updating ${hg_src_dir}/${EHG_PROJECT}/${module} from ${EHG_REPO_URI}" |
| 56 | # update working copy |
109 | cd "${module}" || die "failed to cd to ${module}" |
| 57 | ebegin "${EHG_PULL_CMD} ${repo}" |
110 | ${EHG_PULL_CMD} || die "update failed" |
| 58 | cd "${EHG_PROJECT}/${module}" && |
|
|
| 59 | ${EHG_PULL_CMD} |
|
|
| 60 | case $? in |
|
|
| 61 | # hg pull returns status 1 when there were no changes to pull |
|
|
| 62 | 1) eend 0 ;; |
|
|
| 63 | *) eend $? || die ;; |
|
|
| 64 | esac |
|
|
| 65 | fi |
111 | fi |
| 66 | |
112 | |
| 67 | # use rsync instead of cp for --exclude |
113 | # Checkout working copy: |
| 68 | ebegin "rsync to ${WORKDIR}/${module}" |
114 | einfo "Creating working directory in ${WORKDIR}/${module} (revision: ${EHG_REVISION})" |
| 69 | mkdir -p "${WORKDIR}/${module}" && |
115 | hg clone \ |
| 70 | rsync -a --delete --exclude=.hg/ . "${WORKDIR}/${module}" |
116 | ${EHG_QUIET_CMD_OPT} \ |
| 71 | eend $? || die |
117 | --rev="${EHG_REVISION}" \ |
| 72 | |
118 | "${hg_src_dir}/${EHG_PROJECT}/${module}" \ |
| 73 | popd >/dev/null |
119 | "${WORKDIR}/${module}" || die "hg clone failed" |
| 74 | } |
120 | } |
| 75 | |
121 | |
|
|
122 | # @FUNCTION: mercurial_src_unpack |
|
|
123 | # @DESCRIPTION: |
|
|
124 | # The mercurial src_unpack function, which will be exported. |
| 76 | function mercurial_src_unpack { |
125 | function mercurial_src_unpack { |
| 77 | mercurial_fetch |
126 | mercurial_fetch |
| 78 | } |
127 | } |