+++ /dev/null
-# Copyright 1999-2015 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=4
-inherit autotools eutils
-
-DESCRIPTION="Audio sub system for multiple applications"
-HOMEPAGE="http://www.directfb.org/"
-SRC_URI="http://www.directfb.org/downloads/Core/${P}.tar.gz"
-
-LICENSE="GPL-2"
-SLOT="0"
-KEYWORDS="alpha amd64 hppa ppc ppc64 x86"
-IUSE="alsa cddb ffmpeg mad oss timidity vorbis"
-
-RDEPEND=">=dev-libs/DirectFB-${PV}
- <dev-libs/DirectFB-1.6.3
- alsa? ( media-libs/alsa-lib )
- timidity? (
- media-libs/libtimidity
- media-sound/timidity++
- )
- vorbis? ( media-libs/libvorbis )
- mad? ( media-libs/libmad )
- cddb? ( media-libs/libcddb )
- ffmpeg? ( >=virtual/ffmpeg-9 )"
-DEPEND="${RDEPEND}
- virtual/pkgconfig
- sys-apps/sed"
-
-src_prepare() {
- epatch \
- "${FILESDIR}"/${P}-gcc43.patch \
- "${FILESDIR}"/${P}-ffmpeg.patch \
- "${FILESDIR}"/${P}-ffmpeg-0.6.90.patch \
- "${FILESDIR}"/${P}-ffmpeg-0.10.patch \
- "${FILESDIR}"/${P}-libavformat54.patch \
- "${FILESDIR}"/${P}-libav-0.8.1.patch \
- "${FILESDIR}"/${P}-libav-9.patch \
- "${FILESDIR}"/${P}-ffmpeg2.patch \
- "${FILESDIR}"/${P}-segfault.patch
-
- sed -i -e 's:-O3 -ffast-math -pipe::' configure.in || die
-
- AT_M4DIR="m4" eautoreconf
-}
-
-src_configure() {
- local myaudio="wave"
- use alsa && myaudio+=" alsa"
- use oss && myaudio+=" oss"
-
- # Lite is used only for tests or examples.
- # Tremor isn't there with latest libvorbis.
- econf \
- --without-lite \
- --with-drivers="${myaudio}" \
- --without-examples \
- $(use_with timidity) \
- --with-wave \
- $(use_with vorbis) \
- --without-tremor \
- $(use_with mad) \
- $(use_with cddb cdda) \
- $(use_with ffmpeg) \
- --with-playlist
-}
-
-src_install() {
- emake DESTDIR="${D}" htmldir=/usr/share/doc/${PF}/html install
- dodoc AUTHORS ChangeLog NEWS README TODO
-}
+++ /dev/null
-DIST FusionSound-1.1.1.tar.gz 1103465 SHA256 573505cb6d8e39174f188ef8f749fc4c0f3476397f379d2b65ff8d07b8aa6f6d SHA512 58ede71d78165491a24f28ee7658f4ca7ea6292e3bc5dad3e54f42f785338a6ae02020a03af38e92f3a4e9b2fd5a70cc2d643dc338ffb62eeeed1a0e9d11d853 WHIRLPOOL f0905d60ca3b72daa1744e8608fc7797b335fa4978440fbfb6397ebae689a8e20a2df1509ae7f76a65b92200b975a052df4d38e9608410393863e44fc7973200
+++ /dev/null
-Parts of:
-http://cvs.pld-linux.org/cgi-bin/viewvc.cgi/cvs/packages/FusionSound/FusionSound-ffmpeg.patch?view=markup
-
-and remove a write only variable.
-https://bugs.gentoo.org/show_bug.cgi?id=405721
-
-Index: FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-===================================================================
---- FusionSound-1.1.1.orig/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-+++ FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-@@ -41,6 +41,7 @@
-
- #include <misc/sound_util.h>
-
-+#define FF_API_OLD_METADATA2 0
- #include <libavcodec/avcodec.h>
- #include <libavformat/avformat.h>
-
-@@ -476,17 +477,26 @@ static DFBResult
- IFusionSoundMusicProvider_FFmpeg_GetTrackDescription( IFusionSoundMusicProvider *thiz,
- FSTrackDescription *desc )
- {
-+ AVDictionaryEntry *tag = NULL;
-+
- DIRECT_INTERFACE_GET_DATA( IFusionSoundMusicProvider_FFmpeg )
-
- if (!desc)
- return DFB_INVARG;
-
-- direct_snputs( desc->artist, data->ctx->author, FS_TRACK_DESC_ARTIST_LENGTH );
-- direct_snputs( desc->title, data->ctx->title, FS_TRACK_DESC_TITLE_LENGTH );
-- direct_snputs( desc->album, data->ctx->album, FS_TRACK_DESC_ALBUM_LENGTH );
-- direct_snputs( desc->genre, data->ctx->genre, FS_TRACK_DESC_GENRE_LENGTH );
-- direct_snputs( desc->encoding, data->codec->codec->name, FS_TRACK_DESC_ENCODING_LENGTH );
-- desc->year = data->ctx->year;
-+ tag = av_dict_get(data->ctx->metadata, "artist", NULL, 0);
-+ if (tag) direct_snputs( desc->artist, tag->value, FS_TRACK_DESC_ARTIST_LENGTH );
-+ tag = av_dict_get(data->ctx->metadata, "title", NULL, 0);
-+ if (tag) direct_snputs( desc->title, tag->value, FS_TRACK_DESC_TITLE_LENGTH );
-+ tag = av_dict_get(data->ctx->metadata, "album", NULL, 0);
-+ if (tag) direct_snputs( desc->album, tag->value, FS_TRACK_DESC_ALBUM_LENGTH );
-+ tag = av_dict_get(data->ctx->metadata, "genre", NULL, 0);
-+ if (tag) direct_snputs( desc->genre, tag->value, FS_TRACK_DESC_GENRE_LENGTH );
-+ tag = av_dict_get(data->ctx->metadata, "encoding", NULL, 0);
-+ if (tag) direct_snputs( desc->encoding, tag->value, FS_TRACK_DESC_ENCODING_LENGTH );
-+ tag = av_dict_get(data->ctx->metadata, "year", NULL, 0);
-+ if (tag) desc->year = atoi(tag->value);
-+
- desc->bitrate = data->codec->bit_rate;
- desc->replaygain = desc->replaygain_album = 0;
-
-@@ -540,7 +550,6 @@ FFmpegStreamThread( DirectThread *thread
- IFusionSoundMusicProvider_FFmpeg_data *data = ctx;
-
- AVPacket pkt;
-- u8 *pkt_data = NULL;
- int pkt_size = 0;
- s64 pkt_pts = AV_NOPTS_VALUE;
-
-@@ -584,7 +593,6 @@ FFmpegStreamThread( DirectThread *thread
- continue;
- }
-
-- pkt_data = pkt.data;
- pkt_size = pkt.size;
- pkt_pts = pkt.pts;
- if (pkt_pts != AV_NOPTS_VALUE) {
-@@ -595,14 +603,13 @@ FFmpegStreamThread( DirectThread *thread
- }
-
- len = AVCODEC_MAX_AUDIO_FRAME_SIZE;
-- decoded = avcodec_decode_audio2( data->codec,
-- (s16*)data->buf, &len, pkt_data, pkt_size );
-+ decoded = avcodec_decode_audio3( data->codec,
-+ (s16*)data->buf, &len, &pkt );
- if (decoded < 0) {
- av_free_packet( &pkt );
- pkt_size = 0;
- }
- else {
-- pkt_data += decoded;
- pkt_size -= decoded;
- if (pkt_size <= 0)
- av_free_packet( &pkt );
-@@ -739,7 +746,6 @@ FFmpegBufferThread( DirectThread *thread
- IFusionSoundMusicProvider_FFmpeg_data *data = ctx;
-
- AVPacket pkt;
-- u8 *pkt_data = NULL;
- int pkt_size = 0;
- s64 pkt_pts = AV_NOPTS_VALUE;
- int pos = 0;
-@@ -789,7 +795,6 @@ FFmpegBufferThread( DirectThread *thread
- continue;
- }
-
-- pkt_data = pkt.data;
- pkt_size = pkt.size;
- pkt_pts = pkt.pts;
- if (pkt_pts != AV_NOPTS_VALUE) {
-@@ -800,14 +805,13 @@ FFmpegBufferThread( DirectThread *thread
- }
-
- len = AVCODEC_MAX_AUDIO_FRAME_SIZE;
-- decoded = avcodec_decode_audio2( data->codec,
-- (s16*)data->buf, &len, pkt_data, pkt_size );
-+ decoded = avcodec_decode_audio3( data->codec,
-+ (s16*)data->buf, &len, &pkt );
- if (decoded < 0) {
- av_free_packet( &pkt );
- pkt_size = 0;
- }
- else {
-- pkt_data += decoded;
- pkt_size -= decoded;
- if (pkt_size <= 0)
- av_free_packet( &pkt );
-@@ -1208,7 +1212,7 @@ Construct( IFusionSoundMusicProvider *th
- }
-
- for (i = 0; i < data->ctx->nb_streams; i++) {
-- if (data->ctx->streams[i]->codec->codec_type == CODEC_TYPE_AUDIO) {
-+ if (data->ctx->streams[i]->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
- if (!data->st || data->st->codec->bit_rate < data->ctx->streams[i]->codec->bit_rate)
- data->st = data->ctx->streams[i];
- }
+++ /dev/null
---- interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c.orig 2011-06-15 20:01:31.000000000 +0200
-+++ interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c 2011-06-15 20:01:45.000000000 +0200
-@@ -64,7 +64,7 @@
-
- DirectStream *stream;
-
-- ByteIOContext pb;
-+ AVIOContext pb;
- AVFormatContext *ctx;
- AVStream *st;
- void *iobuf;
+++ /dev/null
-diff -Naurp FusionSound-1.1.1-original/configure.in FusionSound-1.1.1/configure.in
---- FusionSound-1.1.1-original/configure.in 2008-02-11 05:31:45.000000000 -0600
-+++ FusionSound-1.1.1/configure.in 2009-04-10 15:18:02.000000000 -0600
-@@ -513,11 +513,11 @@ AC_ARG_WITH(ffmpeg,
-
- if test "x$with_ffmpeg" = "xyes"; then
- AC_MSG_CHECKING([for libavcodec/libavformat])
-- if $PKG_CONFIG libavcodec libavformat; then
-+ if $PKG_CONFIG libavcodec libavformat libavutil; then
- AC_MSG_RESULT(yes)
- ffmpeg="yes"
-- FFMPEG_CFLAGS=`$PKG_CONFIG --cflags libavcodec libavformat`
-- FFMPEG_LIBS=`$PKG_CONFIG --libs libavcodec libavformat`
-+ FFMPEG_CFLAGS=`$PKG_CONFIG --cflags libavcodec libavformat libavutil`
-+ FFMPEG_LIBS=`$PKG_CONFIG --libs libavcodec libavformat libavutil`
- else
- AC_MSG_RESULT(no)
- AC_MSG_WARN([
-diff -Naurp FusionSound-1.1.1-original/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
---- FusionSound-1.1.1-original/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c 2008-02-11 05:31:45.000000000 -0600
-+++ FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c 2009-04-10 15:18:21.000000000 -0600
-@@ -41,8 +41,8 @@
-
- #include <misc/sound_util.h>
-
--#include <avcodec.h>
--#include <avformat.h>
-+#include <libavcodec/avcodec.h>
-+#include <libavformat/avformat.h>
-
- static DFBResult
- Probe( IFusionSoundMusicProvider_ProbeContext *ctx );
-@@ -123,8 +123,8 @@ av_read_callback( void *opaque, uint8_t
- return len;
- }
-
--static offset_t
--av_seek_callback( void *opaque, offset_t offset, int whence )
-+static int64_t
-+av_seek_callback( void *opaque, int64_t offset, int whence )
- {
- IFusionSoundMusicProvider_FFmpeg_data *data = opaque;
- unsigned int pos = 0;
+++ /dev/null
-Minimal change fix to build with ffmpeg2.
-
-Index: FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-===================================================================
---- FusionSound-1.1.1.orig/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-+++ FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-@@ -46,6 +46,10 @@
- #include <libavformat/avformat.h>
- #include <libavutil/mathematics.h>
-
-+#ifndef MAX_AUDIO_FRAME_SIZE
-+#define AVCODEC_MAX_AUDIO_FRAME_SIZE 192000 // 1 second of 48khz 32bit audio
-+#endif
-+
- static DFBResult
- Probe( IFusionSoundMusicProvider_ProbeContext *ctx );
-
-@@ -416,11 +420,11 @@ IFusionSoundMusicProvider_FFmpeg_Destruc
- /* Ugly hack to fix a bug (segfault) in url_fclose() */
- if (!(iformat->flags & AVFMT_NOFILE)) {
- iformat->flags |= AVFMT_NOFILE;
-- av_close_input_file( data->ctx );
-+ avformat_close_input( &data->ctx );
- iformat->flags ^= AVFMT_NOFILE;
- }
- else {
-- av_close_input_file( data->ctx );
-+ avformat_close_input( &data->ctx );
- }
- }
-
+++ /dev/null
---- src/fusionsound.c.old 2009-01-16 14:28:27.000000000 +0100
-+++ src/fusionsound.c 2009-01-16 14:33:34.000000000 +0100
-@@ -116,7 +116,7 @@
- return fs_config_set( name, value );
- }
-
--DirectResult
-+DFBResult
- FusionSoundCreate( IFusionSound **ret_interface )
- {
- DFBResult ret;
-@@ -160,8 +160,8 @@
- return ret;
- }
-
--DirectResult
--FusionSoundError( const char *msg, DirectResult error )
-+DFBResult
-+FusionSoundError( const char *msg, DFBResult error )
- {
- if (msg)
- fprintf( stderr, "(#) FusionSound Error [%s]: %s\n", msg, DirectResultString( error ) );
-@@ -172,7 +172,7 @@
- }
-
- DFBResult
--FusionSoundErrorFatal( const char *msg, DirectResult error )
-+FusionSoundErrorFatal( const char *msg, DFBResult error )
- {
- FusionSoundError( msg, error );
-
-@@ -180,7 +180,7 @@
- }
-
- const char *
--FusionSoundErrorString( DirectResult error )
-+FusionSoundErrorString( DFBResult error )
- {
- return DirectResultString( error );
- }
+++ /dev/null
-diff -Naur FusionSound-1.1.1.orig/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
---- FusionSound-1.1.1.orig/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c 2012-04-17 15:13:57.864935809 +0200
-+++ FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c 2012-04-17 15:15:07.299067761 +0200
-@@ -44,6 +44,7 @@
- #define FF_API_OLD_METADATA2 0
- #include <libavcodec/avcodec.h>
- #include <libavformat/avformat.h>
-+#include <libavutil/mathematics.h>
-
- static DFBResult
- Probe( IFusionSoundMusicProvider_ProbeContext *ctx );
+++ /dev/null
-diff -burN FusionSound-1.1.1.old//interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
---- FusionSound-1.1.1.old//interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c 2012-11-25 14:41:46.306782213 +0100
-+++ FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c 2012-11-25 14:46:14.151772465 +0100
-@@ -1197,7 +1197,7 @@
- return DFB_FAILURE;
- }
-
-- if (av_find_stream_info( data->ctx ) < 0) {
-+ if (avformat_find_stream_info( data->ctx, NULL ) < 0) {
- D_ERROR( "IFusionSoundMusicProvider_FFmpeg: couldn't find stream info!\n" );
- IFusionSoundMusicProvider_FFmpeg_Destruct( thiz );
- return DFB_FAILURE;
-@@ -1218,7 +1218,7 @@
-
- data->codec = data->st->codec;
- c = avcodec_find_decoder( data->codec->codec_id );
-- if (!c || avcodec_open( data->codec, c ) < 0) {
-+ if (!c || avcodec_open2( data->codec, c, NULL ) < 0) {
- D_ERROR( "IFusionSoundMusicProvider_FFmpeg: couldn't find audio decoder!\n" );
- IFusionSoundMusicProvider_FFmpeg_Destruct( thiz );
- return DFB_FAILURE;
+++ /dev/null
-Index: FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-===================================================================
---- FusionSound-1.1.1.orig/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-+++ FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-@@ -65,7 +65,6 @@ typedef struct {
-
- DirectStream *stream;
-
-- AVIOContext pb;
- AVFormatContext *ctx;
- AVStream *st;
- void *iobuf;
-@@ -1191,16 +1190,8 @@ Construct( IFusionSoundMusicProvider *th
- return D_OOM();
- }
-
-- if (init_put_byte( &data->pb, data->iobuf, 4096, 0,
-- (void*)data, av_read_callback, NULL,
-- direct_stream_seekable( stream ) ? av_seek_callback : NULL ) < 0) {
-- D_ERROR( "IFusionSoundMusicProvider_FFmpeg: init_put_byte() failed!\n" );
-- IFusionSoundMusicProvider_FFmpeg_Destruct( thiz );
-- return DFB_INIT;
-- }
--
-- if (av_open_input_stream( &data->ctx, &data->pb, filename, fmt, NULL ) < 0) {
-- D_ERROR( "IFusionSoundMusicProvider_FFmpeg: av_open_input_stream() failed!\n" );
-+ if (avformat_open_input( &data->ctx, filename, fmt, NULL ) < 0) {
-+ D_ERROR( "IFusionSoundMusicProvider_FFmpeg: avformat_open_input() failed!\n" );
- IFusionSoundMusicProvider_FFmpeg_Destruct( thiz );
- return DFB_FAILURE;
- }
+++ /dev/null
-Fixes a segfault on probe.
-
-Index: FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-===================================================================
---- FusionSound-1.1.1.orig/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-+++ FusionSound-1.1.1/interfaces/IFusionSoundMusicProvider/ifusionsoundmusicprovider_ffmpeg.c
-@@ -1138,7 +1138,7 @@ IFusionSoundMusicProvider_FFmpeg_WaitSta
- static DFBResult
- Probe( IFusionSoundMusicProvider_ProbeContext *ctx )
- {
-- AVProbeData pd;
-+ AVProbeData pd = { 0 };
- AVInputFormat *format;
-
- av_register_all();
-@@ -1165,7 +1165,7 @@ Construct( IFusionSoundMusicProvider *th
- const char *filename,
- DirectStream *stream )
- {
-- AVProbeData pd;
-+ AVProbeData pd = { 0 };
- AVInputFormat *fmt;
- AVCodec *c;
- unsigned char buf[64];
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?>
-<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
-<pkgmetadata>
- <maintainer type="person">
- <email>hd_brummy@gentoo.org</email>
- <name>Joerg Bornkessel</name>
- </maintainer>
-<maintainer type="project">
- <email>sound@gentoo.org</email>
- <name>Gentoo Sound project</name>
- </maintainer>
-</pkgmetadata>