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

Diff of /eclass/bzr.eclass

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

Revision 1.1 Revision 1.16
1# Copyright 1999-2008 Gentoo Foundation 1# Copyright 1999-2011 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/bzr.eclass,v 1.1 2008/10/25 12:17:23 ulm Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/bzr.eclass,v 1.16 2011/09/02 21:26:58 ulm Exp $
4# 4#
5# @ECLASS: bzr.eclass 5# @ECLASS: bzr.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Emacs team <emacs@gentoo.org>
8# Bazaar team <bazaar@gentoo.org>
9# @AUTHOR:
7# Jorge Manuel B. S. Vicetto <jmbsvicetto@gentoo.org>, 10# Jorge Manuel B. S. Vicetto <jmbsvicetto@gentoo.org>
11# Mark Lee <bzr-gentoo-overlay@lazymalevolence.com>
8# Ulrich Mueller <ulm@gentoo.org>, 12# Ulrich MΓΌller <ulm@gentoo.org>
9# and anyone who wants to help 13# Christian Faulhammer <fauli@gentoo.org>
10# @BLURB: This eclass provides support to use the Bazaar DSCM 14# @BLURB: generic fetching functions for the Bazaar VCS
11# @DESCRIPTION: 15# @DESCRIPTION:
12# The bzr.eclass provides support for apps using the bazaar DSCM 16# The bzr.eclass provides functions to fetch, unpack, patch, and
13# (distributed source control management system). 17# bootstrap sources from repositories of the Bazaar distributed version
14# The eclass was originally derived from the git eclass. 18# control system. The eclass was originally derived from git.eclass.
15# 19#
16# Note: Just set EBZR_REPO_URI to the url of the branch and the src_unpack 20# Note: Just set EBZR_REPO_URI to the URI of the branch and src_unpack()
17# this eclass provides will put an export of the branch in ${WORKDIR}/${PN}. 21# of this eclass will export the branch to ${WORKDIR}/${P}.
18 22
19inherit eutils 23inherit eutils
20 24
21EBZR="bzr.eclass" 25EBZR="bzr.eclass"
22 26
27case "${EAPI:-0}" in
23EXPORT_FUNCTIONS src_unpack 28 0|1) EXPORT_FUNCTIONS src_unpack ;;
29 *) EXPORT_FUNCTIONS src_unpack src_prepare ;;
30esac
24 31
25HOMEPAGE="http://bazaar-vcs.org/" 32HOMEPAGE="http://bazaar-vcs.org/"
26DESCRIPTION="Based on the ${EBZR} eclass" 33DESCRIPTION="Based on the ${EBZR} eclass"
27 34
28DEPEND=">=dev-util/bzr-1.5" 35DEPEND=">=dev-vcs/bzr-2.0.1"
36case "${EAPI:-0}" in
37 0|1) ;;
38 *) [[ ${EBZR_REPO_URI%%:*} = sftp ]] \
39 && DEPEND=">=dev-vcs/bzr-2.0.1[sftp]" ;;
40esac
29 41
30# @ECLASS-VARIABLE: EBZR_STORE_DIR 42# @ECLASS-VARIABLE: EBZR_STORE_DIR
31# @DESCRIPTION: 43# @DESCRIPTION:
32# The dir to store the bzr sources. 44# The directory to store all fetched Bazaar live sources.
33EBZR_STORE_DIR="${PORTAGE_ACTUAL_DISTDIR-${DISTDIR}}/bzr-src" 45: ${EBZR_STORE_DIR:=${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}/bzr-src}
46
47# @ECLASS-VARIABLE: EBZR_INIT_REPO_CMD
48# @DESCRIPTION:
49# The Bazaar command to initialise a shared repository.
50: ${EBZR_INIT_REPO_CMD:="bzr init-repository --no-trees"}
34 51
35# @ECLASS-VARIABLE: EBZR_FETCH_CMD 52# @ECLASS-VARIABLE: EBZR_FETCH_CMD
36# @DESCRIPTION: 53# @DESCRIPTION:
37# The bzr command to fetch the sources. 54# The Bazaar command to fetch the sources.
38EBZR_FETCH_CMD="bzr branch" 55: ${EBZR_FETCH_CMD:="bzr branch --no-tree"}
39 56
40# @ECLASS-VARIABLE: EBZR_UPDATE_CMD 57# @ECLASS-VARIABLE: EBZR_UPDATE_CMD
41# @DESCRIPTION: 58# @DESCRIPTION:
42# The bzr command to update the sources. 59# The Bazaar command to update the sources.
43EBZR_UPDATE_CMD="bzr pull" 60: ${EBZR_UPDATE_CMD:="bzr pull"}
44
45# @ECLASS-VARIABLE: EBZR_DIFFSTAT_CMD
46# @DESCRIPTION:
47# The bzr command to get the diffstat output.
48EBZR_DIFFSTAT_CMD="bzr diff"
49 61
50# @ECLASS-VARIABLE: EBZR_EXPORT_CMD 62# @ECLASS-VARIABLE: EBZR_EXPORT_CMD
51# @DESCRIPTION: 63# @DESCRIPTION:
52# The bzr command to export a branch. 64# The Bazaar command to export a branch.
53EBZR_EXPORT_CMD="bzr export" 65: ${EBZR_EXPORT_CMD:="bzr export"}
54 66
55# @ECLASS-VARIABLE: EBZR_REVNO_CMD 67# @ECLASS-VARIABLE: EBZR_REVNO_CMD
56# @DESCRIPTION: 68# @DESCRIPTION:
57# The bzr command to list revision number of the branch. 69# The Bazaar command to list a revision number of the branch.
58EBZR_REVNO_CMD="bzr revno" 70: ${EBZR_REVNO_CMD:="bzr revno"}
59 71
60# @ECLASS-VARIABLE: EBZR_OPTIONS 72# @ECLASS-VARIABLE: EBZR_OPTIONS
73# @DEFAULT_UNSET
61# @DESCRIPTION: 74# @DESCRIPTION:
62# The options passed to the fetch and update commands. 75# The options passed to the fetch and update commands.
63EBZR_OPTIONS="${EBZR_OPTIONS:-}"
64 76
65# @ECLASS-VARIABLE: EBZR_REPO_URI 77# @ECLASS-VARIABLE: EBZR_REPO_URI
78# @DEFAULT_UNSET
79# @REQUIRED
66# @DESCRIPTION: 80# @DESCRIPTION:
67# The repository uri for the source package. 81# The repository URI for the source package.
68# 82#
69# @CODE 83# Note: If the ebuild uses an sftp:// URI, then in EAPI 0 or 1 it must
70# Supported protocols: 84# make sure that dev-vcs/bzr was built with USE="sftp". In EAPI 2 or
71# - http:// 85# later, the eclass will depend on dev-vcs/bzr[sftp].
72# - https:// 86
73# - sftp:// 87# @ECLASS-VARIABLE: EBZR_INITIAL_URI
74# - rsync:// 88# @DEFAULT_UNSET
75# - lp:// 89# @DESCRIPTION:
76# @CODE 90# The URI used for initial branching of the source repository. If this
91# variable is set, the initial branch will be cloned from the location
92# specified, followed by a pull from ${EBZR_REPO_URI}. This is intended
93# for special cases, e.g. when download from the original repository is
94# slow, but a fast mirror exists but may be out of date.
77# 95#
78# Note: lp = https://launchpad.net 96# Normally, this variable needs not be set.
79EBZR_REPO_URI="${EBZR_REPO_URI:-}"
80 97
81# @ECLASS-VARIABLE: EBZR_BOOTSTRAP 98# @ECLASS-VARIABLE: EBZR_BOOTSTRAP
99# @DEFAULT_UNSET
82# @DESCRIPTION: 100# @DESCRIPTION:
83# Bootstrap script or command like autogen.sh or etc. 101# Bootstrap script or command like autogen.sh or etc.
84EBZR_BOOTSTRAP="${EBZR_BOOTSTRAP:-}"
85 102
86# @ECLASS-VARIABLE: EBZR_PATCHES 103# @ECLASS-VARIABLE: EBZR_PATCHES
104# @DEFAULT_UNSET
87# @DESCRIPTION: 105# @DESCRIPTION:
88# bzr eclass can apply patches in bzr_bootstrap(). 106# bzr.eclass can apply patches in bzr_bootstrap(). You can use regular
89# you can use regexp in this valiable like *.diff or *.patch or etc. 107# expressions in this variable like *.diff or *.patch and the like.
90# NOTE: this patches will applied before EBZR_BOOTSTRAP is processed. 108# Note: These patches will be applied before EBZR_BOOTSTRAP is processed.
91# 109#
92# Patches are searched both in ${PWD} and ${FILESDIR}, if not found in either 110# Patches are searched both in ${PWD} and ${FILESDIR}. If not found in
93# location, the installation dies. 111# either location, the installation dies.
94EBZR_PATCHES="${EBZR_PATCHES:-}" 112
113# @ECLASS-VARIABLE: EBZR_PROJECT
114# @DESCRIPTION:
115# The project name of your ebuild. Normally, the branch will be stored
116# in the ${EBZR_STORE_DIR}/${EBZR_PROJECT} directory.
117#
118# If EBZR_BRANCH is set (see below), then a shared repository will be
119# created in that directory, and the branch will be located in
120# ${EBZR_STORE_DIR}/${EBZR_PROJECT}/${EBZR_BRANCH}.
121: ${EBZR_PROJECT:=${PN}}
95 122
96# @ECLASS-VARIABLE: EBZR_BRANCH 123# @ECLASS-VARIABLE: EBZR_BRANCH
124# @DEFAULT_UNSET
97# @DESCRIPTION: 125# @DESCRIPTION:
98# The branch to fetch in bzr_fetch(). 126# The directory where to store the branch within a shared repository,
127# relative to ${EBZR_STORE_DIR}/${EBZR_PROJECT}.
99# 128#
100# default: trunk 129# This variable should be set if there are several live ebuilds for
101EBZR_BRANCH="${EBZR_BRANCH:-trunk}" 130# different branches of the same upstream project. The branches can
131# then share the same repository in EBZR_PROJECT, which will save both
132# data traffic volume and disk space.
133#
134# If there is only a live ebuild for one single branch, EBZR_BRANCH
135# needs not be set. In this case, the branch will be stored in a
136# stand-alone repository directly in EBZR_PROJECT.
102 137
103# @ECLASS-VARIABLE: EBZR_REVISION 138# @ECLASS-VARIABLE: EBZR_REVISION
139# @DEFAULT_UNSET
104# @DESCRIPTION: 140# @DESCRIPTION:
105# Revision to get, if not latest (see http://bazaar-vcs.org/BzrRevisionSpec) 141# Revision to fetch, defaults to the latest
106EBZR_REVISION="${EBZR_REVISION:-}" 142# (see http://bazaar-vcs.org/BzrRevisionSpec or bzr help revisionspec).
107 143
108# @ECLASS-VARIABLE: EBZR_CACHE_DIR 144# @ECLASS-VARIABLE: EBZR_OFFLINE
109# @DESCRIPTION: 145# @DESCRIPTION:
110# The dir to store the source for the package, relative to EBZR_STORE_DIR. 146# Set this variable to a non-empty value to disable automatic updating
111# 147# of a bzr source tree. This is intended to be set outside the ebuild
112# default: ${PN} 148# by users.
113EBZR_CACHE_DIR="${EBZR_CACHE_DIR:-${PN}}" 149: ${EBZR_OFFLINE=${EVCS_OFFLINE}}
114 150
115# @FUNCTION: bzr_fetch 151# @FUNCTION: bzr_initial_fetch
152# @USAGE: <repository URI> <branch directory>
116# @DESCRIPTION: 153# @DESCRIPTION:
117# Wrapper function to fetch sources from bazaar via bzr fetch or bzr update, 154# Internal function, retrieves the source code from a repository for the
118# depending on whether there is an existing working copy in ${EBZR_BRANCH_DIR}. 155# first time, using ${EBZR_FETCH_CMD}.
119bzr_fetch() { 156bzr_initial_fetch() {
120 local EBZR_BRANCH_DIR 157 local repo_uri=$1 branch_dir=$2
121 158
122 # EBZR_REPO_URI is empty. 159 if [[ -n "${EBZR_OFFLINE}" ]]; then
123 [[ ${EBZR_REPO_URI} ]] || die "${EBZR}: EBZR_REPO_URI is empty." 160 ewarn "EBZR_OFFLINE cannot be used when there is no local branch yet."
124
125 # check for the protocol or pull from a local repo.
126 if [[ -z ${EBZR_REPO_URI%%:*} ]] ; then
127 case ${EBZR_REPO_URI%%:*} in
128 # lp:// is https://launchpad.net
129 http|https|rsync|sftp|lp)
130 ;;
131 *)
132 die "${EBZR}: fetch from ${EBZR_REPO_URI%:*} is not yet implemented."
133 ;;
134 esac
135 fi 161 fi
136 162
137 if [[ ! -d ${EBZR_STORE_DIR} ]] ; then
138 debug-print "${FUNCNAME}: initial branch. creating bzr directory"
139 addwrite /
140 mkdir -p "${EBZR_STORE_DIR}" \
141 || die "${EBZR}: can't mkdir ${EBZR_STORE_DIR}."
142 export SANDBOX_WRITE="${SANDBOX_WRITE%%:/}"
143 fi
144
145 cd -P "${EBZR_STORE_DIR}" || die "${EBZR}: can't chdir to ${EBZR_STORE_DIR}"
146
147 EBZR_BRANCH_DIR="${EBZR_STORE_DIR}/${EBZR_CACHE_DIR}"
148
149 addwrite "${EBZR_STORE_DIR}"
150 addwrite "${EBZR_BRANCH_DIR}"
151
152 debug-print "${FUNCNAME}: EBZR_OPTIONS = ${EBZR_OPTIONS}"
153
154 local repository
155
156 if [[ ${EBZR_REPO_URI} == */* ]]; then
157 repository="${EBZR_REPO_URI}${EBZR_BRANCH}"
158 else
159 repository="${EBZR_REPO_URI}"
160 fi
161
162 if [[ ! -d ${EBZR_BRANCH_DIR} ]] ; then
163 # fetch branch 163 # fetch branch
164 einfo "bzr branch start -->" 164 einfo "bzr branch start -->"
165 einfo " repository: ${repository} => ${EBZR_BRANCH_DIR}" 165 einfo " repository: ${repo_uri} => ${branch_dir}"
166 166
167 ${EBZR_FETCH_CMD} ${EBZR_OPTIONS} "${repository}" "${EBZR_BRANCH_DIR}" \ 167 ${EBZR_FETCH_CMD} ${EBZR_OPTIONS} "${repo_uri}" "${branch_dir}" \
168 || die "${EBZR}: can't branch from ${repository}." 168 || die "${EBZR}: can't branch from ${repo_uri}"
169}
169 170
171# @FUNCTION: bzr_update
172# @USAGE: <repository URI> <branch directory>
173# @DESCRIPTION:
174# Internal function, updates the source code from a repository, using
175# ${EBZR_UPDATE_CMD}.
176bzr_update() {
177 local repo_uri=$1 branch_dir=$2
178
179 if [[ -n "${EBZR_OFFLINE}" ]]; then
180 einfo "skipping bzr pull -->"
181 einfo " repository: ${repo_uri}"
170 else 182 else
171 # update branch 183 # update branch
172 einfo "bzr pull start -->" 184 einfo "bzr pull start -->"
173 einfo " repository: ${repository}" 185 einfo " repository: ${repo_uri}"
174 186
175 cd "${EBZR_BRANCH_DIR}" 187 pushd "${branch_dir}" > /dev/null \
188 || die "${EBZR}: can't chdir to ${branch_dir}"
176 ${EBZR_UPDATE_CMD} ${EBZR_OPTIONS} "${repository}" \ 189 ${EBZR_UPDATE_CMD} ${EBZR_OPTIONS} "${repo_uri}" \
177 || die "${EBZR}: can't merge from ${repository}." 190 || die "${EBZR}: can't pull from ${repo_uri}"
178 ${EBZR_DIFFSTAT_CMD} 191 popd > /dev/null
192 fi
193}
194
195# @FUNCTION: bzr_fetch
196# @DESCRIPTION:
197# Wrapper function to fetch sources from a Bazaar repository with
198# bzr branch or bzr pull, depending on whether there is an existing
199# working copy.
200bzr_fetch() {
201 local repo_dir branch_dir
202
203 [[ -n ${EBZR_REPO_URI} ]] || die "${EBZR}: EBZR_REPO_URI is empty"
204
205 if [[ ! -d ${EBZR_STORE_DIR} ]] ; then
206 local save_sandbox_write=${SANDBOX_WRITE}
207 addwrite /
208 mkdir -p "${EBZR_STORE_DIR}" \
209 || die "${EBZR}: can't mkdir ${EBZR_STORE_DIR}"
210 SANDBOX_WRITE=${save_sandbox_write}
211 fi
212
213 pushd "${EBZR_STORE_DIR}" > /dev/null \
214 || die "${EBZR}: can't chdir to ${EBZR_STORE_DIR}"
215
216 repo_dir=${EBZR_STORE_DIR}/${EBZR_PROJECT}
217 branch_dir=${repo_dir}${EBZR_BRANCH:+/${EBZR_BRANCH}}
218
219 addwrite "${EBZR_STORE_DIR}"
220
221 # Clean up if the existing local copy is a checkout (as was the case
222 # with an older version of bzr.eclass).
223 # This test can be removed after 1 Mar 2012.
224 if [[ ${EBZR_FETCH_CMD} != *checkout* && -d ${repo_dir}/.bzr/checkout ]]
225 then
226 local tmpname=$(mktemp -u "${repo_dir}._old_.XXXXXX")
227 ewarn "checkout from old version of ${EBZR} found, moving it to:"
228 ewarn "${tmpname}"
229 ewarn "you may manually remove it"
230 mv "${repo_dir}" "${tmpname}" \
231 || die "${EBZR}: can't move old checkout out of the way"
232 fi
233
234 if [[ ! -d ${branch_dir}/.bzr ]]; then
235 if [[ ${repo_dir} != "${branch_dir}" && ! -d ${repo_dir}/.bzr ]]; then
236 einfo "creating shared bzr repository"
237 ${EBZR_INIT_REPO_CMD} "${repo_dir}" \
238 || die "${EBZR}: can't create shared repository"
179 fi 239 fi
180 240
181 cd "${EBZR_BRANCH_DIR}" 241 if [[ -z ${EBZR_INITIAL_URI} ]]; then
242 bzr_initial_fetch "${EBZR_REPO_URI}" "${branch_dir}"
243 else
244 # Workaround for faster initial download. This clones the
245 # branch from a fast server (which may be out of date), and
246 # subsequently pulls from the slow original repository.
247 bzr_initial_fetch "${EBZR_INITIAL_URI}" "${branch_dir}"
248 if [[ ${EBZR_REPO_URI} != "${EBZR_INITIAL_URI}" ]]; then
249 EBZR_UPDATE_CMD="${EBZR_UPDATE_CMD} --remember --overwrite" \
250 EBZR_OFFLINE="" \
251 bzr_update "${EBZR_REPO_URI}" "${branch_dir}"
252 fi
253 fi
254 else
255 bzr_update "${EBZR_REPO_URI}" "${branch_dir}"
256 fi
257
258 cd "${branch_dir}" || die "${EBZR}: can't chdir to ${branch_dir}"
259
260 # Save revision number in environment. #311101
261 export EBZR_REVNO=$(${EBZR_REVNO_CMD})
182 262
183 einfo "exporting ..." 263 einfo "exporting ..."
184 ${EBZR_EXPORT_CMD} ${EBZR_REVISION:+-r ${EBZR_REVISION}} "${WORKDIR}/${P}" \ 264 ${EBZR_EXPORT_CMD} ${EBZR_REVISION:+-r ${EBZR_REVISION}} \
185 || die "${EBZR}: export failed" 265 "${WORKDIR}/${P}" . || die "${EBZR}: export failed"
266 einfo "revision ${EBZR_REVISION:-${EBZR_REVNO}} is now in ${WORKDIR}/${P}"
186 267
187 local revision 268 popd > /dev/null
188 if [[ -n "${EBZR_REVISION}" ]]; then
189 revision="${EBZR_REVISION}"
190 else
191 revision=$(${EBZR_REVNO_CMD} "${EBZR_BRANCH_DIR}")
192 fi
193
194 einfo "Revision ${revision} is now in ${WORKDIR}/${P}"
195
196 cd "${WORKDIR}"
197} 269}
198 270
199# @FUNCTION: bzr_bootstrap 271# @FUNCTION: bzr_bootstrap
200# @DESCRIPTION: 272# @DESCRIPTION:
201# Apply patches in ${EBZR_PATCHES} and run ${EBZR_BOOTSTRAP} if specified 273# Apply patches in ${EBZR_PATCHES} and run ${EBZR_BOOTSTRAP} if specified.
202bzr_bootstrap() { 274bzr_bootstrap() {
203 local patch lpatch 275 local patch lpatch
204 276
205 cd "${S}" 277 pushd "${S}" > /dev/null || die "${EBZR}: can't chdir to ${S}"
206 278
207 if [[ -n ${EBZR_PATCHES} ]] ; then 279 if [[ -n ${EBZR_PATCHES} ]] ; then
208 einfo "apply patches -->" 280 einfo "apply patches -->"
209 281
210 for patch in ${EBZR_PATCHES} ; do 282 for patch in ${EBZR_PATCHES} ; do
211 if [[ -f ${patch} ]] ; then 283 if [[ -f ${patch} ]] ; then
212 epatch ${patch} 284 epatch ${patch}
213 else 285 else
286 # This loop takes care of wildcarded patches given via
287 # EBZR_PATCHES in an ebuild
214 for lpatch in "${FILESDIR}"/${patch} ; do 288 for lpatch in "${FILESDIR}"/${patch} ; do
215 if [[ -f ${lpatch} ]] ; then 289 if [[ -f ${lpatch} ]] ; then
216 epatch ${lpatch} 290 epatch ${lpatch}
217 else 291 else
218 die "${EBZR}: ${patch} is not found" 292 die "${EBZR}: ${patch} is not found"
226 einfo "begin bootstrap -->" 300 einfo "begin bootstrap -->"
227 301
228 if [[ -f ${EBZR_BOOTSTRAP} ]] && [[ -x ${EBZR_BOOTSTRAP} ]] ; then 302 if [[ -f ${EBZR_BOOTSTRAP} ]] && [[ -x ${EBZR_BOOTSTRAP} ]] ; then
229 einfo " bootstrap with a file: ${EBZR_BOOTSTRAP}" 303 einfo " bootstrap with a file: ${EBZR_BOOTSTRAP}"
230 "./${EBZR_BOOTSTRAP}" \ 304 "./${EBZR_BOOTSTRAP}" \
231 || die "${EBZR}: can't execute EBZR_BOOTSTRAP." 305 || die "${EBZR}: can't execute EBZR_BOOTSTRAP"
232 else 306 else
233 einfo " bootstrap with commands: ${EBZR_BOOTSTRAP}" 307 einfo " bootstrap with commands: ${EBZR_BOOTSTRAP}"
234 "${EBZR_BOOTSTRAP}" \ 308 "${EBZR_BOOTSTRAP}" \
235 || die "${EBZR}: can't eval EBZR_BOOTSTRAP." 309 || die "${EBZR}: can't eval EBZR_BOOTSTRAP"
236 fi 310 fi
237 fi 311 fi
312
313 popd > /dev/null
238} 314}
239 315
240# @FUNCTION: bzr_src_unpack 316# @FUNCTION: bzr_src_unpack
241# @DESCRIPTION: 317# @DESCRIPTION:
242# default src_unpack. fetch and bootstrap. 318# Default src_unpack(), calls bzr_fetch. For EAPIs 0 and 1, also calls
319# bzr_src_prepare.
243bzr_src_unpack() { 320bzr_src_unpack() {
244 bzr_fetch || die "${EBZR}: unknown problem in bzr_fetch()." 321 bzr_fetch
245 bzr_bootstrap || die "${EBZR}: unknown problem in bzr_bootstrap()." 322 case "${EAPI:-0}" in
323 0|1) bzr_src_prepare ;;
324 esac
246} 325}
326
327# @FUNCTION: bzr_src_prepare
328# @DESCRIPTION:
329# Default src_prepare(), calls bzr_bootstrap.
330bzr_src_prepare() {
331 bzr_bootstrap
332}

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.16

  ViewVC Help
Powered by ViewVC 1.1.20