commit:     18ce84572fcf18fe9841d9536582d47aa78d772c
Author:     Jory A. Pratt <anarchy <AT> gentoo <DOT> org>
AuthorDate: Fri Aug 25 12:35:40 2017 +0000
Commit:     Jory Pratt <anarchy <AT> gentoo <DOT> org>
CommitDate: Fri Aug 25 12:35:40 2017 +0000
URL:        https://gitweb.gentoo.org/proj/musl.git/commit/?id=18ce8457

net-misc/networkmanager - musl support is here

 net-misc/networkmanager/Manifest                   |   8 +
 .../files/0001-Support-musl-libc.patch             | 108 +++++++
 ...top.NetworkManager.settings.modify.system.rules |   7 +
 net-misc/networkmanager/files/10-openrc-status-r4  |  35 +++
 .../networkmanager/files/conf.d.NetworkManager     |   4 +
 .../networkmanager/files/init.d.NetworkManager-r1  |  58 ++++
 net-misc/networkmanager/metadata.xml               |  38 +++
 .../networkmanager/networkmanager-1.8.2.ebuild     | 331 +++++++++++++++++++++
 8 files changed, 589 insertions(+)

diff --git a/net-misc/networkmanager/Manifest b/net-misc/networkmanager/Manifest
new file mode 100644
index 0000000..5a57c26
--- /dev/null
+++ b/net-misc/networkmanager/Manifest
@@ -0,0 +1,8 @@
+AUX 0001-Support-musl-libc.patch 3238 SHA256 
8b01890c7bd0267106c8c55f1e900f43a59704707441f9a4e407eb00dd4134a2 SHA512 
557464b1f7a0ec729d7a9b604ccc7671881db25bc683a6a68a535b9f076a80408be913e8d5890e4fba7c72df4b6c60aeca424d3df184d2a1d7ceb3ac314b6b6c
 WHIRLPOOL 
755f01472816ed5c5009a7614b31f835c78190eadc6e8add27f576c9b373578cc014454e368824154d2f5234480dd153177562a42693759fe3bb1839093c9cb0
+AUX 01-org.freedesktop.NetworkManager.settings.modify.system.rules 265 SHA256 
702e1e702ec633608fd75dfd44f66437896421c9d2d7fe9966df8e4ef1d93a6c SHA512 
22dfa5b071891ba16b9a8b90a1964d56e370cb640d78191934ae802e568f92c299b9d4d965f7081fb36a8c09378bfb0b33193b2332cbdc28c6799b152128c214
 WHIRLPOOL 
b89a4069cc973cf55001a5f0028c75a90ce4ea070c4424b5a22f3e9b8e61ee34ff7b06891eb1c6f8fa24735b3e5d98e61f0bfefca7dd12eeb615b83e72225c8b
+AUX 10-openrc-status-r4 1182 SHA256 
f8ed424818b866a0bf882c569f4484e8b1485ce7ac8c472f060fd877f2dcfe65 SHA512 
b1f0cd7eaeb13af9ab1ce192fd3f47e52d505c4ad5a0888af1ad2598701a034231c03f5346441f44443daca84f2089cb68e08c2876396be0e668c484c3d331ec
 WHIRLPOOL 
c71c923c293730894a660c8db3371fee2697666388f49947ecc2508b18a0a0d16a72643f34e8a1dadb559743ea1b56a34d3abfd95bced85dc0d753a33d661fb8
+AUX conf.d.NetworkManager 230 SHA256 
4594573f01fe5e04b6dde4525796acf909158591bdcefd662ec23fe0d1c3e1bd SHA512 
f8c9331834cbc66ab0e4e6f4a120fde6a08a435d680a1e1087718fdbb2b9843a313e7ec30b7008822999dafd98e152aa7d2a96f87320ba9c91c3adb63e0b7c9a
 WHIRLPOOL 
7dbb15bf184e918369187605af91816ed11c460147066ede11f200d73103bb6f7f63ccc7abe7996d485294f44282d6bbd9520cc9e50f04ce41262c9817f7b994
+AUX init.d.NetworkManager-r1 1822 SHA256 
861445d46e8863dca26a91018da3dd9fee6a64467a93e7512774dfd88914539d SHA512 
a8356480592ec5e818b390b83cb258248d64850748e9e485bed68befabf067219d02fda137ee63684e0cd2c0e4f5fca30f94f8db71f811149183ff4715159658
 WHIRLPOOL 
