Merge pull request #116826 from OPNA2608/update/libsidplayfp-2.1.1/21.05

This commit is contained in:
Sandro 2021-04-15 23:57:58 +02:00 committed by GitHub
commit 3783fb8475
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 163 additions and 43 deletions

View File

@ -1,40 +1,47 @@
{ stdenv { stdenv
, lib , lib
, fetchurl , fetchFromGitHub
, autoreconfHook
, perl
, pkg-config , pkg-config
, libsidplayfp , libsidplayfp
, alsaSupport ? stdenv.hostPlatform.isLinux , alsaSupport ? stdenv.hostPlatform.isLinux
, alsaLib , alsaLib
, pulseSupport ? stdenv.hostPlatform.isLinux , pulseSupport ? stdenv.hostPlatform.isLinux
, libpulseaudio , libpulseaudio
, out123Support ? stdenv.hostPlatform.isDarwin
, mpg123
}: }:
assert alsaSupport -> alsaLib != null;
assert pulseSupport -> libpulseaudio != null;
let
inherit (lib) optional;
inherit (lib.versions) majorMinor;
in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
pname = "sidplayfp"; pname = "sidplayfp";
version = "2.0.2"; version = "2.1.1";
src = fetchurl { src = fetchFromGitHub {
url = "mirror://sourceforge/sidplay-residfp/sidplayfp/${majorMinor version}/${pname}-${version}.tar.gz"; owner = "libsidplayfp";
sha256 = "1s2dfs9z1hwarpfzawg11wax9nh0zcqx4cafwq7iysckyg4scz4k"; repo = "sidplayfp";
rev = "v${version}";
sha256 = "0s3xmg3yzfqbsnlh2y46w7b5jim5zq7mshs6hx03q8wdr75cvwh4";
}; };
nativeBuildInputs = [ pkg-config ] nativeBuildInputs = [ autoreconfHook perl pkg-config ];
++ optional alsaSupport alsaLib
++ optional pulseSupport libpulseaudio;
buildInputs = [ libsidplayfp ]; buildInputs = [ libsidplayfp ]
++ lib.optional alsaSupport alsaLib
++ lib.optional pulseSupport libpulseaudio
++ lib.optional out123Support mpg123;
configureFlags = lib.optionals out123Support [
"--with-out123"
];
enableParallelBuilding = true;
meta = with lib; { meta = with lib; {
description = "A SID player using libsidplayfp"; description = "A SID player using libsidplayfp";
homepage = "https://sourceforge.net/projects/sidplay-residfp/"; homepage = "https://github.com/libsidplayfp/sidplayfp";
license = with licenses; [ gpl2Plus ]; license = with licenses; [ gpl2Plus ];
maintainers = with maintainers; [ dezgeg ]; maintainers = with maintainers; [ dezgeg OPNA2608 ];
platforms = with platforms; linux; platforms = platforms.all;
}; };
} }

View File

