avidemux: refactor again to fix build failures

This commit is contained in:
Nikolay Amiantov 2016-04-13 18:15:36 +03:00
parent 0420a532e9
commit 76281d5dec
3 changed files with 108 additions and 90 deletions

View File

@ -1,7 +1,9 @@
{ stdenv, lib, fetchurl, cmake, pkgconfig, lndir { stdenv, lib, fetchurl, cmake, pkgconfig, lndir
, zlib, gettext, libvdpau, libva, libXv, sqlite, x265 , zlib, gettext, libvdpau, libva, libXv, sqlite
, yasm, fribidi, gtk3, qt4 , yasm, freetype, fontconfig, fribidi, gtk3, qt4
, withX265 ? true, x265
, withX264 ? true, x264 , withX264 ? true, x264
, withXvid ? true, xvidcore
, withLAME ? true, lame , withLAME ? true, lame
, withFAAC ? false, faac , withFAAC ? false, faac
, withVorbis ? true, libvorbis , withVorbis ? true, libvorbis
@ -11,8 +13,7 @@
, withVPX ? true, libvpx , withVPX ? true, libvpx
}: }:
stdenv.mkDerivation rec { let
name = "avidemux-${version}";
version = "2.6.12"; version = "2.6.12";
src = fetchurl { src = fetchurl {
@ -20,96 +21,108 @@ stdenv.mkDerivation rec {
sha256 = "0nz52yih8sff53inndkh2dba759xjzsh4b8xjww419lcpk0qp6kn"; sha256 = "0nz52yih8sff53inndkh2dba759xjzsh4b8xjww419lcpk0qp6kn";
}; };
nativeBuildInputs = [ cmake pkgconfig yasm lndir ]; common = {
buildInputs = [ zlib gettext libvdpau libva libXv sqlite x265 fribidi gtk3 qt4 ] inherit version src;
++ lib.optional withX264 x264
++ lib.optional withLAME lame
++ lib.optional withFAAC faac
++ lib.optional withVorbis libvorbis
++ lib.optional withPulse libpulseaudio
++ lib.optional withFAAD faad2
++ lib.optional withOpus libopus
++ lib.optional withVPX libvpx
;
enableParallelBuilding = false; patches = [ ./dynamic_install_dir.patch ];
outputs = [ "out" "cli" "gtk" "qt4" ]; enableParallelBuilding = false;
patches = [ ./dynamic_install_dir.patch ]; nativeBuildInputs = [ cmake pkgconfig yasm ];
buildInputs = [ zlib gettext libvdpau libva libXv sqlite fribidi fontconfig freetype ]
++ lib.optional withX264 x264
++ lib.optional withX265 x265
++ lib.optional withXvid xvidcore
++ lib.optional withLAME lame
++ lib.optional withFAAC faac
++ lib.optional withVorbis libvorbis
++ lib.optional withPulse libpulseaudio
++ lib.optional withFAAD faad2
++ lib.optional withOpus libopus
++ lib.optional withVPX libvpx
;
buildCommand = '' meta = {
unpackPhase homepage = http://fixounet.free.fr/avidemux/;
cd "$sourceRoot" description = "Free video editor designed for simple video editing tasks";
patchPhase maintainers = with stdenv.lib.maintainers; [ viric abbradar ];
platforms = with stdenv.lib.platforms; linux;
license = stdenv.lib.licenses.gpl2;
};
};
export cmakeFlags="$cmakeFlags -DAVIDEMUX_SOURCE_DIR=$(pwd)" core = stdenv.mkDerivation (common // {
name = "avidemux-${version}";
function buildOutput() { preConfigure = ''
( plugin_ui="$1" cd avidemux_core
output_dir="$2" '';
shift 2 });
export cmakeFlags="$cmakeFlags -DPLUGIN_UI=$plugin_ui -DCMAKE_INSTALL_PREFIX=$output_dir"
for i in "$@" avidemux_plugins; do
( cd "$i"
cmakeConfigurePhase
buildPhase
installPhase
)
done
rm -rf avidemux_plugins/build
)
}
function buildUi() { buildPlugin = args: stdenv.mkDerivation (common // {
plugin_ui="$1" name = "avidemux-${args.pluginName}-${version}";
output_dir="$2"
shift 2
# Hack to split builds properly buildInputs = (args.buildInputs or []) ++ common.buildInputs ++ [ lndir ];
mkdir -p $output_dir
lndir $out $output_dir
buildOutput $plugin_ui $output_dir "$@"
}
function fixupUi() { cmakeFlags = [ "-DPLUGIN_UI=${args.pluginUi}" ];
output_dir="$1"
shift
find $output_dir -lname $out\* -delete passthru.isUi = args.isUi or false;
find $output_dir -type f | while read -r f; do
rpath="$(patchelf --print-rpath $f 2>/dev/null)" || continue buildCommand = ''
new_rpath="" unpackPhase
IFS=':' read -ra old_rpath <<< "$rpath" cd "$sourceRoot"
for p in "''${old_rpath[@]}"; do patchPhase
new_rpath="$new_rpath:$p"
if [[ $p = $output_dir* ]]; then mkdir $out
new_rpath="$new_rpath:$out/''${p#$output_dir}" lndir ${core} $out
fi
done export cmakeFlags="$cmakeFlags -DAVIDEMUX_SOURCE_DIR=$(pwd)"
patchelf --set-rpath "$new_rpath" $f
patchelf --shrink-rpath $f for i in ${toString (args.buildDirs or [])} avidemux_plugins; do
( cd "$i"
cmakeConfigurePhase
buildPhase
installPhase
)
done done
}
buildOutput COMMON $out avidemux_core fixupPhase
buildOutput SETTINGS $out '';
buildUi CLI $cli avidemux/cli });
buildUi GTK $gtk avidemux/gtk
buildUi QT4 $qt4 avidemux/qt4
fixupPhase in {
avidemux_core = core;
fixupUi $cli avidemux_cli = buildPlugin {
fixupUi $gtk pluginName = "cli";
fixupUi $qt4 pluginUi = "CLI";
''; isUi = true;
buildDirs = [ "avidemux/cli" ];
};
meta = { avidemux_qt4 = buildPlugin {
homepage = http://fixounet.free.fr/avidemux/; pluginName = "qt4";
description = "Free video editor designed for simple video editing tasks"; buildInputs = [ qt4 ];
maintainers = with stdenv.lib.maintainers; [ viric abbradar ]; pluginUi = "QT4";
platforms = with stdenv.lib.platforms; linux; isUi = true;
license = stdenv.lib.licenses.gpl2; buildDirs = [ "avidemux/qt4" ];
};
avidemux_gtk = buildPlugin {
pluginName = "gtk";
buildInputs = [ gtk3 ];
pluginUi = "GTK";
isUi = true;
buildDirs = [ "avidemux/gtk" ];
};
avidemux_common = buildPlugin {
pluginName = "common";
pluginUi = "COMMON";
};
avidemux_settings = buildPlugin {
pluginName = "settings";
pluginUi = "SETTINGS";
}; };
} }