f028c78b1afc1cacb835bb61971910bde1ee6596578e5d7a3d88228a449528be0804fdca4b745894c4d8058980f48b93d976a922ce46727a0492680c085fa8cc
+DIST NetworkManager-1.8.2.tar.xz 3818844 SHA256 
71a5efcd9e4c237ab57b2893ccc8f91f884ace3bec0e2bd4b31a4c9677ff1bf4 SHA512 
7bebea66d8f494c052313224e9d5b1b4cf665482f07ee5d93defc3543f32296545a2d1097ab1fff27dbebb58e07a4bc47fbc0101163db92953ae66ac9b95524d
 WHIRLPOOL 
5928c3d4c1a35dc9485c303f3ce7e7b33c3949a058bd566f8b779d5d6dfa11ee8fc365e1a7954a214cabea70f2239b0f6e2079a67616f5487abbd1d6053260a3
+EBUILD networkmanager-1.8.2.ebuild 10840 SHA256 
f044225597401df61d208349d2ece7d12cc9beef87020b6403d69b7ace3a34ba SHA512 
1e0c75dbf2399a21089e91a9a054dd45b9a3ed859688923a67147af9c74bd67a1634252ba1fe2cb0f6e7b3b297beb30a08a3a3797a76ea027deaa3a4af0a6f83
 WHIRLPOOL 
3066e395c1c3969c8c4d2f1c68ab3e34dce3b216af3fb29ec0e4777c9e53f58198b4cdaf7e6844d5460577895f21c3a41499632419f559e260a62f148ba517af
+MISC metadata.xml 1771 SHA256 
ee2f0f65eaf3effc914d94105b1b44113cccd50ef09de57d6f37319406ed0a9f SHA512 
4a61288c3e91ab8eb040053c706fe147e53fd1e9000b9597dc5b2f0920e08efd0e896f308e32758b4af6371b8fb9737f495355d0a9e2e95a9fd883bd10a8c535
 WHIRLPOOL 
2c91ccec729d06338d05ec4f3641607b4ac29e1228f9407964426db94c44b21d0fc473413395c9356e486b5c680cdd27a2468bf75ce164923aa874df83e9e1da

