new file: games-util/oversteer/Manifest
authorroot <root@admin.liquid.me.uk>
Thu, 8 Feb 2024 14:21:49 +0000 (14:21 +0000)
committerroot <root@admin.liquid.me.uk>
Thu, 8 Feb 2024 14:21:49 +0000 (14:21 +0000)
games-util/oversteer/Manifest [new file with mode: 0644]
games-util/oversteer/oversteer-0.5.2.ebuild [new file with mode: 0644]
games-util/oversteer/oversteer-0.8.0.ebuild [new file with mode: 0644]
sys-fs/eudev/Manifest [new file with mode: 0644]
sys-fs/eudev/eudev-3.2.11-r4.ebuild [new file with mode: 0644]
sys-fs/eudev/files/40-gentoo.rules [new file with mode: 0644]
sys-fs/eudev/files/udev-postmount [new file with mode: 0644]

diff --git a/games-util/oversteer/Manifest b/games-util/oversteer/Manifest
new file mode 100644 (file)
index 0000000..1e93da3
--- /dev/null
@@ -0,0 +1,4 @@
+DIST oversteer-0.5.2.tar.gz 50101 BLAKE2B a4b0b78e4cd26eabb43eee5346c6322249ee2d59afd4b8b0b5498679cfc129ce9222d951dd696fd7e0bc2f2e677bbcbf9e9ebc14aaac24c6c04ff9026cf6e346 SHA512 8a6229766699f56e1b3122de145ce18918f3a19626bcc7bde983512dba6d0c88a31002a1fcb2d9a6be8b454a7b01d765c12cb92dd575a6024d73c355bdb96f9e
+DIST oversteer-0.8.0.tar.gz 97611 BLAKE2B 6ee283a92d14c41940a6e6bec6b003f23772c4449c849ba1cbc49ab944988fb6c61b64765f0f4f72a62764ec77a81b8f4284ba3271c1148b5c3d06fe15963f44 SHA512 f490edc9a084d2120f2bf8fbc6ad18a2a82b613f12946df5cd3fc72a5d50c78c330de42eb1bcb41d6c4ded96d40a300f26d49571ebb1ce7ca4fdc712220c619b
+EBUILD oversteer-0.5.2.ebuild 719 BLAKE2B ab56335e3ea83df25e7fc44c2982e6571d4a837bdac2c9d755abcab421245211705900746d29f36e84af5f03c7bbddaf8ab022097c342ef0d4b6130cdc58219c SHA512 642433539c608fe7cba0e3ff0bceb78a9176bbc3d81f01082089fb0d28c8db8642635b96e44738603ced847efd4c8140379236ca4bd89f01ca39a2530de4af94
+EBUILD oversteer-0.8.0.ebuild 719 BLAKE2B ab56335e3ea83df25e7fc44c2982e6571d4a837bdac2c9d755abcab421245211705900746d29f36e84af5f03c7bbddaf8ab022097c342ef0d4b6130cdc58219c SHA512 642433539c608fe7cba0e3ff0bceb78a9176bbc3d81f01082089fb0d28c8db8642635b96e44738603ced847efd4c8140379236ca4bd89f01ca39a2530de4af94
diff --git a/games-util/oversteer/oversteer-0.5.2.ebuild b/games-util/oversteer/oversteer-0.5.2.ebuild
new file mode 100644 (file)
index 0000000..c12aa69
--- /dev/null
@@ -0,0 +1,34 @@
+EAPI=7
+PYTHON_COMPAT=( python3_{6,7} )
+DESCRIPTION="Graphical application to configure Logitech Wheels"
+HOMEPAGE="https://github.com/berarma/oversteer"
+SRC_URI="https://github.com/berarma/oversteer/archive/${PV}.tar.gz -> ${P}.tar.gz"
+LICENSE="GPL-3"
+SLOT="0"
+KEYWORDS="amd64 x86"
+
+BDEPEND="dev-util/meson"
+
+RDEPEND="dev-python/pygobject
+                dev-python/pyudev
+                dev-python/python-evdev
+                dev-python/pyxdg
+                sys-devel/gettext
+                dev-libs/appstream-glib
+                dev-util/desktop-file-utils
+                x11-libs/gtk+"
+
+src_prepare() {
+       eapply_user
+       sed -i 's/Utility;//' data/org.berarma.Oversteer.desktop.in
+}
+
+src_compile() {
+       meson build --prefix="/usr"
+       ninja -C build
+}
+
+src_install() {
+       DESTDIR="${D}" ninja -C build install
+}
+
diff --git a/games-util/oversteer/oversteer-0.8.0.ebuild b/games-util/oversteer/oversteer-0.8.0.ebuild
new file mode 100644 (file)
index 0000000..c12aa69
--- /dev/null
@@ -0,0 +1,34 @@
+EAPI=7
+PYTHON_COMPAT=( python3_{6,7} )
+DESCRIPTION="Graphical application to configure Logitech Wheels"
+HOMEPAGE="https://github.com/berarma/oversteer"
+SRC_URI="https://github.com/berarma/oversteer/archive/${PV}.tar.gz -> ${P}.tar.gz"
+LICENSE="GPL-3"
+SLOT="0"
+KEYWORDS="amd64 x86"
+
+BDEPEND="dev-util/meson"
+
+RDEPEND="dev-python/pygobject
+                dev-python/pyudev
+                dev-python/python-evdev
+                dev-python/pyxdg
+                sys-devel/gettext
+                dev-libs/appstream-glib
+                dev-util/desktop-file-utils
+                x11-libs/gtk+"
+
+src_prepare() {
+       eapply_user
+       sed -i 's/Utility;//' data/org.berarma.Oversteer.desktop.in
+}
+
+src_compile() {
+       meson build --prefix="/usr"
+       ninja -C build
+}
+
+src_install() {
+       DESTDIR="${D}" ninja -C build install
+}
+
diff --git a/sys-fs/eudev/Manifest b/sys-fs/eudev/Manifest
new file mode 100644 (file)
index 0000000..5b72080
--- /dev/null
@@ -0,0 +1,4 @@
+AUX 40-gentoo.rules 167 BLAKE2B 07116c6e5aab7de9fa8a88c6cdd9ad76a09d797d6f7bc3d0535c93ccf83486bbdae8f68d682714576b072a174df070505cce9c6f4b729e91a6f61ed89da72e8e SHA512 92e2be610839432f46cefab4d128825199dc9f2c5ef33119f9ff84dfe635ef56a4f7aaed64ba52ea2798868b00c3a1b7955caa33219aa298c6a2b8290181f94b
+AUX udev-postmount 1208 BLAKE2B bcfbaee26ea666304091092deabcc068c533c7707252917a0d8617812f26744c0454f10f5f829031f8668a345c35034ec68396cbf07792a4a83a87e3816001bb SHA512 8ef1b911843ab13acb1c1b9b7a0a5cd76659f395c3db9e579429556f23eacebb414507dc0231e2455e7589bc70054fa1e6b6dd93dd833f7101c0da0597aabf88
+DIST eudev-3.2.11.tar.gz 2254373 BLAKE2B cfa6235d6509b751fde93ff2b0961b93c3741458e561a7ad9b07b49a57779627532cff25ad3519e5f79320854fcedfcdc23642ef542505cebcd6b2803067389a SHA512 17b328365913af3e434abe667dd0498c3702a41c6cb66f3793ca2c195b05ac06397b0a401077f81df7dd25193e4eeea13657a221ca6cb3d237c4d91e31e30b33
+EBUILD eudev-3.2.11-r4.ebuild 7146 BLAKE2B b4961871e468c9f2f708b24be8f40f59ce54c0d9de8b14df833cae7764689c2c991b1fed806aaa1c8991f3c8d145ef7dd692eae7140601d3908f7dab1ccbd8a0 SHA512 75484b41d701334673c86fb4fc1066678d0ad9140aea68ce76febda8d4edc7df61af620656be093d6971640bab515670798a4212c6cac19b1e4b7fc7dd516674
diff --git a/sys-fs/eudev/eudev-3.2.11-r4.ebuild b/sys-fs/eudev/eudev-3.2.11-r4.ebuild
new file mode 100644 (file)
index 0000000..1427c56
--- /dev/null
@@ -0,0 +1,251 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+KV_MIN=2.6.39
+
+inherit autotools linux-info multilib-minimal toolchain-funcs
+
+if [[ ${PV} = 9999* ]]; then
+       EGIT_REPO_URI="https://github.com/eudev-project/eudev.git"
+       inherit git-r3
+else
+       SRC_URI="https://github.com/eudev-project/eudev/archive/refs/tags/v${PV}.tar.gz -> ${P}.tar.gz"
+       KEYWORDS="~alpha amd64 arm arm64 hppa ~ia64 ~m68k ~mips ppc ppc64 ~riscv ~s390 sparc x86"
+fi
+
+DESCRIPTION="Linux dynamic and persistent device naming support (aka userspace devfs)"
+HOMEPAGE="https://github.com/gentoo/eudev"
+
+LICENSE="LGPL-2.1 MIT GPL-2"
+SLOT="0"
+IUSE="+kmod introspection rule-generator selinux static-libs test"
+RESTRICT="!test? ( test )"
+
+DEPEND=">=sys-apps/util-linux-2.20
+       >=sys-kernel/linux-headers-${KV_MIN}
+       virtual/libcrypt:=
+       introspection? ( >=dev-libs/gobject-introspection-1.38 )
+       kmod? ( >=sys-apps/kmod-16 )
+       selinux? ( >=sys-libs/libselinux-2.1.9 )
+       !sys-apps/gentoo-systemd-integration
+       !sys-apps/systemd"
+RDEPEND="${DEPEND}
+       acct-group/input
+       acct-group/kvm
+       acct-group/render
+       acct-group/audio
+       acct-group/cdrom
+       acct-group/dialout
+       acct-group/disk
+       acct-group/floppy
+       acct-group/input
+       acct-group/kmem
+       acct-group/kvm
+       acct-group/lp
+       acct-group/render
+       acct-group/sgx
+       acct-group/tape
+       acct-group/tty
+       acct-group/usb
+       acct-group/video
+       !sys-apps/systemd-utils[udev]
+       !sys-fs/udev
+       !sys-apps/systemd
+       !sys-apps/hwids[udev]"
+BDEPEND="dev-util/gperf
+       virtual/os-headers
+       virtual/pkgconfig
+       >=sys-devel/make-3.82-r4
+       test? ( app-text/tree dev-lang/perl )"
+PDEPEND=">=sys-fs/udev-init-scripts-26"
+
+MULTILIB_WRAPPED_HEADERS=(
+       /usr/include/udev.h
+)
+
+pkg_pretend() {
+       ewarn
+       ewarn "As of 2013-01-29, ${P} provides the new interface renaming functionality,"
+       ewarn "as described in the URL below:"
+       ewarn "https://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames"
+       ewarn
+       ewarn "This functionality is enabled BY DEFAULT because eudev has no means of synchronizing"
+       ewarn "between the default or user-modified choice of sys-fs/udev.  If you wish to disable"
+       ewarn "this new iface naming, please be sure that /etc/udev/rules.d/80-net-name-slot.rules"
+       ewarn "exists: touch /etc/udev/rules.d/80-net-name-slot.rules"
+       ewarn
+}
+
+pkg_setup() {
+       CONFIG_CHECK="~BLK_DEV_BSG ~DEVTMPFS ~!IDE ~INOTIFY_USER ~!SYSFS_DEPRECATED ~!SYSFS_DEPRECATED_V2 ~SIGNALFD ~EPOLL ~FHANDLE ~NET ~UNIX"
+       linux-info_pkg_setup
+       get_running_version
+
+       # These are required kernel options, but we don't error out on them
+       # because you can build under one kernel and run under another.
+       if kernel_is lt ${KV_MIN//./ }; then
+               ewarn
+               ewarn "Your current running kernel version ${KV_FULL} is too old to run ${P}."
+               ewarn "Make sure to run udev under kernel version ${KV_MIN} or above."
+               ewarn
+       fi
+}
+
+src_prepare() {
+       # change rules back to group uucp instead of dialout for now
+       sed -e 's/GROUP="dialout"/GROUP="uucp"/' -i rules/*.rules \
+               || die "failed to change group dialout to uucp"
+
+       default
+       eautoreconf
+}
+
+multilib_src_configure() {
+       # bug #463846
+       tc-export CC
+       # bug #502950
+       export cc_cv_CFLAGS__flto=no
+
+       # Keep sorted by ./configure --help and only pass --disable flags
+       # when *required* to avoid external deps or unnecessary compile
+       local econf_args
+       econf_args=(
+               ac_cv_search_cap_init=
+               ac_cv_header_sys_capability_h=yes
+               DBUS_CFLAGS=' '
+               DBUS_LIBS=' '
+               --with-rootprefix=
+               --with-rootrundir=/run
+               --exec-prefix="${EPREFIX}"
+               --bindir="${EPREFIX}"/bin
+               --includedir="${EPREFIX}"/usr/include
+               --libdir="${EPREFIX}"/usr/$(get_libdir)
+               --with-rootlibexecdir="${EPREFIX}"/lib/udev
+               --enable-split-usr
+               --enable-manpages
+       )
+
+       # Only build libudev for non-native_abi, and only install it to libdir,
+       # that means all options only apply to native_abi
+       if multilib_is_native_abi; then
+               econf_args+=(
+                       --with-rootlibdir="${EPREFIX}"/$(get_libdir)
+                       $(use_enable introspection)
+                       $(use_enable kmod)
+                       $(use_enable static-libs static)
+                       $(use_enable selinux)
+                       $(use_enable rule-generator)
+               )
+       else
+               econf_args+=(
+                       --disable-static
+                       --disable-introspection
+                       --disable-kmod
+                       --disable-selinux
+                       --disable-rule-generator
+                       --disable-hwdb
+               )
+       fi
+
+       ECONF_SOURCE="${S}" econf "${econf_args[@]}"
+}
+
+multilib_src_compile() {
+       if multilib_is_native_abi; then
+               emake
+       else
+               emake -C src/shared
+               emake -C src/libudev
+       fi
+}
+
+multilib_src_test() {
+       # make sandbox get out of the way
+       # these are safe because there is a fake root filesystem put in place,
+       # but sandbox seems to evaluate the paths of the test i/o instead of the
+       # paths of the actual i/o that results.
+       # also only test for native abi
+       if multilib_is_native_abi; then
+               addread /sys
+               addwrite /dev
+               addwrite /run
+
+               default_src_test
+       fi
+}
+
+multilib_src_install() {
+       if multilib_is_native_abi; then
+               emake DESTDIR="${D}" install
+       else
+               emake -C src/libudev DESTDIR="${D}" install
+       fi
+}
+
+multilib_src_install_all() {
+       find "${ED}" -name '*.la' -delete || die
+
+       insinto /lib/udev/rules.d
+       doins "${FILESDIR}"/40-gentoo.rules
+
+       use rule-generator && doinitd "${FILESDIR}"/udev-postmount
+}
+
+pkg_postinst() {
+       mkdir -p "${EROOT}"/run
+
+       # "losetup -f" is confused if there is an empty /dev/loop/, Bug #338766
+       # So try to remove it here (will only work if empty).
+       rmdir "${EROOT}"/dev/loop 2>/dev/null
+       if [[ -d ${EROOT}/dev/loop ]]; then
+               ewarn "Please make sure your remove /dev/loop,"
+               ewarn "else losetup may be confused when looking for unused devices."
+       fi
+
+       # REPLACING_VERSIONS should only ever have zero or 1 values but in case it doesn't,
+       # process it as a list.  We only care about the zero case (new install) or the case where
+       # the same version is being re-emerged.  If there is a second version, allow it to abort.
+       local rv rvres=doitnew
+       for rv in ${REPLACING_VERSIONS} ; do
+               if [[ ${rvres} == doit* ]]; then
+                       if [[ ${rv%-r*} == ${PV} ]]; then
+                               rvres=doit
+                       else
+                               rvres=${rv}
+                       fi
+               fi
+       done
+
+       if has_version 'sys-apps/hwids[udev]'; then
+               udevadm hwdb --update --root="${ROOT}"
+
+               # https://cgit.freedesktop.org/systemd/systemd/commit/?id=1fab57c209035f7e66198343074e9cee06718bda
+               # reload database after it has be rebuilt, but only if we are not upgrading
+               # also pass if we are -9999 since who knows what hwdb related changes there might be
+               if [[ ${rvres} == doit* ]] && [[ -z ${ROOT} ]] && [[ ${PV} != "9999" ]]; then
+                       udevadm control --reload
+               fi
+       fi
+
+       if [[ ${rvres} != doitnew ]]; then
+               ewarn
+               ewarn "You need to restart eudev as soon as possible to make the"
+               ewarn "upgrade go into effect:"
+               ewarn "\t/etc/init.d/udev --nodeps restart"
+       fi
+
+       if use rule-generator && \
+       [[ -x $(type -P rc-update) ]] && rc-update show | grep udev-postmount | grep -qsv 'boot\|default\|sysinit'; then
+               ewarn
+               ewarn "Please add the udev-postmount init script to your default runlevel"
+               ewarn "to ensure the legacy rule-generator functionality works as reliably"
+               ewarn "as possible."
+               ewarn "\trc-update add udev-postmount default"
+       fi
+
+       elog
+       elog "For more information on eudev on Gentoo, writing udev rules, and"
+       elog "fixing known issues visit: https://wiki.gentoo.org/wiki/Eudev"
+}
diff --git a/sys-fs/eudev/files/40-gentoo.rules b/sys-fs/eudev/files/40-gentoo.rules
new file mode 100644 (file)
index 0000000..6b96bd0
--- /dev/null
@@ -0,0 +1,3 @@
+# Gentoo specific groups
+ACTION=="add", SUBSYSTEM=="block", KERNEL=="fd[0-9]", GROUP="floppy"
+ACTION=="add", SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", GROUP="usb"
diff --git a/sys-fs/eudev/files/udev-postmount b/sys-fs/eudev/files/udev-postmount
new file mode 100644 (file)
index 0000000..f1f94f4
--- /dev/null
@@ -0,0 +1,55 @@
+#!/sbin/openrc-run
+# Copyright 1999-2013 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+depend()
+{
+       need localmount
+       keyword -vserver -lxc
+}
+
+dir_writeable()
+{
+        touch "$1"/.test.$$ 2>/dev/null && rm "$1"/.test.$$
+}
+
+# store persistent-rules that got created while booting
+# when / was still read-only
+store_persistent_rules()
+{
+       # create /etc/udev/rules.d if it does not exist and /etc/udev is writable
+       [ -d /etc/udev/rules.d ] || \
+               dir_writeable /etc/udev && \
+               mkdir -p /etc/udev/rules.d
+
+       # only continue if rules-directory is writable
+       dir_writeable /etc/udev/rules.d || return 0
+
+       local file dest
+       for file in /run/udev/tmp-rules--*; do
+               dest=${file##*tmp-rules--}
+               [ "$dest" = '*' ] && break
+               type=${dest##70-persistent-}
+               type=${type%%.rules}
+               ebegin "Saving udev persistent ${type} rules to /etc/udev/rules.d"
+               cat "$file" >> /etc/udev/rules.d/"$dest" && rm -f "$file"
+               eend $? "Failed moving persistent rules!"
+       done
+}
+
+start()
+{
+       # check if this system uses udev
+       [ -d /run/udev ] || return 0
+
+       # store persistent-rules that got created while booting
+       # when / was still read-only
+       store_persistent_rules
+}
+
+stop()
+{
+       return 0
+}
+
+# vim:ts=4