2023-03-27 19:17:25 +00:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, audiofile
|
|
|
|
, libtiff
|
|
|
|
, buildPackages
|
|
|
|
, fetchpatch
|
|
|
|
, autoreconfHook
|
|
|
|
}:
|
|
|
|
|
|
|
|
stdenv.mkDerivation (finalAttrs: {
|
|
|
|
pname = "spandsp";
|
|
|
|
|
|
|
|
patches = [
|
|
|
|
# submitted upstream: https://github.com/freeswitch/spandsp/pull/47
|
|
|
|
(fetchpatch {
|
|
|
|
url = "https://github.com/freeswitch/spandsp/commit/1f810894804d3fa61ab3fc2f3feb0599145a3436.patch";
|
|
|
|
hash = "sha256-Cf8aaoriAvchh5cMb75yP2gsZbZaOLha/j5mq3xlkVA=";
|
|
|
|
})
|
|
|
|
];
|
|
|
|
|
|
|
|
outputs = [ "out" "dev" ];
|
|
|
|
|
|
|
|
nativeBuildInputs = [ autoreconfHook ];
|
|
|
|
depsBuildBuild = [ buildPackages.stdenv.cc ];
|
|
|
|
propagatedBuildInputs = [ audiofile libtiff ];
|
|
|
|
|
|
|
|
configureFlags = [
|
|
|
|
# This flag is required to prevent linking error in the cross-compilation case.
|
|
|
|
# I think it's fair to assume that realloc(NULL, size) will return a valid memory
|
|
|
|
# block for most libc implementation, so let's just assume that and hope for the best.
|
|
|
|
"ac_cv_func_malloc_0_nonnull=yes"
|
|
|
|
];
|
|
|
|
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
|
|
|
makeFlags = [
|
|
|
|
"CC=${stdenv.cc.targetPrefix}cc"
|
|
|
|
"CC_FOR_BUILD=${buildPackages.stdenv.cc}/bin/cc"
|
|
|
|
];
|
|
|
|
|
|
|
|
strictDeps = true;
|
|
|
|
|
|
|
|
meta = {
|
|
|
|
description = "A portable and modular SIP User-Agent with audio and video support";
|
|
|
|
homepage = "https://github.com/freeswitch/spandsp";
|
|
|
|
platforms = with lib.platforms; unix;
|
2024-01-02 11:29:13 +00:00
|
|
|
maintainers = with lib.maintainers; [ misuzu ];
|
2023-03-27 19:17:25 +00:00
|
|
|
license = lib.licenses.gpl2;
|
|
|
|
downloadPage = "http://www.soft-switch.org/downloads/spandsp/";
|
|
|
|
};
|
|
|
|
})
|