diff --git a/net-misc/networkmanager/files/0001-Support-musl-libc.patch 
b/net-misc/networkmanager/files/0001-Support-musl-libc.patch
new file mode 100644
index 0000000..14206d3
--- /dev/null
+++ b/net-misc/networkmanager/files/0001-Support-musl-libc.patch
@@ -0,0 +1,108 @@
+From 7c7a97f8a4cc9a3efba630dc31ca9c35592bb1b9 Mon Sep 17 00:00:00 2001
+From: "Jory A. Pratt" <[email protected]>
+Date: Tue, 23 May 2017 14:15:43 -0500
+Subject: [PATCH] Support musl libc
+
+Signed-off-by: Jory A. Pratt <[email protected]>
+---
+ configure.ac                        | 1 +
+ libnm-core/nm-utils.h               | 4 ++++
+ src/platform/wifi/wifi-utils.h      | 4 ++++
+ src/systemd/src/basic/socket-util.h | 5 +++++
+ src/systemd/src/basic/stdio-util.h  | 2 ++
+ src/systemd/src/basic/util.h        | 5 +++++
+ 6 files changed, 21 insertions(+)
+
+diff --git a/configure.ac b/configure.ac
+index 6f190c0..ddc25f0 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -278,6 +278,7 @@ dnl
+ dnl Checks for libdl - on certain platforms its part of libc
+ dnl
+ AC_SEARCH_LIBS([dlopen], [dl dld], [], [ac_cv_search_dlopen=])
++AS_IF([test "$ac_cv_search_dlopen" = "none 
required"],[ac_cv_search_dlopen=""])
+ AC_SUBST([DL_LIBS], "$ac_cv_search_dlopen")
+ 
+ PKG_CHECK_MODULES(GLIB, [gio-unix-2.0 >= 2.37.6 gmodule-2.0],
+diff --git a/libnm-core/nm-utils.h b/libnm-core/nm-utils.h
+index 77fe18a..dcc776f 100644
+--- a/libnm-core/nm-utils.h
++++ b/libnm-core/nm-utils.h
+@@ -30,7 +30,11 @@
+ #include <netinet/in.h>
+ 
+ /* For ETH_ALEN and INFINIBAND_ALEN */
++#if defined(__GLIBC__)
+ #include <linux/if_ether.h>
++#else
++#define ETH_ALEN      6               /* Octets in one ethernet addr   */
++#endif
+ #include <linux/if_infiniband.h>
+ 
+ #include "nm-core-enum-types.h"
+diff --git a/src/platform/wifi/wifi-utils.h b/src/platform/wifi/wifi-utils.h
+index 705717b..da3edc4 100644
+--- a/src/platform/wifi/wifi-utils.h
++++ b/src/platform/wifi/wifi-utils.h
+@@ -22,7 +22,11 @@
+ #ifndef __WIFI_UTILS_H__
+ #define __WIFI_UTILS_H__
+ 
++#if defined(__GLIBC__)
+ #include <net/ethernet.h>
++#else /* musl libc */
++#define ETH_ALEN      6               /* Octets in one ethernet addr   */
++#endif
+ 
+ #include "nm-dbus-interface.h"
+ 
+diff --git a/src/systemd/src/basic/socket-util.h 
b/src/systemd/src/basic/socket-util.h
+index 19a9ddb..337b20e 100644
+--- a/src/systemd/src/basic/socket-util.h
++++ b/src/systemd/src/basic/socket-util.h
+@@ -28,6 +28,11 @@
+ #include <sys/un.h>
+ #include <linux/netlink.h>
+ #include <linux/if_packet.h>
++#if !defined(__GLIBC__)
++/* SIOCGSTAMPNS from linux/asm-generic.h 
++ * for src/systemd/src/libsystemd-network/sd-lldp.c */
++#include <linux/sockios.h>
++#endif
+ 
+ #include "macro.h"
+ #include "missing.h"
+diff --git a/src/systemd/src/basic/stdio-util.h 
b/src/systemd/src/basic/stdio-util.h
+index bd1144b..9eafacb 100644
+--- a/src/systemd/src/basic/stdio-util.h
++++ b/src/systemd/src/basic/stdio-util.h
+@@ -19,7 +19,9 @@
+   along with systemd; If not, see <http://www.gnu.org/licenses/>.
+ ***/
+ 
++#if defined(__GLIBC__)
+ #include <printf.h>
++#endif
+ #include <stdarg.h>
+ #include <stdio.h>
+ #include <sys/types.h>
+diff --git a/src/systemd/src/basic/util.h b/src/systemd/src/basic/util.h
+index c7da6c3..d19e1b2 100644
+--- a/src/systemd/src/basic/util.h
++++ b/src/systemd/src/basic/util.h
+@@ -46,6 +46,11 @@
+ #include "missing.h"
+ #include "time-util.h"
+ 
++#if !defined(__GLIBC__)
++typedef int (*__compar_fn_t) (const void*, const void*);
++typedef __compar_fn_t comparison_fn_t;
++#endif
++
+ size_t page_size(void) _pure_;
+ #define PAGE_ALIGN(l) ALIGN_TO((l), page_size())
+ 
+-- 
+2.13.0
+

diff --git 
a/net-misc/networkmanager/files/01-org.freedesktop.NetworkManager.settings.modify.system.rules
 
b/net-misc/networkmanager/files/01-org.freedesktop.NetworkManager.settings.modify.system.rules
new file mode 100644
index 0000000..d00b268
--- /dev/null
+++ 
b/net-misc/networkmanager/files/01-org.freedesktop.NetworkManager.settings.modify.system.rules
@@ -0,0 +1,7 @@
+// Let users in plugdev group modify NetworkManager
+polkit.addRule(function(action, subject) {
+    if (action.id == "org.freedesktop.NetworkManager.settings.modify.system" &&
+        subject.isInGroup("plugdev") && subject.active) {
+        return "yes";
+    }
+});

diff --git a/net-misc/networkmanager/files/10-openrc-status-r4 
b/net-misc/networkmanager/files/10-openrc-status-r4
new file mode 100644
index 0000000..e195ccc
--- /dev/null
+++ b/net-misc/networkmanager/files/10-openrc-status-r4
@@ -0,0 +1,35 @@
+#!/bin/sh
+# Copyright (c) 2012 Alexandre Rostovtsev
+# Released under the 2-clause BSD license.
+
+# Ensures that the NetworkManager OpenRC service is marked as started and
+# providing net only when it has a successful connection.
+
+if [ ! -e "/run/openrc/softlevel" ]; then
+       # OpenRC is not running
+       exit 0
+fi
+
+# Ensure rc-service is in PATH
+PATH="${PATH}:@EPREFIX@/sbin:@EPREFIX@/usr/sbin"
+
+# Exit if the NetworkManager OpenRC service is not running
+rc-service NetworkManager status 2>&1 | grep -Eq "status: 
(starting|started|inactive|stopping)" || exit 0
+
+# Call rc-service in background mode so that the start/stop functions update
+# NetworkManager service status to started or inactive instead of actually
+# starting or stopping the daemon
+export IN_BACKGROUND=YES
+
+case "$2" in
+       up) nm-online -t 0 -x &&
+               ! rc-service NetworkManager status 2>&1 | grep -q started &&
+               exec rc-service NetworkManager start ;;
+       down) nm-online -t 0 -x ||
+               rc-service NetworkManager status 2>&1 | grep -q stopped ||
+               exec rc-service NetworkManager stop ;;
+       pre-sleep) rc-service NetworkManager status 2>&1 | grep -q stopped ||
+               exec rc-service NetworkManager stop ;;
+esac
+exit 0
+# vim: set ts=4:

