From 06e674531a03b77d77afcdab360b4f0334c74d51 Mon Sep 17 00:00:00 2001 From: Austen Adler Date: Sat, 2 Jan 2016 00:36:39 -0500 Subject: [PATCH] Various fixes --- media-libs/mlt/Manifest | 4 + .../mlt/files/mlt-0.9.8-ruby-link.patch | 19 ++ media-libs/mlt/mlt-0.9.8.ebuild | 177 ++++++++++++++++++ profiles/repo_name | 1 + 4 files changed, 201 insertions(+) create mode 100644 media-libs/mlt/files/mlt-0.9.8-ruby-link.patch create mode 100644 media-libs/mlt/mlt-0.9.8.ebuild create mode 100644 profiles/repo_name diff --git a/media-libs/mlt/Manifest b/media-libs/mlt/Manifest index 6bcdb2d..deddc36 100644 --- a/media-libs/mlt/Manifest +++ b/media-libs/mlt/Manifest @@ -1,2 +1,6 @@ +AUX mlt-0.9.8-ruby-link.patch 715 SHA256 7614260b5880aa457c5da1ab8e6e738fd30a64b6115f9be2de67943cd94467a4 SHA512 10515daf23469531f1b9de1fbd148c7bde0be7dc0fcd3390beb8e2a2b7723d3154687304e135a91d1a614463490fd360059dab2706a47e4e36cbaa2bede4eac5 WHIRLPOOL 62f86d0f1f8b3f6ac10d3416593d765744783e3d421f4d75e8afbf110f2e9fe00f719230437328868ccddad40b0e36e36788283a8ce0a91b54a4b9e5b2183c6a +AUX mlt-0.9.8.ebuild 4836 SHA256 032cd950088c0edcc2e7250bc918e1ab23d244d7386ed42756e8a542bf199eb8 SHA512 b54f5b919832ba50da78ed7ec5d4b4d49cd8363a569dcb1c7534a99077a605b95a9358934027e69e985c61ef34d3138abde34a4962c514d357726bf105744510 WHIRLPOOL 7642cb51cb2dbaf978b1c4c6302000413f7f32f5c69f743ee211eb4aa0006c45e682f13b2499bd487b6bfd2cff50b0ec16088f89b83d737e7774fffd4893df54 DIST mlt-0.9.8.tar.gz 1263364 SHA256 1214d6ad7fd1c3d36f0b1e64fd1c8d8a7ab6290e8452396003e79d58c0d21074 SHA512 2f3db19cbff8bdd11c53fe835fcc1c32d775ead061b2e225466376be98c622cdd18e67f66becda503a57725ac9a296bc48aae4c3ae1111ed09ba878f61fd1e10 WHIRLPOOL 615323613eeee9ea80f8d6727a05129a9dc32097a8c2bf41cb818843fa8d47885744c1534fd7d26817262f60404e4caa12ea67ae9b3f59984874981865ee9148 EBUILD mlt-0.9.8-r1.ebuild 5050 SHA256 ad2fb0210af41d281e53c22a716e699cad1870a97cd152da3d6e7739afe1d825 SHA512 35af27e5bc7a115468b7ab5a56c8df628d07b5c69da9d2e0b539860c5a60dd4af07ed56d1cde07c9636dec08b1e6af10309f06ca010a5d448911d500fdd1763b WHIRLPOOL 9520d9d3875abcd05a5e9f78260ab62d92e0f559b5ebb3caec03a33312c20424ba48752fb32172d582b40c00be3a2b9d6e3cd840951680f6bafbbcbf4bf5f4de +EBUILD mlt-0.9.8.ebuild 4836 SHA256 032cd950088c0edcc2e7250bc918e1ab23d244d7386ed42756e8a542bf199eb8 SHA512 b54f5b919832ba50da78ed7ec5d4b4d49cd8363a569dcb1c7534a99077a605b95a9358934027e69e985c61ef34d3138abde34a4962c514d357726bf105744510 WHIRLPOOL 7642cb51cb2dbaf978b1c4c6302000413f7f32f5c69f743ee211eb4aa0006c45e682f13b2499bd487b6bfd2cff50b0ec16088f89b83d737e7774fffd4893df54 +MISC metadata.xml 1331 SHA256 f25f342a10de0d73a52ced7b904c1cdc3be12fa9bef0c632a89463a814b4a643 SHA512 c61adbfe7799f41e19dc7fb1d580fd769937e744cf265d29a782511c43e85557c58ad268e7d48256c7e656e6396507b1d5c35ebd29e16eeae02e79c1e43ec172 WHIRLPOOL 48989b5551b309aa479f8b90652de90f0d17e03e41718fa2e4ae42ea80abb0bfea87c5757f25172ebee7dfb333e93f68687759be9e375e5745624bdddf8b909a diff --git a/media-libs/mlt/files/mlt-0.9.8-ruby-link.patch b/media-libs/mlt/files/mlt-0.9.8-ruby-link.patch new file mode 100644 index 0000000..9b2327d --- /dev/null +++ b/media-libs/mlt/files/mlt-0.9.8-ruby-link.patch @@ -0,0 +1,19 @@ +The build system tries to link to installed system libraries first, which +fails because the ABI has changed... + +Index: mlt-0.9.8/src/swig/ruby/build +=================================================================== +--- mlt-0.9.8.orig/src/swig/ruby/build ++++ mlt-0.9.8/src/swig/ruby/build +@@ -5,8 +5,10 @@ if ARGV.shift == 'clean' + exit 0 + end + system( "ln -sf ../mlt.i" ) ++system( "ln -sf ../../framework/libmlt.so" ) ++system( "ln -sf ../../mlt++/libmlt++.so" ) + system( "swig -c++ -ruby -I../../mlt++ -I../.. mlt.i" ) + $CFLAGS += " -I../.. " + (ENV.has_key?('CXXFLAGS')? ENV['CXXFLAGS'] : '') +-$LDFLAGS += " -L../../mlt++ -lmlt++" ++$LIBS += " -lmlt++ -lmlt -lstdc++" + create_makefile('mlt') + system( "make" ) diff --git a/media-libs/mlt/mlt-0.9.8.ebuild b/media-libs/mlt/mlt-0.9.8.ebuild new file mode 100644 index 0000000..021bf91 --- /dev/null +++ b/media-libs/mlt/mlt-0.9.8.ebuild @@ -0,0 +1,177 @@ +# Copyright 1999-2015 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Id$ + +EAPI=5 +PYTHON_COMPAT=( python2_7 ) +USE_RUBY="ruby19" +inherit eutils toolchain-funcs multilib python-single-r1 ruby-single + +DESCRIPTION="An open source multimedia framework, designed and developed for television broadcasting" +HOMEPAGE="http://www.mltframework.org/" +SRC_URI="https://github.com/mltframework/mlt/archive/v0.9.8.tar.gz -> ${P}.tar.gz" + +LICENSE="GPL-3" +SLOT="0" +KEYWORDS="~amd64 ~ppc64 ~x86 ~x86-fbsd ~amd64-linux ~x86-linux" +IUSE="compressed-lumas debug ffmpeg fftw frei0r gtk jack kde kdenlive libav libsamplerate melt opengl +cpu_flags_x86_mmx qt4 rtaudio sdl cpu_flags_x86_sse cpu_flags_x86_sse2 xine xml lua python ruby vdpau" # java perl php tcl +IUSE="${IUSE} kernel_linux" + +#rtaudio will use OSS on non linux OSes +RDEPEND=" + ffmpeg? ( + libav? ( media-video/libav:0=[vdpau?] ) + !libav? ( media-video/ffmpeg:0=[vdpau?] ) + ) + xml? ( >=dev-libs/libxml2-2.5 ) + sdl? ( >=media-libs/libsdl-1.2.10[X,opengl] + >=media-libs/sdl-image-1.2.4 ) + libsamplerate? ( >=media-libs/libsamplerate-0.1.2 ) + jack? ( >=media-sound/jack-audio-connection-kit-0.121.3 + media-libs/ladspa-sdk + >=dev-libs/libxml2-2.5 ) + fftw? ( sci-libs/fftw:3.0= ) + frei0r? ( media-plugins/frei0r-plugins ) + gtk? ( x11-libs/gtk+:2 + media-libs/libexif + x11-libs/pango ) + opengl? ( media-video/movit ) + rtaudio? ( kernel_linux? ( media-libs/alsa-lib ) ) + xine? ( >=media-libs/xine-lib-1.1.2_pre20060328-r7 ) + qt4? ( dev-qt/qtcore:4 + dev-qt/qtgui:4 + dev-qt/qtsvg:4 + media-libs/libexif + x11-libs/libX11 ) + kde? ( kde-base/kdelibs:4 + media-libs/libexif ) + !media-libs/mlt++ + lua? ( >=dev-lang/lua-5.1.4-r4:= ) + ruby? ( ${RUBY_DEPS} )" +# sox? ( media-sound/sox ) +# java? ( >=virtual/jre-1.5 ) +# perl? ( dev-lang/perl ) +# php? ( dev-lang/php ) +# tcl? ( dev-lang/tcl:0= ) + +SWIG_DEPEND=">=dev-lang/swig-2.0" +DEPEND="${RDEPEND} + virtual/pkgconfig + compressed-lumas? ( || ( media-gfx/imagemagick[png] + media-gfx/graphicsmagick[imagemagick,png] ) ) + lua? ( ${SWIG_DEPEND} virtual/pkgconfig ) + python? ( ${SWIG_DEPEND} ${PYTHON_DEPS} ) + ruby? ( ${SWIG_DEPEND} )" +# java? ( ${SWIG_DEPEND} >=virtual/jdk-1.5 ) +# perl? ( ${SWIG_DEPEND} ) +# php? ( ${SWIG_DEPEND} ) +# tcl? ( ${SWIG_DEPEND} ) + +pkg_setup() { + python-single-r1_pkg_setup +} + +src_prepare() { + epatch "${FILESDIR}"/${PN}-0.9.8-ruby-link.patch + + # respect CFLAGS LDFLAGS when building shared libraries. Bug #308873 + for x in python lua; do + sed -i "/mlt.so/s: -lmlt++ :& ${CFLAGS} ${LDFLAGS} :" src/swig/$x/build || die + done + sed -i "/^LDFLAGS/s: += :& ${LDFLAGS} :" src/swig/ruby/build || die + + epatch_user +} + +src_configure() { + tc-export CC CXX + + local myconf="--enable-gpl + --enable-gpl3 + --enable-motion-est + --target-arch=$(tc-arch-kernel) + --disable-swfdec + $(use_enable debug) + $(use_enable cpu_flags_x86_sse sse) + $(use_enable cpu_flags_x86_sse2 sse2) + $(use_enable gtk gtk2) + $(use_enable sdl) + $(use_enable jack jackrack) + $(use_enable ffmpeg avformat) + $(use_enable fftw plus) + $(use_enable frei0r) + $(use_enable melt) + $(use_enable opengl) + $(use_enable libsamplerate resample) + $(use_enable rtaudio) + $(use vdpau && echo ' --avformat-vdpau') + $(use_enable xml) + $(use_enable xine) + $(use_enable kdenlive) + $(use_enable qt4 qt) + --disable-sox" + #$(use_enable sox) FIXME + + use ffmpeg && myconf="${myconf} --avformat-swscale" + use kde || myconf="${myconf} --without-kde" + use compressed-lumas && myconf="${myconf} --luma-compress" + + ( use x86 || use amd64 ) && \ + myconf="${myconf} $(use_enable cpu_flags_x86_mmx mmx)" || + myconf="${myconf} --disable-mmx" + + if ! use melt; then + sed -i -e "s;src/melt;;" Makefile || die + fi + + # TODO: add swig language bindings + # see also http://www.mltframework.org/twiki/bin/view/MLT/ExtremeMakeover + + local swig_lang + # TODO: java perl php tcl + for i in lua python ruby ; do + use $i && swig_lang="${swig_lang} $i" + done + [ -z "${swig_lang}" ] && swig_lang="none" + + econf ${myconf} --swig-languages="${swig_lang}" + sed -i -e s/^OPT/#OPT/ "${S}/config.mak" || die +} + +src_install() { + emake DESTDIR="${D}" install + dodoc AUTHORS ChangeLog NEWS README docs/*.txt + + dodir /usr/share/${PN} + insinto /usr/share/${PN} + doins -r demo + + docinto swig + + # Install SWIG bindings + if use lua; then + cd "${S}"/src/swig/lua || die + exeinto $(pkg-config --variable INSTALL_CMOD lua) + doexe mlt.so + dodoc play.lua + fi + + if use python; then + cd "${S}"/src/swig/python || die + insinto $(python_get_sitedir) + doins mlt.py + exeinto $(python_get_sitedir) + doexe _mlt.so + dodoc play.py + python_optimize + fi + + if use ruby; then + cd "${S}"/src/swig/ruby || die + exeinto $("${EPREFIX}"/usr/bin/ruby -r rbconfig -e 'print Config::CONFIG["sitearchdir"]') + doexe mlt.so + dodoc play.rb thumbs.rb + fi + # TODO: java perl php tcl +} diff --git a/profiles/repo_name b/profiles/repo_name new file mode 100644 index 0000000..09e5a05 --- /dev/null +++ b/profiles/repo_name @@ -0,0 +1 @@ +aw-overlay