blob: 38ff37233cab40090cfa11e1eb66fc4ac28f6659 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
|
# Copyright 1999-2011 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/sys-apps/paludis/paludis-0.64.0.ebuild,v 1.1 2011/06/20 17:04:02 dagger Exp $
inherit bash-completion eutils
DESCRIPTION="paludis, the other package mangler"
HOMEPAGE="http://paludis.pioto.org/"
SRC_URI="http://paludis.pioto.org/download/${P}.tar.bz2"
IUSE="doc pbins portage pink prebuilt-documentation python-bindings ruby-bindings search-index vim-syntax visibility xml zsh-completion"
LICENSE="GPL-2 vim-syntax? ( vim )"
SLOT="0"
KEYWORDS="~alpha ~amd64 ~arm ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sparc ~x86"
COMMON_DEPEND="
>=app-admin/eselect-1.2.13
>=app-shells/bash-3.2
>=sys-devel/gcc-4.4
dev-libs/libpcre
sys-apps/file
pbins? ( >=app-arch/libarchive-2.8.4 )
python-bindings? ( >=dev-lang/python-2.6 >=dev-libs/boost-1.41.0 )
ruby-bindings? ( >=dev-lang/ruby-1.8 )
xml? ( >=dev-libs/libxml2-2.6 )
search-index? ( >=dev-db/sqlite-3 )"
DEPEND="${COMMON_DEPEND}
!prebuilt-documentation? (
>=app-text/asciidoc-8.6.3
app-text/xmlto
)
doc? (
|| ( >=app-doc/doxygen-1.5.3 <=app-doc/doxygen-1.5.1 )
media-gfx/imagemagick
python-bindings? ( dev-python/epydoc dev-python/pygments )
ruby-bindings? ( dev-ruby/syntax dev-ruby/allison )
)
dev-util/pkgconfig
dev-util/gtest"
RDEPEND="${COMMON_DEPEND}
sys-apps/sandbox"
# Keep syntax as a PDEPEND. It avoids issues when Paludis is used as the
# default virtual/portage provider.
PDEPEND="
vim-syntax? ( >=app-editors/vim-core-7 )
app-admin/eselect-package-manager"
create-paludis-user() {
enewgroup "paludisbuild"
enewuser "paludisbuild" -1 -1 "/var/tmp/paludis" "paludisbuild,tty"
}
pkg_setup() {
if ! built_with_use dev-libs/libpcre cxx ; then
eerror "Paludis needs dev-libs/libpcre built with C++ support"
eerror "Please build dev-libs/libpcre with USE=cxx support"
die "Rebuild dev-libs/libpcre with USE=cxx"
fi
if ! built_with_use dev-util/gtest threads ; then
eerror "Paludis needs dev-util/gtest built with threads support"
eerror "Please build dev-util/gtest with USE=threads support"
die "Rebuild dev-util/gtest with USE threads"
fi
if use python-bindings && \
! built_with_use --missing true dev-libs/boost python; then
eerror "With USE python-bindings you need boost build with the python"
eerror "use flag."
die "Rebuild dev-libs/boost with USE python"
fi
if use pbins && \
built_with_use app-arch/libarchive xattr; then
eerror "With USE pbins you need libarchive build without the xattr"
eerror "use flag."
die "Rebuild app-arch/libarchive without USE xattr"
fi
if id paludisbuild >/dev/null 2>/dev/null ; then
if ! groups paludisbuild | grep --quiet '\<tty\>' ; then
eerror "The 'paludisbuild' user is now expected to be a member of the"
eerror "'tty' group. You should add the user to this group before"
eerror "upgrading Paludis."
die "Please add paludisbuild to tty group"
fi
fi
create-paludis-user
# 'paludis' tries to exec() itself after an upgrade
if [[ "${PKGMANAGER}" == paludis-0.[012345]* ]] && [[ -z "${CAVE}" ]] ; then
eerror "The 'paludis' client has been removed in Paludis 0.60. You must use"
eerror "'cave' to upgrade."
die "Can't use 'paludis' to upgrade Paludis"
fi
}
src_compile() {
local repositories=`echo default unavailable unpackaged | tr -s \ ,`
local environments=`echo default $(usev portage ) | tr -s \ ,`
econf \
$(use_enable doc doxygen ) \
$(use_enable pbins ) \
$(use_enable pink ) \
$(use_enable ruby-bindings ruby ) \
$(useq ruby-bindings && useq doc && echo --enable-ruby-doc ) \
$(use_enable prebuilt-documentation ) \
$(use_enable python-bindings python ) \
$(useq python-bindings && useq doc && echo --enable-python-doc ) \
$(use_enable vim-syntax vim ) \
$(use_enable visibility ) \
$(use_enable xml ) \
$(use_enable search-index ) \
--with-vim-install-dir=/usr/share/vim/vimfiles \
--with-repositories=${repositories} \
--with-environments=${environments} \
|| die "econf failed"
emake || die "emake failed"
}
src_install() {
emake DESTDIR="${D}" install || die "install failed"
dodoc AUTHORS README NEWS
BASHCOMPLETION_NAME="cave" dobashcompletion bash-completion/cave
if use zsh-completion ; then
insinto /usr/share/zsh/site-functions
doins zsh-completion/_cave
fi
}
src_test() {
# Work around Portage bugs
export PALUDIS_DO_NOTHING_SANDBOXY="portage sucks"
export BASH_ENV=/dev/null
if [[ `id -u` == 0 ]] ; then
# hate
export PALUDIS_REDUCED_UID=0
export PALUDIS_REDUCED_GID=0
fi
if ! emake check ; then
eerror "Tests failed. Looking for files for you to add to your bug report..."
find "${S}" -type f -name '*.epicfail' -or -name '*.log' | while read a ; do
eerror " $a"
done
die "Make check failed"
fi
}
pkg_postinst() {
pm_is_paludis=false
if [[ -f ${ROOT}/etc/env.d/50package-manager ]] ; then
pm_is_paludis=$( source ${ROOT}/etc/env.d/50package-manager ; [[ ${PACKAGE_MANAGER} == paludis ]] && echo true || echo false )
fi
if ! $pm_is_paludis ; then
elog "If you are using paludis or cave as your primary package manager,"
elog "you should consider running:"
elog " eselect package-manager set paludis"
fi
}
|