diff --git a/net-misc/networkmanager/files/conf.d.NetworkManager 
b/net-misc/networkmanager/files/conf.d.NetworkManager
new file mode 100644
index 0000000..4a99229
--- /dev/null
+++ b/net-misc/networkmanager/files/conf.d.NetworkManager
@@ -0,0 +1,4 @@
+# If NetworkManager does not establish a connection within $INACTIVE_TIMEOUT
+# seconds after starting, the service will be marked as inactive, and it will
+# continue to wait for a connection in background mode.
+INACTIVE_TIMEOUT=1

diff --git a/net-misc/networkmanager/files/init.d.NetworkManager-r1 
b/net-misc/networkmanager/files/init.d.NetworkManager-r1
new file mode 100644
index 0000000..3209644
--- /dev/null
+++ b/net-misc/networkmanager/files/init.d.NetworkManager-r1
@@ -0,0 +1,58 @@
+#!/sbin/openrc-run
+# Copyright (c) 2008 Saleem Abdulrasool <[email protected]>
+# Copyright 2013-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+description="NetworkManager daemon. The service is marked as started only \
+when a network connection is established."
+
+depend() {
+       need dbus
+       use consolekit
+       provide net
+}
+
+start() {
+       # If we are re-called by a dispatcher event, we want to mark the service
+       # as started without starting the daemon again
+       yesno "${IN_BACKGROUND}" && return 0
+
+       [ -z "${INACTIVE_TIMEOUT}" ] && INACTIVE_TIMEOUT="1"
+
+       ebegin "Starting NetworkManager"
+       start-stop-daemon --start --quiet --pidfile 
/run/NetworkManager/NetworkManager.pid \
+               --exec /usr/sbin/NetworkManager -- --pid-file 
/run/NetworkManager/NetworkManager.pid
+       local _retval=$?
+       eend "${_retval}"
+       if [ "x${_retval}" = 'x0' ] && ! nm-online -t "${INACTIVE_TIMEOUT}"; 
then
+               einfo "Marking NetworkManager as inactive. It will 
automatically be marked"
+               einfo "as started after a network connection has been 
established."
+               mark_service_inactive
+       fi
+       return "${_retval}"
+}
+
+stop() {
+       # If we are re-called by a dispatcher event, we want to mark the service
+       # as inactive without stopping the daemon
+       if yesno "${IN_BACKGROUND}"; then
+               mark_service_inactive "${SVCNAME}"
+               return 0
+       fi
+
+       ebegin "Stopping NetworkManager"
+       local pidfile=/run/NetworkManager/NetworkManager.pid
+       if [ ! -e "${pidfile}" ] && [ -e /var/run/NetworkManager.pid ]; then 
+               # Try stopping the pid file used by <0.9.7
+               pidfile=/var/run/NetworkManager.pid
+               start-stop-daemon --stop --quiet --pidfile "${pidfile}"
+               ret=$?
+               [ ${ret} = 0 ] && [ -e "${pidfile}" ] && rm "${pidfile}"
+               eend ${ret}
+       else
+               start-stop-daemon --stop --quiet --pidfile "${pidfile}"
+               eend $?
+       fi
+}
+
+# vim: set ft=gentoo-init-d ts=4 :