@ -9,7 +9,10 @@ stdenv.mkDerivation rec {
version = "0.1.4"; version = "0.1.4";
src = fetchurl { src = fetchurl {
url = "https://www.floodgap.com/retrotech/xa/dists/${pname}-${version}.tar.gz"; urls = [
"https://www.floodgap.com/retrotech/xa/dists/${pname}-${version}.tar.gz"
"https://www.floodgap.com/retrotech/xa/dists/unsupported/${pname}-${version}.tar.gz"
];
hash = "sha256-C0rgwK51Ij9EZCm9GeiVnWIkEkse0d60ok8G9hm2a5U="; hash = "sha256-C0rgwK51Ij9EZCm9GeiVnWIkEkse0d60ok8G9hm2a5U=";
}; };

View File

@ -1,6 +1,7 @@
{ lib { lib
, stdenv , stdenv
, fetchurl , fetchurl
, perl
}: }:
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
@ -8,22 +9,39 @@ stdenv.mkDerivation rec {
version = "2.3.11"; version = "2.3.11";
src = fetchurl { src = fetchurl {
url = "https://www.floodgap.com/retrotech/xa/dists/${pname}-${version}.tar.gz"; urls = [
"https://www.floodgap.com/retrotech/xa/dists/${pname}-${version}.tar.gz"
"https://www.floodgap.com/retrotech/xa/dists/unsupported/${pname}-${version}.tar.gz"
];
hash = "sha256-MvIWTJnjBSGOmSlwhW3Y4jCbXLasR1jXsq/jv+vJAS0="; hash = "sha256-MvIWTJnjBSGOmSlwhW3Y4jCbXLasR1jXsq/jv+vJAS0=";
}; };
checkInputs = [ perl ];
dontConfigure = true; dontConfigure = true;
postPatch = '' postPatch = ''
substituteInPlace Makefile \ substituteInPlace Makefile \
--replace "DESTDIR" "PREFIX" \
--replace "CC = gcc" "CC = ${stdenv.cc.targetPrefix}cc" \ --replace "CC = gcc" "CC = ${stdenv.cc.targetPrefix}cc" \
--replace "LDD = gcc" "LDD = ${stdenv.cc.targetPrefix}cc" \ --replace "LD = gcc" "LD = ${stdenv.cc.targetPrefix}cc" \
--replace "CFLAGS = -O2" "CFLAGS ?=" \ --replace "CFLAGS = -O2" "CFLAGS ?=" \
--replace "LDFLAGS = -lc" "LDFLAGS ?= -lc" --replace "LDFLAGS = -lc" "LDFLAGS ?= -lc"
''; '';
makeFlags = [ "PREFIX=${placeholder "out"}" ]; makeFlags = [
"DESTDIR:=${placeholder "out"}"
];
enableParallelBuilding = true;
doCheck = true;
# Running tests in parallel does not work
enableParallelChecking = false;
preCheck = ''
patchShebangs tests
'';
meta = with lib; { meta = with lib; {
homepage = "https://www.floodgap.com/retrotech/xa/"; homepage = "https://www.floodgap.com/retrotech/xa/";

View File

@ -0,0 +1,47 @@
{ stdenv
, lib
, fetchFromGitHub
, autoreconfHook
, pkg-config
, docSupport ? true
, doxygen
, libftdi1
}:
stdenv.mkDerivation rec {
pname = "libexsid";
version = "2.1";
src = fetchFromGitHub {
owner = "libsidplayfp";
repo = "exsid-driver";
rev = version;
sha256 = "1qbiri549fma8c72nmj3cpz3sn1vc256kfafnygkmkzg7wdmgi7r";
};
outputs = [ "out" ]
++ lib.optional docSupport "doc";
nativeBuildInputs = [ autoreconfHook pkg-config ]
++ lib.optional docSupport doxygen;
buildInputs = [ libftdi1 ];
enableParallelBuilding = true;
installTargets = [ "install" ]
++ lib.optional docSupport "doc";
postInstall = lib.optionalString docSupport ''
mkdir -p $doc/share/libexsid/doc
cp -r docs/html $doc/share/libexsid/doc/
'';
meta = with lib; {
description = "Driver for exSID USB";
homepage = "http://hacks.slashdirt.org/hw/exsid/";
license = licenses.gpl2Plus;
maintainers = with maintainers; [ OPNA2608 ];
platforms = platforms.all;
};
}

View File

@ -1,45 +1,88 @@
{ stdenv { stdenv
, lib , lib
, fetchurl , fetchFromGitHub
, fetchpatch
, autoreconfHook
, pkg-config , pkg-config
, perl
, unittest-cpp
, xa
, libgcrypt
, libexsid
, docSupport ? true , docSupport ? true
, doxygen ? null , doxygen
, graphviz ? null , graphviz
}: }:
assert docSupport -> doxygen != null && graphviz != null;
let
inherit (lib) optionals optionalString;
inherit (lib.versions) majorMinor;
in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
pname = "libsidplayfp"; pname = "libsidplayfp";
version = "2.0.5"; version = "2.1.1";
src = fetchurl { src = fetchFromGitHub {
url = "mirror://sourceforge/sidplay-residfp/${pname}/${majorMinor version}/${pname}-${version}.tar.gz"; owner = "libsidplayfp";
sha256 = "04vdrrkh5y9x9rrmj6gdp242ah70b4sslwqfby8wp2riis4hr9z0"; repo = "libsidplayfp";
rev = "v${version}";
fetchSubmodules = true;
sha256 = "0487gap2b0ypikyra74lk1qwqwr0vncldamk5xb1db2x97v504fd";
}; };
nativeBuildInputs = [ pkg-config ] # https://github.com/libsidplayfp/libsidplayfp/issues/13
++ optionals docSupport [ doxygen graphviz ]; # Remove on next version bump
patches = [
(fetchpatch {
url = "https://github.com/libsidplayfp/libsidplayfp/commit/84f5498f5653261ed84328e1b5676c31e3ba9e6e.patch";
sha256 = "1vysbl4fkdzm11k40msng2ag6i6mb6z9jsw32vyj9calcfha5957";
})
(fetchpatch {
url = "https://github.com/libsidplayfp/libsidplayfp/commit/c1a1b732cc2e791d910522d58f47c6d094493c6d.patch";
sha256 = "1d3sgdly0q9dysgkx5afxbwfas6p0m8n3lw1hmj4n6wm3j9sdz4g";
})
];
postPatch = ''
patchShebangs .
'';
nativeBuildInputs = [ autoreconfHook pkg-config perl xa ]
++ lib.optionals docSupport [ doxygen graphviz ];
buildInputs = [ libgcrypt libexsid ];
doCheck = true;
checkInputs = [ unittest-cpp ];
enableParallelBuilding = true;
installTargets = [ "install" ] installTargets = [ "install" ]
++ optionals docSupport [ "doc" ]; ++ lib.optionals docSupport [ "doc" ];
outputs = [ "out" ] outputs = [ "out" ]
++ optionals docSupport [ "doc" ]; ++ lib.optionals docSupport [ "doc" ];
postInstall = optionalString docSupport '' configureFlags = [
"--enable-hardsid"
"--with-gcrypt"
"--with-exsid"
]
++ lib.optional doCheck "--enable-tests";
postInstall = lib.optionalString docSupport ''
mkdir -p $doc/share/doc/libsidplayfp mkdir -p $doc/share/doc/libsidplayfp
mv docs/html $doc/share/doc/libsidplayfp/ mv docs/html $doc/share/doc/libsidplayfp/
''; '';
meta = with lib; { meta = with lib; {
description = "A library to play Commodore 64 music derived from libsidplay2"; description = "A library to play Commodore 64 music derived from libsidplay2";
homepage = "https://sourceforge.net/projects/sidplay-residfp/"; longDescription = ''
libsidplayfp is a C64 music player library which integrates
the reSID SID chip emulation into a cycle-based emulator
environment, constantly aiming to improve emulation of the
C64 system and the SID chips.
'';
homepage = "https://github.com/libsidplayfp/libsidplayfp";
license = with licenses; [ gpl2Plus ]; license = with licenses; [ gpl2Plus ];
maintainers = with maintainers; [ ramkromberg ]; maintainers = with maintainers; [ ramkromberg OPNA2608 ];
platforms = with platforms; unix; platforms = platforms.all;
}; };
} }

View File

@ -15531,6 +15531,8 @@ in
libexosip = callPackage ../development/libraries/exosip {}; libexosip = callPackage ../development/libraries/exosip {};
libexsid = callPackage ../development/libraries/libexsid { };
libextractor = callPackage ../development/libraries/libextractor { libextractor = callPackage ../development/libraries/libextractor {
libmpeg2 = mpeg2dec; libmpeg2 = mpeg2dec;
}; };