blob: 211e913b475857f3c85b4b1fa12c1580dd2882af (
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
|
# Copyright 1999-2016 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Id$
EAPI=5
EGIT_REPO_URI='https://git.exherbo.org/paludis/paludis.git'
PYTHON_COMPAT=( python2_7 )
# matching profile defaults for now
RUBY_VER=2.1
inherit autotools bash-completion-r1 eutils git-r3 python-single-r1 user
DESCRIPTION="paludis, the other package mangler"
HOMEPAGE="http://paludis.exherbo.org/"
SRC_URI=""
IUSE="doc pbins pink python ruby search-index test +xml"
LICENSE="GPL-2 vim"
SLOT="0"
KEYWORDS=""
COMMON_DEPEND="
>=app-admin/eselect-1.2.13
>=app-shells/bash-3.2:0
dev-libs/libpcre[cxx]
sys-apps/file
pbins? ( >=app-arch/libarchive-3.1.2 )
python? (
${PYTHON_DEPS}
>=dev-libs/boost-1.41.0[python,${PYTHON_USEDEP}] )
ruby? ( dev-lang/ruby:${RUBY_VER} )
search-index? ( >=dev-db/sqlite-3 )
xml? ( >=dev-libs/libxml2-2.6 )"
DEPEND="${COMMON_DEPEND}
>=app-text/asciidoc-8.6.3
app-text/htmltidy
app-text/xmlto
>=sys-devel/gcc-4.7
doc? (
app-doc/doxygen
python? ( dev-python/sphinx[${PYTHON_USEDEP}] )
ruby? ( dev-ruby/syntax[ruby_targets_ruby${RUBY_VER/./}] )
)
virtual/pkgconfig
test? ( >=dev-cpp/gtest-1.6.0-r1 )"
RDEPEND="${COMMON_DEPEND}
sys-apps/sandbox"
PDEPEND="app-eselect/eselect-package-manager"
REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )"
RESTRICT="!test? ( test )"
pkg_pretend() {
if [[ ${MERGE_TYPE} != buildonly ]]; then
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
fi
}
pkg_setup() {
enewgroup "paludisbuild"
enewuser "paludisbuild" -1 -1 "/var/tmp/paludis" "paludisbuild,tty"
use python && python-single-r1_pkg_setup
}
src_prepare() {
# Fix the script shebang on Ruby scripts.
# https://bugs.gentoo.org/show_bug.cgi?id=439372#c2
sed -i -e "1s/ruby/&${RUBY_VER/./}/" ruby/demos/*.rb || die
./autotools_prepare.bash || die
eautoreconf
epatch_user
}
src_configure() {
local myconf=(
--htmldir=/usr/share/doc/${PF}/html
$(use_enable doc doxygen)
$(use_enable test gtest)
$(use_enable pbins)
$(use_enable pink)
$(use_enable python)
$(use python && use_enable doc python-doc)
$(use_enable ruby)
$(use ruby && use_enable doc ruby-doc)
--with-ruby-version="${RUBY_VER}"
$(use_enable search-index)
$(use_enable xml)
--enable-vim
--with-config-framework=eselect
--with-environments=default,portage
--with-vim-install-dir=/usr/share/vim/vimfiles
)
econf "${myconf[@]}"
}
src_install() {
default
prune_libtool_files
dobashcomp bash-completion/cave
insinto /usr/share/zsh/site-functions
doins zsh-completion/_cave
}
src_test() {
# Work around Portage bugs
local -x PALUDIS_DO_NOTHING_SANDBOXY="portage sucks"
local -x BASH_ENV=/dev/null
if [[ ${EUID} == 0 ]] ; then
# hate
local -x PALUDIS_REDUCED_UID=0
local -x PALUDIS_REDUCED_GID=0
fi
if ! nonfatal emake -k 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() {
local pm
if [[ -f ${ROOT}/etc/env.d/50package-manager ]] ; then
pm=$( source "${ROOT}"/etc/env.d/50package-manager ; echo "${PACKAGE_MANAGER}" )
fi
if [[ ${pm} != 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
}
|