View File

@ -1,15 +1,18 @@
{ buildEnv, avidemux, makeWrapper { buildEnv, avidemux_unwrapped, makeWrapper
# GTK version is broken upstream, see https://bugzilla.redhat.com/show_bug.cgi?id=1244340 # GTK version is broken upstream, see https://bugzilla.redhat.com/show_bug.cgi?id=1244340
, withUi ? "qt4" , withUi ? "qt4"
}: }:
let let ui = builtins.getAttr "avidemux_${withUi}" avidemux_unwrapped; in
ui = builtins.getAttr withUi avidemux;
in buildEnv { assert ui.isUi;
name = "avidemux-${withUi}-" + avidemux.version;
paths = [ avidemux ui ]; buildEnv {
name = "avidemux-${withUi}-" + ui.version;
paths = [ ui avidemux_unwrapped.avidemux_common avidemux_unwrapped.avidemux_settings ];
ignoreCollisions = true;
buildInputs = [ makeWrapper ]; buildInputs = [ makeWrapper ];
@ -26,4 +29,6 @@ in buildEnv {
wrapProgram $i --set ADM_ROOT_DIR $out wrapProgram $i --set ADM_ROOT_DIR $out
done done
''; '';
meta = ui.meta;
} }

View File

@ -11628,12 +11628,12 @@ in
autopanosiftc = callPackage ../applications/graphics/autopanosiftc { }; autopanosiftc = callPackage ../applications/graphics/autopanosiftc { };
avidemux_unwrapped = callPackage ../applications/video/avidemux { }; avidemux_unwrapped = callPackage ../applications/video/avidemux {
libva = libva-full; # also wants libva-x11
avidemux = callPackage ../applications/video/avidemux/wrapper.nix {
avidemux = avidemux_unwrapped;
}; };
avidemux = callPackage ../applications/video/avidemux/wrapper.nix { };
avogadro = callPackage ../applications/science/chemistry/avogadro { avogadro = callPackage ../applications/science/chemistry/avogadro {
eigen = eigen2; eigen = eigen2;
}; };