Gentoo Archives: gentoo-commits

From: Pacho Ramos <pacho@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: net-wireless/bluez/
Date: Thu, 31 Dec 2015 12:36:28
Message-Id: 1451565363.83b56c7f8e066f0c65e4b1226764307b6cdaa1e7.pacho@gentoo
1 commit: 83b56c7f8e066f0c65e4b1226764307b6cdaa1e7
2 Author: Pacho Ramos <pacho <AT> gentoo <DOT> org>
3 AuthorDate: Thu Dec 31 12:34:12 2015 +0000
4 Commit: Pacho Ramos <pacho <AT> gentoo <DOT> org>
5 CommitDate: Thu Dec 31 12:36:03 2015 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=83b56c7f
7
8 net-wireless/bluez: Version bump. Add a extra-tools USE flag to install tools upstream doesn't officially support and that doesn't want to be installed by default.
9
10 Package-Manager: portage-2.2.26
11
12 net-wireless/bluez/Manifest | 1 +
13 net-wireless/bluez/bluez-5.37.ebuild | 231 +++++++++++++++++++++++++++++++++++
14 net-wireless/bluez/metadata.xml | 4 +
15 3 files changed, 236 insertions(+)
16
17 diff --git a/net-wireless/bluez/Manifest b/net-wireless/bluez/Manifest
18 index af8c3cc..d40aa9e 100644
19 --- a/net-wireless/bluez/Manifest
20 +++ b/net-wireless/bluez/Manifest
21 @@ -4,3 +4,4 @@ DIST bluez-5.33.tar.xz 1636808 SHA256 1801807a13506678cbfeb15c6a4b89ecb5739efe10
22 DIST bluez-5.34.tar.xz 1640772 SHA256 e461ec2927f5491a202de4a180b2b42377f596b0ce372430d8204ae042d3b19c SHA512 9735c95dd2a7d4c51168aed622604efeaf820bc4c99615c4ab2a4b153cb650e0d82e24d09c96d7e1f15e3bc6aa61e83b49c90e8cff200d9b4d0b144a4e6138b8 WHIRLPOOL 2f4364a2a3feb7e9e23761ff1e3ac153772ab39403702b4f850e473153ec12f981fae7235ab14120d46d48007af751dd66d344b52e7d9dad1aef7b309c40605c
23 DIST bluez-5.35.tar.xz 1643068 SHA256 1afee054644a8b1753ac98d7ad5cd95681a38f5c4cbb1b4bb3ceaa078bf8f0e2 SHA512 33850a01e135f14015295f0eb9b578c515d180d24441b89dff545ec7c0ce8dad5fa321e20918ed6285edaa386375b4ed5688cb17bbfaf4db0742f6d6a72eec6d WHIRLPOOL e334e0e9b37f823eb348cf1679e010567893a73941533a5dc12b598f3b3c845d82f15b3b79e106a7fc4c4344a204a2205fa96509e61d7e61b6ec9f413d650356
24 DIST bluez-5.36.tar.xz 1649088 SHA256 a343ea1aeb53d3bd139087f3b1c1e1fb70db452d9762cc7a3d23e75962e578f2 SHA512 2cff79533d052d5b718101d31093cce34849dd316a41597384d0e777679ca96d83537f0cf7a5d7a1d5919c8f2afdd7164536b104cba616dde230e774c55774c3 WHIRLPOOL b2977103d7b5fa0a2284ba41f2213c402455b119f81f8a9c0d4c267c1ec8cac00cc8453c0107f158cd49f897376d7258905e72cde0b52dd0674278477d33b586
25 +DIST bluez-5.37.tar.xz 1657760 SHA256 c14ba9ddcb0055522073477b8fd8bf1ddf5d219e75fdfd4699b7e0ce5350d6b0 SHA512 e9af3b1dd079185425db10630fefbb66c26f398f21edb0c213baba9599f73715ca36f405a3f9d9572e6c55b7d3d25a4cdc18668c6eb439422f637e64798a28e9 WHIRLPOOL 1697a379d944978193db51a50c19a10fb27aa4e57ee9793563ba59b25de6388dfb4847c1a851fe1467d2521f14b2b9655208b8cef0cd5e44604bc0b26beb0c2b
26
27 diff --git a/net-wireless/bluez/bluez-5.37.ebuild b/net-wireless/bluez/bluez-5.37.ebuild
28 new file mode 100644
29 index 0000000..37f3102
30 --- /dev/null
31 +++ b/net-wireless/bluez/bluez-5.37.ebuild
32 @@ -0,0 +1,231 @@
33 +# Copyright 1999-2015 Gentoo Foundation
34 +# Distributed under the terms of the GNU General Public License v2
35 +# $Id$
36 +
37 +EAPI=5
38 +PYTHON_COMPAT=( python2_7 )
39 +
40 +inherit autotools eutils multilib python-single-r1 readme.gentoo systemd udev user multilib-minimal
41 +
42 +DESCRIPTION="Bluetooth Tools and System Daemons for Linux"
43 +HOMEPAGE="http://www.bluez.org"
44 +SRC_URI="mirror://kernel/linux/bluetooth/${P}.tar.xz"
45 +
46 +LICENSE="GPL-2+ LGPL-2.1+"
47 +SLOT="0/3"
48 +KEYWORDS="~amd64 ~arm ~hppa ~mips ~ppc ~ppc64 ~x86"
49 +IUSE="cups doc debug extra-tools +obex +readline selinux systemd test test-programs +udev"
50 +REQUIRED_USE="test? ( ${PYTHON_REQUIRED_USE} ) test-programs? ( ${PYTHON_REQUIRED_USE} )"
51 +
52 +CDEPEND="
53 + >=dev-libs/glib-2.28:2
54 + >=sys-apps/dbus-1.6:=
55 + >=sys-apps/hwids-20121202.2
56 + cups? ( net-print/cups:= )
57 + obex? ( dev-libs/libical:= )
58 + readline? ( sys-libs/readline:= )
59 + systemd? ( sys-apps/systemd )
60 + udev? ( >=virtual/udev-172 )
61 + abi_x86_32? (
62 + !<app-emulation/emul-linux-x86-soundlibs-20140406-r1
63 + !app-emulation/emul-linux-x86-soundlibs[-abi_x86_32]
64 + )
65 +"
66 +TEST_DEPS="${PYTHON_DEPS}
67 + >=dev-python/dbus-python-1[${PYTHON_USEDEP}]
68 + || (
69 + dev-python/pygobject:3[${PYTHON_USEDEP}]
70 + dev-python/pygobject:2[${PYTHON_USEDEP}]
71 + )
72 +"
73 +
74 +DEPEND="${CDEPEND}
75 + app-arch/xz-utils
76 + virtual/pkgconfig
77 + test? (
78 + ${TEST_DEPS}
79 + )
80 +"
81 +RDEPEND="${CDEPEND}
82 + selinux? ( sec-policy/selinux-bluetooth )
83 + test-programs? ( ${TEST_DEPS} )
84 +"
85 +DOC_CONTENTS="
86 + If you want to use rfcomm as a normal user, you need to add the user
87 + to the uucp group.
88 +"
89 +
90 +pkg_setup() {
91 + enewgroup plugdev
92 +
93 + if use test || use test-programs; then
94 + python-single-r1_pkg_setup
95 + fi
96 +
97 + if ! use udev; then
98 + ewarn
99 + ewarn "You are installing ${PN} with USE=-udev. This means various bluetooth"
100 + ewarn "devices and adapters from Apple, Dell, Logitech etc. will not work,"
101 + ewarn "and hid2hci will not be available."
102 + ewarn
103 + fi
104 +}
105 +
106 +src_prepare() {
107 + # Use static group "plugdev" if there is no ConsoleKit (or systemd logind)
108 + epatch "${FILESDIR}"/bluez-plugdev.patch
109 +
110 + # Try both udevadm paths to cover udev/systemd vs. eudev locations (#539844)
111 + # http://www.spinics.net/lists/linux-bluetooth/msg58739.html
112 + epatch "${FILESDIR}"/bluez-udevadm-path.patch
113 +
114 + # Fedora patches
115 + # http://www.spinics.net/lists/linux-bluetooth/msg38490.html
116 + epatch "${FILESDIR}"/0001-Allow-using-obexd-without-systemd-in-the-user-sessio.patch
117 +
118 + # http://www.spinics.net/lists/linux-bluetooth/msg40136.html
119 + epatch "${FILESDIR}"/0001-obex-Use-GLib-helper-function-to-manipulate-paths.patch
120 +
121 + # http://www.spinics.net/lists/linux-bluetooth/msg41264.html
122 + epatch "${FILESDIR}"/0002-autopair-Don-t-handle-the-iCade.patch
123 +
124 + # ???
125 + epatch "${FILESDIR}"/0004-agent-Assert-possible-infinite-loop.patch
126 +
127 + if use cups; then
128 + sed -i \
129 + -e "s:cupsdir = \$(libdir)/cups:cupsdir = $(cups-config --serverbin):" \
130 + Makefile.{in,tools} || die
131 + fi
132 +
133 + eautoreconf
134 +
135 + multilib_copy_sources
136 +}
137 +
138 +multilib_src_configure() {
139 + local myconf=(
140 + # readline is automagic when client is enabled
141 + # --enable-client always needs readline, bug #504038
142 + ac_cv_header_readline_readline_h=$(multilib_native_usex readline)
143 + )
144 +
145 + if ! multilib_is_native_abi; then
146 + myconf+=(
147 + # deps not used for the library
148 + {DBUS,GLIB}_{CFLAGS,LIBS}=' '
149 + )
150 + fi
151 +
152 + econf \
153 + --localstatedir=/var \
154 + --disable-android \
155 + --enable-datafiles \
156 + --enable-experimental \
157 + --enable-optimization \
158 + $(use_enable debug) \
159 + --enable-pie \
160 + --enable-threads \
161 + --enable-library \
162 + --enable-tools \
163 + --enable-manpages \
164 + --enable-monitor \
165 + $(multilib_native_use_enable cups) \
166 + $(multilib_native_use_enable obex) \
167 + $(multilib_native_use_enable readline client) \
168 + $(multilib_native_use_enable systemd) \
169 + $(multilib_native_use_enable test-programs test) \
170 + $(systemd_with_unitdir) \
171 + $(multilib_native_use_enable udev) \
172 + $(multilib_native_use_enable udev sixaxis)
173 +}
174 +
175 +multilib_src_compile() {
176 + if multilib_is_native_abi; then
177 + default
178 + else
179 + emake -f Makefile -f - libs \
180 + <<<'libs: $(lib_LTLIBRARIES)'
181 + fi
182 +}
183 +
184 +multilib_src_test() {
185 + multilib_is_native_abi && default
186 +}
187 +
188 +multilib_src_install() {
189 + if multilib_is_native_abi; then
190 + emake DESTDIR="${D}" install
191 +
192 + # Only install extra-tools when relevant USE flag is enabled
193 + if use extra-tools; then
194 + ewarn "Upstream doesn't support using this tools and their bugs are"
195 + ewarn "likely to be ignored forever, also that tools can break"
196 + ewarn "without previous announcement."
197 + ewarn "Upstream also states all this tools are not really needed,"
198 + ewarn "then, if you still need to rely on them, you must ask them"
199 + ewarn "to either install that tool by default or add the needed"
200 + ewarn "functionality to the existing 'official' tools."
201 + ewarn "Please report this issues to:"
202 + ewarn "http://www.bluez.org/development/lists/"
203 +
204 + # Upstream doesn't install this, bug #524640
205 + # http://permalink.gmane.org/gmane.linux.bluez.kernel/53115
206 + # http://comments.gmane.org/gmane.linux.bluez.kernel/54564
207 + # gatttool is only built with readline, bug #530776
208 + if use readline; then
209 + dobin attrib/gatttool
210 + dobin tools/btmgmt
211 + fi
212 + dobin tools/hex2hcd
213 + fi
214 +
215 + # Unittests are not that useful once installed, so make them optional
216 + if use test-programs; then
217 + python_fix_shebang "${ED}"/usr/$(get_libdir)/bluez/test
218 + for i in $(find "${ED}"/usr/$(get_libdir)/bluez/test -maxdepth 1 -type f ! -name "*.*"); do
219 + dosym "${i}" /usr/bin/bluez-"${i##*/}"
220 + done
221 + fi
222 + else
223 + emake DESTDIR="${D}" \
224 + install-includeHEADERS \
225 + install-libLTLIBRARIES \
226 + install-pkgconfigDATA
227 + fi
228 +}
229 +
230 +multilib_src_install_all() {
231 + prune_libtool_files --modules
232 +
233 + keepdir /var/lib/bluetooth
234 +
235 + # Upstream don't want people to play with them
236 + # But we keep installing them due to 'historical' reasons
237 + insinto /etc/bluetooth
238 + local d
239 + for d in input network proximity; do
240 + doins profiles/${d}/${d}.conf
241 + done
242 + doins src/main.conf
243 +
244 + newinitd "${FILESDIR}"/bluetooth-init.d-r3 bluetooth
245 + newinitd "${FILESDIR}"/rfcomm-init.d-r2 rfcomm
246 +
247 + einstalldocs
248 + use doc && dodoc doc/*.txt
249 + readme.gentoo_create_doc
250 +}
251 +
252 +pkg_postinst() {
253 + readme.gentoo_print_elog
254 +
255 + use udev && udev_reload
256 +
257 + has_version net-dialup/ppp || elog "To use dial up networking you must install net-dialup/ppp."
258 +
259 + if ! has_version sys-auth/consolekit && ! has_version sys-apps/systemd; then
260 + elog "Since you don't have sys-auth/consolekit neither sys-apps/systemd, you will"
261 + elog "need to add the user to the plugdev group."
262 + fi
263 +}
264
265 diff --git a/net-wireless/bluez/metadata.xml b/net-wireless/bluez/metadata.xml
266 index de19c8b..ec7178e 100644
267 --- a/net-wireless/bluez/metadata.xml
268 +++ b/net-wireless/bluez/metadata.xml
269 @@ -6,6 +6,10 @@
270 <name>Pacho Ramos</name>
271 </maintainer>
272 <use>
273 + <flag name="extra-tools">Install tools that upstream doesn't install on
274 + purpose by default. All this tools shouldn't be used. Then, please
275 + notify upstream about you still need them to let them know the
276 + situation.</flag>
277 <flag name="test-programs">Install tools for testing of
278 various Bluetooth functions</flag>
279 <flag name="hid2hci">The HID proxying makes the keyboard / mouse show up