Merge pull request #116826 from OPNA2608/update/libsidplayfp-2.1.1/21.05
This commit is contained in:
commit
3783fb8475
@ -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;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -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=";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -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/";
|
||||||
|
47
pkgs/development/libraries/libexsid/default.nix
Normal file
47
pkgs/development/libraries/libexsid/default.nix
Normal 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;
|
||||||
|
};
|
||||||
|
}
|
@ -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;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user