diff --git a/net-misc/networkmanager/metadata.xml 
b/net-misc/networkmanager/metadata.xml
new file mode 100644
index 0000000..8d695c7
--- /dev/null
+++ b/net-misc/networkmanager/metadata.xml
@@ -0,0 +1,38 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd";>
+<pkgmetadata>
+       <maintainer type="project">
+               <email>[email protected]</email>
+               <name>Gentoo GNOME Desktop</name>
+       </maintainer>
+       <maintainer type="person">
+               <email>[email protected]</email>
+               <name>Mike Gilbert</name>
+       </maintainer>
+       <use>
+               <flag name="connection-sharing">Use <pkg>net-dns/dnsmasq</pkg> 
and
+                       <pkg>net-firewall/iptables</pkg> for connection 
sharing</flag>
+               <flag name="consolekit">Use <pkg>sys-auth/consolekit</pkg> for 
session
+                       tracking</flag>
+               <flag name="dhclient">Use dhclient from 
<pkg>net-misc/dhcp</pkg> for
+                       getting ip</flag>
+               <flag name="dhcpcd">Use <pkg>net-misc/dhcpcd</pkg> for getting 
ip</flag>
+               <flag name="elogind">Use <pkg>sys-auth/elogind</pkg> for 
session tracking</flag>
+               <flag name="json">Enable JSON validation via 
<pkg>dev-libs/jansson</pkg>
+                       in libnm.</flag>
+               <flag name="modemmanager">Enable support for mobile broadband 
devices
+                       using <pkg>net-misc/modemmanager</pkg></flag>
+               <flag name="nss">Use <pkg>dev-libs/nss</pkg> for 
cryptography</flag>
+               <flag name="ofono">Use <pkg>net-misc/ofono</pkg> for telephony 
support.</flag>
+               <flag name="ppp">Enable support for mobile broadband and PPPoE
+                       connections using <pkg>net-dialup/ppp</pkg></flag>
+               <flag name="resolvconf">Use <pkg>net-dns/openresolv</pkg> for 
managing
+                       DNS information</flag>
+               <flag name="teamd">Enable Teamd control support</flag>
+               <flag name="wifi">Enable support for wifi and 802.1x security 
using
+                       <pkg>net-wireless/wpa_supplicant</pkg></flag>
+               <flag name="wext">Enable support for the deprecated Wext 
(Wireless
+                       Extensions) API; needed for some older drivers (e.g. 
ipw2200,
+                       ndiswrapper)</flag>
+       </use>
+</pkgmetadata>

