diff options
author | Gluzskiy Alexandr <sss@sss.chaoslab.ru> | 2017-08-02 00:04:55 +0300 |
---|---|---|
committer | Gluzskiy Alexandr <sss@sss.chaoslab.ru> | 2017-08-02 00:04:55 +0300 |
commit | d8116ef833f349ac63d6c4417de020aacacda870 (patch) | |
tree | 1e437f5ee034a11b244dfa8dcabc0770236e4bcb /media-sound | |
parent | b2131a51b43560868349da9fb84c1d9d57444744 (diff) |
dirty bugfix for wrong buffer in stringformat //may cause bugs with malloc/free vs new/delete as i do not know internals of mpd.
Diffstat (limited to 'media-sound')
-rw-r--r-- | media-sound/mpd/files/mpd-0.20.4.init | 32 | ||||
-rw-r--r-- | media-sound/mpd/files/mpd-0.20.4.logrotate | 6 | ||||
-rw-r--r-- | media-sound/mpd/files/string_crashfix.patch | 74 | ||||
-rw-r--r-- | media-sound/mpd/mpd-0.20.9-r1.ebuild | 261 |
4 files changed, 373 insertions, 0 deletions
diff --git a/media-sound/mpd/files/mpd-0.20.4.init b/media-sound/mpd/files/mpd-0.20.4.init new file mode 100644 index 0000000..3eb0bc2 --- /dev/null +++ b/media-sound/mpd/files/mpd-0.20.4.init @@ -0,0 +1,32 @@ +#!/sbin/openrc-run +# Copyright 1999-2016 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 + +: CFGFILE=${CFGFILE:=/etc/mpd.conf} + +depend() { + need localmount + use net netmount nfsmount alsasound esound pulseaudio + config ${CFGFILE} +} + +get_config() { + x=$1 + test -e ${CFGFILE} || return 1 + sed -n \ + -e '/^[ \t]*'${x}'/{s:^[ \t]*'${x}'[ \t]\+"\?\([^#"]\+\)[^"]*"\?$:\1: ; p }' \ + ${CFGFILE} +} + +extra_started_commands='reload' +command=/usr/bin/mpd +command_args=${opts:=${CFGFILE}} +required_files=${CFGFILE} +pidfile=$(get_config pid_file) +description="Music Player Daemon" + +reload() { + ebegin "Reloading ${SVCNAME}" + kill -HUP `cat ${pidfile}` + eend $? +} diff --git a/media-sound/mpd/files/mpd-0.20.4.logrotate b/media-sound/mpd/files/mpd-0.20.4.logrotate new file mode 100644 index 0000000..ff47d10 --- /dev/null +++ b/media-sound/mpd/files/mpd-0.20.4.logrotate @@ -0,0 +1,6 @@ +/var/lib/mpd/log { + missingok + postrotate + /etc/init.d/mpd reload + endscript +} diff --git a/media-sound/mpd/files/string_crashfix.patch b/media-sound/mpd/files/string_crashfix.patch new file mode 100644 index 0000000..0d2b7f9 --- /dev/null +++ b/media-sound/mpd/files/string_crashfix.patch @@ -0,0 +1,74 @@ +--- mpd-0.20.9/src/util/FormatString.cxx 2017-01-27 10:46:51.000000000 +0300 ++++ mpd-0.20.9_patched/src/util/FormatString.cxx 2017-08-01 23:55:23.781161186 +0300 +@@ -23,42 +23,46 @@ + #include <stdio.h> + #include <stdlib.h> + +-#ifdef WIN32 + #include <string.h> +-#endif + + AllocatedString<> + FormatStringV(const char *fmt, va_list args) + { +-#ifndef WIN32 +- va_list tmp; +- va_copy(tmp, args); +- const int length = vsnprintf(NULL, 0, fmt, tmp); +- va_end(tmp); +- +- if (length <= 0) +- /* wtf.. */ +- abort(); +- +- char *buffer = new char[length + 1]; +- vsnprintf(buffer, length + 1, fmt, args); +- return AllocatedString<>::Donate(buffer); +-#else ++//#ifndef WIN32 ++// va_list tmp; ++// va_copy(tmp, args); ++// const int length = vsnprintf(NULL, 0, fmt, tmp); ++// va_end(tmp); ++ ++// if (length <= 0) ++// /* wtf.. */ ++// abort(); ++// ++// char *buffer = new char[length + 1]; ++// vsnprintf(buffer, length + 1, fmt, args); ++// return AllocatedString<>::Donate(buffer); ++// char *buf = new char[128]; ++// strcpy(buf, "fucked shit"); ++// return AllocatedString<>::Donate(buf); ++//#else + /* On mingw32, snprintf() expects a 64 bit integer instead of + a "long int" for "%li". This is not consistent with our + expectation, so we're using plain sprintf() here, hoping + the static buffer is large enough. Sorry for this hack, + but WIN32 development is so painful, I'm not in the mood to + do it properly now. */ +- +- char buffer[16384]; +- vsprintf(buffer, fmt, args); +- +- const size_t length = strlen(buffer); +- char *p = new char[length + 1]; +- memcpy(p, buffer, length + 1); +- return AllocatedString<>::Donate(buffer); +-#endif ++ ++ if(!fmt) ++ abort(); ++ const int buf_len = 16384; ++ char buffer[buf_len]; ++ vsnprintf(buffer, buf_len-1, fmt, args); ++ ++// const size_t length = strlen(buffer); ++// char *p = new char[length + 1]; ++ char *p = strdup(buffer); ++ return AllocatedString<>::Donate(p); ++//#endif + } + + AllocatedString<> diff --git a/media-sound/mpd/mpd-0.20.9-r1.ebuild b/media-sound/mpd/mpd-0.20.9-r1.ebuild new file mode 100644 index 0000000..bce5e9d --- /dev/null +++ b/media-sound/mpd/mpd-0.20.9-r1.ebuild @@ -0,0 +1,261 @@ +# Copyright 1999-2017 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 + +EAPI=6 + +inherit autotools eutils flag-o-matic linux-info multilib systemd user + +DESCRIPTION="The Music Player Daemon (mpd)" +HOMEPAGE="https://www.musicpd.org https://github.com/MusicPlayerDaemon/MPD" +SRC_URI="https://www.musicpd.org/download/${PN}/${PV%.*}/${P}.tar.xz" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ppc ~ppc64 ~sh ~x86 ~x86-fbsd ~x64-macos" +IUSE="adplug +alsa ao audiofile bzip2 cdio +curl debug +eventfd expat faad + +fifo +ffmpeg flac fluidsynth gme +icu +id3tag +inotify +ipv6 jack + lame mms libav libmpdclient libsamplerate libsoxr +mad mikmod modplug + mpg123 musepack +network nfs ogg openal opus oss pipe pulseaudio recorder + samba selinux sid +signalfd sndfile soundcloud sqlite systemd tcpd twolame + unicode upnp vorbis wavpack wildmidi zeroconf zip zlib" + +OUTPUT_PLUGINS="alsa ao fifo jack network openal oss pipe pulseaudio recorder" +DECODER_PLUGINS="adplug audiofile faad ffmpeg flac fluidsynth mad mikmod + modplug mpg123 musepack ogg flac sid vorbis wavpack wildmidi" +ENCODER_PLUGINS="audiofile flac lame twolame vorbis" + +REQUIRED_USE=" + || ( ${OUTPUT_PLUGINS} ) + || ( ${DECODER_PLUGINS} ) + network? ( || ( ${ENCODER_PLUGINS} ) ) + recorder? ( || ( ${ENCODER_PLUGINS} ) ) + opus? ( ogg ) + upnp? ( expat ) +" + +CDEPEND="!<sys-cluster/mpich2-1.4_rc2 + adplug? ( media-libs/adplug ) + alsa? ( + media-sound/alsa-utils + media-libs/alsa-lib + ) + ao? ( media-libs/libao[alsa?,pulseaudio?] ) + audiofile? ( media-libs/audiofile ) + bzip2? ( app-arch/bzip2 ) + cdio? ( dev-libs/libcdio-paranoia ) + curl? ( net-misc/curl ) + expat? ( dev-libs/expat ) + faad? ( media-libs/faad2 ) + ffmpeg? ( + libav? ( media-video/libav:0= ) + !libav? ( media-video/ffmpeg:0= ) + ) + flac? ( media-libs/flac[ogg?] ) + fluidsynth? ( media-sound/fluidsynth ) + gme? ( >=media-libs/game-music-emu-0.6.0_pre20120802 ) + icu? ( dev-libs/icu:= ) + id3tag? ( media-libs/libid3tag ) + jack? ( virtual/jack ) + lame? ( network? ( media-sound/lame ) ) + libmpdclient? ( media-libs/libmpdclient ) + libsamplerate? ( media-libs/libsamplerate ) + mad? ( media-libs/libmad ) + mikmod? ( media-libs/libmikmod:0 ) + mms? ( media-libs/libmms ) + modplug? ( media-libs/libmodplug ) + mpg123? ( >=media-sound/mpg123-1.12.2 ) + musepack? ( media-sound/musepack-tools ) + network? ( + >=media-libs/libshout-2 + !lame? ( !vorbis? ( media-libs/libvorbis ) ) + ) + nfs? ( net-fs/libnfs ) + ogg? ( media-libs/libogg ) + openal? ( media-libs/openal ) + opus? ( media-libs/opus ) + pulseaudio? ( media-sound/pulseaudio ) + samba? ( >=net-fs/samba-4.0.25 ) + sid? ( || ( media-libs/libsidplay:2 media-libs/libsidplayfp ) ) + sndfile? ( media-libs/libsndfile ) + soundcloud? ( >=dev-libs/yajl-2:= ) + libsoxr? ( media-libs/soxr ) + sqlite? ( dev-db/sqlite:3 ) + systemd? ( sys-apps/systemd ) + tcpd? ( sys-apps/tcp-wrappers ) + twolame? ( media-sound/twolame ) + upnp? ( net-libs/libupnp:= ) + vorbis? ( media-libs/libvorbis ) + wavpack? ( media-sound/wavpack ) + wildmidi? ( media-sound/wildmidi ) + zeroconf? ( net-dns/avahi[dbus] ) + zip? ( dev-libs/zziplib ) + zlib? ( sys-libs/zlib )" +DEPEND="${CDEPEND} + dev-libs/boost + virtual/pkgconfig" +RDEPEND="${CDEPEND} + selinux? ( sec-policy/selinux-mpd ) +" + +PATCHES=( + "${FILESDIR}"/mpdconf.patch + "${FILESDIR}"/string_crashfix.patch +) + +pkg_setup() { + use network || ewarn "Icecast and Shoutcast streaming needs networking." + use fluidsynth && ewarn "Using fluidsynth is discouraged by upstream." + + enewuser mpd "" "" "/var/lib/mpd" audio + + if use eventfd; then + CONFIG_CHECK+=" ~EVENTFD" + ERROR_EVENTFD="${P} requires eventfd in-kernel support." + fi + if use signalfd; then + CONFIG_CHECK+=" ~SIGNALFD" + ERROR_SIGNALFD="${P} requires signalfd in-kernel support." + fi + if use inotify; then + CONFIG_CHECK+=" ~INOTIFY_USER" + ERROR_INOTIFY_USER="${P} requires inotify in-kernel support." + fi + if use eventfd || use signalfd || use inotify; then + linux-info_pkg_setup + fi + + elog "If you will be starting mpd via /etc/init.d/mpd, please make + sure that MPD's pid_file is _set_." +} + +src_prepare() { + cp -f doc/mpdconf.example doc/mpdconf.dist || die "cp failed" + default + eautoreconf +} + +src_configure() { + local myeconfargs=( + --enable-database --disable-roar --disable-documentation + --enable-dsd --enable-largefile --disable-osx --disable-shine-encoder + --disable-solaris-output --enable-tcp --enable-un --disable-werror + --docdir="${EPREFIX}"/usr/share/doc/${PF} + ) + + if use network; then + myeconfargs+=( + --enable-shout + $(use_enable vorbis vorbis-encoder) + --enable-httpd-output + $(use_enable lame lame-encoder) + $(use_enable twolame twolame-encoder) + $(use_enable audiofile wave-encoder) + ) + else + myeconfargs+=( + --disable-shout + --disable-vorbis-encoder + --disable-httpd-output + --disable-lame-encoder + --disable-twolame-encoder + --disable-wave-encoder + ) + fi + + if use samba || use upnp; then + myeconfargs+=( --enable-neighbor-plugins ) + fi + + append-lfs-flags + append-ldflags "-L/usr/$(get_libdir)/sidplay/builders" + + myeconfargs+=( + $(use_enable eventfd) + $(use_enable signalfd) + $(use_enable libmpdclient) + $(use_enable expat) + $(use_enable upnp) + $(use_enable adplug) + $(use_enable alsa) + $(use_enable ao) + $(use_enable audiofile) + $(use_enable zlib) + $(use_enable bzip2) + $(use_enable cdio cdio-paranoia) + $(use_enable curl) + $(use_enable samba smbclient) + $(use_enable nfs) + $(use_enable debug) + $(use_enable ffmpeg) + $(use_enable fifo) + $(use_enable flac) + $(use_enable fluidsynth) + $(use_enable gme) + $(use_enable id3tag id3) + $(use_enable inotify) + $(use_enable ipv6) + $(use_enable cdio iso9660) + $(use_enable jack) + $(use_enable soundcloud) + $(use_enable tcpd libwrap) + $(use_enable libsamplerate lsr) + $(use_enable libsoxr soxr) + $(use_enable mad) + $(use_enable mikmod) + $(use_enable mms) + $(use_enable modplug) + $(use_enable musepack mpc) + $(use_enable mpg123) + $(use_enable openal) + $(use_enable opus) + $(use_enable oss) + $(use_enable pipe pipe-output) + $(use_enable pulseaudio pulse) + $(use_enable recorder recorder-output) + $(use_enable sid sidplay) + $(use_enable sndfile sndfile) + $(use_enable sqlite) + $(use_enable systemd systemd_daemon) + $(use_enable vorbis) + $(use_enable wavpack) + $(use_enable wildmidi) + $(use_enable zip zzip) + $(use_enable icu) + $(use_enable faad aac) + $(use_with zeroconf zeroconf avahi) + --with-systemdsystemunitdir=$(systemd_get_systemunitdir) + --with-systemduserunitdir=$(systemd_get_userunitdir) + ) + + econf "${myeconfargs[@]}" +} + +src_install() { + emake DESTDIR="${D}" install + + insinto /etc + newins doc/mpdconf.dist mpd.conf + + newinitd "${FILESDIR}"/${PN}-0.20.4.init ${PN} + + if use unicode; then + sed -i -e 's:^#filesystem_charset.*$:filesystem_charset "UTF-8":' \ + "${ED}"/etc/mpd.conf || die "sed failed" + fi + + insinto /etc/logrotate.d + newins "${FILESDIR}"/${PN}-0.20.4.logrotate ${PN} + + use prefix || diropts -m0755 -o mpd -g audio + dodir /var/lib/mpd + keepdir /var/lib/mpd + dodir /var/lib/mpd/music + keepdir /var/lib/mpd/music + dodir /var/lib/mpd/playlists + keepdir /var/lib/mpd/playlists +} + +pkg_postinst() { + # also change the homedir if the user has existed before + usermod -d "/var/lib/mpd" mpd +} |