diff --git a/net-misc/networkmanager/networkmanager-1.8.2.ebuild 
b/net-misc/networkmanager/networkmanager-1.8.2.ebuild
new file mode 100644
index 0000000..bc3adeb
--- /dev/null
+++ b/net-misc/networkmanager/networkmanager-1.8.2.ebuild
@@ -0,0 +1,331 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+GNOME_ORG_MODULE="NetworkManager"
+GNOME2_LA_PUNT="yes"
+GNOME2_EAUTORECONF="yes"
+VALA_USE_DEPEND="vapigen"
+PYTHON_COMPAT=( python{2_7,3_4,3_5,3_6} )
+
+inherit bash-completion-r1 gnome2 linux-info multilib python-any-r1 systemd  
flag-o-matic \
+       user readme.gentoo-r1 toolchain-funcs vala versionator virtualx udev 
multilib-minimal
+
+DESCRIPTION="A set of co-operative tools that make networking simple and 
straightforward"
+HOMEPAGE="https://wiki.gnome.org/Projects/NetworkManager";
+
+LICENSE="GPL-2+"
+SLOT="0" # add subslot if libnm-util.so.2 or libnm-glib.so.4 bumps soname 
version
+
+IUSE="audit bluetooth connection-sharing consolekit +dhclient dhcpcd 
elibc_musl elogind gnutls +introspection
+ json kernel_linux +nss +modemmanager ncurses ofono policykit +ppp resolvconf 
selinux systemd teamd test vala +wext +wifi"
+
+REQUIRED_USE="
+       modemmanager? ( ppp )
+       vala? ( introspection )
+       wext? ( wifi )
+       ^^ ( nss gnutls )
+       ?? ( consolekit elogind systemd )
+"
+
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~ia64 ~ppc ~ppc64 ~sparc ~x86"
+
+# gobject-introspection-0.10.3 is needed due to gnome bug 642300
+# wpa_supplicant-0.7.3-r3 is needed due to bug 359271
+# TODO: need multilib janson (linked to libnm.so)
+COMMON_DEPEND="
+       >=sys-apps/dbus-1.2[${MULTILIB_USEDEP}]
+       >=dev-libs/dbus-glib-0.100[${MULTILIB_USEDEP}]
+       >=dev-libs/glib-2.37.6:2[${MULTILIB_USEDEP}]
+       >=dev-libs/libnl-3.2.8:3=[${MULTILIB_USEDEP}]
+       policykit? ( >=sys-auth/polkit-0.106 )
+       net-libs/libndp[${MULTILIB_USEDEP}]
+       net-misc/curl
+       net-misc/iputils
+       sys-apps/util-linux[${MULTILIB_USEDEP}]
+       sys-libs/readline:0=
+       >=virtual/libudev-175:=[${MULTILIB_USEDEP}]
+       audit? ( sys-process/audit )
+       bluetooth? ( >=net-wireless/bluez-5 )
+       connection-sharing? (
+               net-dns/dnsmasq[dbus,dhcp]
+               net-firewall/iptables )
+       consolekit? ( >=sys-auth/consolekit-1.0.0 )
+       dhclient? ( >=net-misc/dhcp-4[client] )
+       dhcpcd? ( net-misc/dhcpcd )
+       elogind? ( sys-auth/elogind )
+       gnutls? (
+               dev-libs/libgcrypt:0=[${MULTILIB_USEDEP}]
+               >=net-libs/gnutls-2.12:=[${MULTILIB_USEDEP}] )
+       introspection? ( >=dev-libs/gobject-introspection-0.10.3:= )
+       json? ( dev-libs/jansson )
+       modemmanager? ( >=net-misc/modemmanager-0.7.991:0= )
+       ncurses? ( >=dev-libs/newt-0.52.15 )
+       nss? ( >=dev-libs/nss-3.11:=[${MULTILIB_USEDEP}] )
+       ofono? ( net-misc/ofono )
+       ppp? ( >=net-dialup/ppp-2.4.5:=[ipv6] )
+       resolvconf? ( net-dns/openresolv )
+       selinux? ( sys-libs/libselinux )
+       systemd? ( >=sys-apps/systemd-209:0= )
+       teamd? (
+               dev-libs/jansson
+               >=net-misc/libteam-1.9
+       )
+"
+RDEPEND="${COMMON_DEPEND}
+       || (
+               net-misc/iputils[arping(+)]
+               net-analyzer/arping
+       )
+       wifi? ( >=net-wireless/wpa_supplicant-0.7.3-r3[dbus] )
+"
+DEPEND="${COMMON_DEPEND}
+       dev-util/gdbus-codegen
+       dev-util/gtk-doc-am
+       >=dev-util/intltool-0.40
+       >=sys-devel/gettext-0.17
+       >=sys-kernel/linux-headers-2.6.29
+       virtual/pkgconfig[${MULTILIB_USEDEP}]
+       introspection? (
+               $(python_gen_any_dep 'dev-python/pygobject:3[${PYTHON_USEDEP}]')
+               dev-lang/perl
+               dev-libs/libxslt
+       )
+       vala? ( $(vala_depend) )
+       test? (
+               $(python_gen_any_dep '
+                       dev-python/dbus-python[${PYTHON_USEDEP}]
+                       dev-python/pygobject:3[${PYTHON_USEDEP}]')
+       )
+"
+
+PATCHES=(
+       "${FILESDIR}"/0001-Support-musl-libc.patch
+)
+
+python_check_deps() {
+       if use introspection; then
+               has_version "dev-python/pygobject:3[${PYTHON_USEDEP}]" || return
+       fi
+       if use test; then
+               has_version "dev-python/dbus-python[${PYTHON_USEDEP}]" &&
+               has_version "dev-python/pygobject:3[${PYTHON_USEDEP}]"
+       fi
+}
+
+sysfs_deprecated_check() {
+       ebegin "Checking for SYSFS_DEPRECATED support"
+
+       if { linux_chkconfig_present SYSFS_DEPRECATED_V2; }; then
+               eerror "Please disable SYSFS_DEPRECATED_V2 support in your 
kernel config and recompile your kernel"
+               eerror "or NetworkManager will not work correctly."
+               eerror "See https://bugs.gentoo.org/333639 for more info."
+               die "CONFIG_SYSFS_DEPRECATED_V2 support detected!"
+       fi
+       eend $?
+}
+
+pkg_pretend() {
+       if use kernel_linux; then
+               get_version
+               if linux_config_exists; then
+                       sysfs_deprecated_check
+               else
+                       ewarn "Was unable to determine your kernel .config"
+                       ewarn "Please note that if CONFIG_SYSFS_DEPRECATED_V2 
is set in your kernel .config, NetworkManager will not work correctly."
+                       ewarn "See https://bugs.gentoo.org/333639 for more 
info."
+               fi
+
+       fi
+}
+
+pkg_setup() {
+       if use connection-sharing; then
+               CONFIG_CHECK="~NF_NAT_IPV4 ~NF_NAT_MASQUERADE_IPV4"
+               linux-info_pkg_setup
+       fi
+       enewgroup plugdev
+       if use introspection || use test; then
+               python-any-r1_pkg_setup
+       fi
+}
+
+src_prepare() {
+       DOC_CONTENTS="To modify system network connections without needing to 
enter the
+               root password, add your user account to the 'plugdev' group."
+
+       use vala && vala_src_prepare
+       gnome2_src_prepare
+}
+
+multilib_src_configure() {
+       use elibc_musl && append-cflags -DHAVE_SECURE_GETENV 
-Dsecure_getenv=getenv -D__USE_POSIX199309
+
+       local myconf=(
+               --disable-more-warnings
+               --disable-static
+               --localstatedir=/var
+               --disable-lto
+               --disable-config-plugin-ibft
+               # ifnet plugin always disabled until someone volunteers to 
actively
+               # maintain and fix it
+               --disable-ifnet
+               --disable-qt
+               --without-netconfig
+               --with-dbus-sys-dir=/etc/dbus-1/system.d
+               # We need --with-libnm-glib (and dbus-glib dep) as reverse deps 
are
+               # still not ready for removing that lib
+               --with-libnm-glib
+               --with-nmcli=yes
+               --with-udev-dir="$(get_udevdir)"
+               --with-config-plugins-default=keyfile
+               --with-iptables=/sbin/iptables
+               $(multilib_native_enable concheck)
+               --with-crypto=$(usex nss nss gnutls)
+               --with-session-tracking=$(multilib_native_usex systemd systemd 
$(multilib_native_usex elogind elogind $(multilib_native_usex consolekit 
consolekit no)))
+               --with-suspend-resume=$(multilib_native_usex systemd systemd 
$(multilib_native_usex elogind elogind consolekit))
+               $(multilib_native_use_with audit libaudit)
+               $(multilib_native_use_enable bluetooth bluez5-dun)
+               $(use_with dhclient)
+               $(use_with dhcpcd)
+               $(multilib_native_use_enable introspection)
+               $(multilib_native_use_enable json json-validation)
+               $(multilib_native_use_enable ppp)
+               --without-libpsl
+               $(multilib_native_use_with modemmanager modem-manager-1)
+               $(multilib_native_use_with ncurses nmtui)
+               $(multilib_native_use_with ofono)
+               $(multilib_native_use_with resolvconf)
+               $(multilib_native_use_with selinux)
+               $(multilib_native_use_with systemd systemd-journal)
+               $(multilib_native_use_enable teamd teamdctl)
+               $(multilib_native_use_enable test tests)
+               $(multilib_native_use_enable vala)
+               --without-valgrind
+               $(multilib_native_use_with wext)
+               $(multilib_native_use_enable wifi)
+       )
+
+       if multilib_is_native_abi && use policykit; then
+               myconf+=( --enable-polkit=yes )
+       else
+               myconf+=( --enable-polkit=disabled )
+       fi
+
+       # Same hack as net-dialup/pptpd to get proper plugin dir for ppp, bug 
#519986
+       if use ppp; then
+               local PPPD_VER=`best_version net-dialup/ppp`
+               PPPD_VER=${PPPD_VER#*/*-} #reduce it to ${PV}-${PR}
+               PPPD_VER=${PPPD_VER%%[_-]*} # main version without 
beta/pre/patch/revision
+               myconf+=( 
--with-pppd-plugin-dir=/usr/$(get_libdir)/pppd/${PPPD_VER} )
+       fi
+
+       # unit files directory needs to be passed only when systemd is enabled,
+       # otherwise systemd support is not disabled completely, bug #524534
+       use systemd && myconf+=( 
--with-systemdsystemunitdir="$(systemd_get_systemunitdir)" )
+
+       if multilib_is_native_abi; then
+               # work-around man out-of-source brokenness, must be done before 
configure
+               ln -s "${S}/docs" docs || die
+               ln -s "${S}/man" man || die
+       fi
+
+       ECONF_SOURCE=${S} runstatedir="/run" gnome2_src_configure "${myconf[@]}"
+}
+
+multilib_src_compile() {
+       if multilib_is_native_abi; then
+               emake
+       else
+               local targets=(
+                       libnm/libnm.la
+                       libnm-util/libnm-util.la
+                       libnm-glib/libnm-glib.la
+                       libnm-glib/libnm-glib-vpn.la
+               )
+               emake "${targets[@]}"
+       fi
+}
+
+multilib_src_test() {
+       if use test && multilib_is_native_abi; then
+               python_setup
+               virtx emake check
+       fi
+}
+
+multilib_src_install() {
+       if multilib_is_native_abi; then
+               # Install completions at proper place, bug #465100
+               gnome2_src_install completiondir="$(get_bashcompdir)"
+       else
+               local targets=(
+                       install-libLTLIBRARIES
+                       install-libdeprecatedHEADERS
+                       install-libnm_glib_libnmvpnHEADERS
+                       install-libnm_glib_libnmincludeHEADERS
+                       install-libnm_util_libnm_util_includeHEADERS
+                       install-libnmincludeHEADERS
+                       install-nodist_libnm_glib_libnmincludeHEADERS
+                       install-nodist_libnm_glib_libnmvpnHEADERS
+                       install-nodist_libnm_util_libnm_util_includeHEADERS
+                       install-nodist_libnmincludeHEADERS
+                       install-pkgconfigDATA
+               )
+               emake DESTDIR="${D}" "${targets[@]}"
+       fi
+}
+
+multilib_src_install_all() {
+       ! use systemd && readme.gentoo_create_doc
+
+       newinitd "${FILESDIR}/init.d.NetworkManager-r1" NetworkManager
+       newconfd "${FILESDIR}/conf.d.NetworkManager" NetworkManager
+
+       # Need to keep the /etc/NetworkManager/dispatched.d for dispatcher 
scripts
+       keepdir /etc/NetworkManager/dispatcher.d
+
+       # Provide openrc net dependency only when nm is connected
+       exeinto /etc/NetworkManager/dispatcher.d
+       newexe "${FILESDIR}/10-openrc-status-r4" 10-openrc-status
+       sed -e "s:@EPREFIX@:${EPREFIX}:g" \
+               -i "${ED}/etc/NetworkManager/dispatcher.d/10-openrc-status" || 
die
+
+       keepdir /etc/NetworkManager/system-connections
+       chmod 0600 "${ED}"/etc/NetworkManager/system-connections/.keep* # bug 
#383765, upstream bug #754594
+
+       # Allow users in plugdev group to modify system connections
+       insinto /usr/share/polkit-1/rules.d/
+       doins 
"${FILESDIR}/01-org.freedesktop.NetworkManager.settings.modify.system.rules"
+}
+
+pkg_postinst() {
+       gnome2_pkg_postinst
+       ! use systemd && readme.gentoo_print_elog
+
+       if [[ -e "${EROOT}etc/NetworkManager/nm-system-settings.conf" ]]; then
+               ewarn "The ${PN} system configuration file has moved to a new 
location."
+               ewarn "You must migrate your settings from 
${EROOT}/etc/NetworkManager/nm-system-settings.conf"
+               ewarn "to ${EROOT}etc/NetworkManager/NetworkManager.conf"
+               ewarn
+               ewarn "After doing so, you can remove 
${EROOT}etc/NetworkManager/nm-system-settings.conf"
+       fi
+
+       # NM fallbacks to plugin specified at compile time (upstream bug 
#738611)
+       # but still show a warning to remember people to have cleaner config 
file
+       if [[ -e "${EROOT}etc/NetworkManager/NetworkManager.conf" ]]; then
+               if grep plugins 
"${EROOT}etc/NetworkManager/NetworkManager.conf" | grep -q ifnet; then
+                       ewarn
+                       ewarn "You seem to use 'ifnet' plugin in 
${EROOT}etc/NetworkManager/NetworkManager.conf"
+                       ewarn "Since it won't be used, you will need to stop 
setting ifnet plugin there."
+                       ewarn
+               fi
+       fi
+
+       # NM shows lots of errors making nmcli neither unusable, bug #528748 
upstream bug #690457
+       if grep -r "psk-flags=1" "${EROOT}"/etc/NetworkManager/; then
+               ewarn "You have psk-flags=1 setting in above files, you will 
need to"
+               ewarn "either reconfigure affected networks or, at least, set 
the flag"
+               ewarn "value to '0'."
+       fi
+}

Reply via email to