diff options
Diffstat (limited to 'nixpkgs/pkgs/development/libraries/gsm')
-rw-r--r-- | nixpkgs/pkgs/development/libraries/gsm/default.nix | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/development/libraries/gsm/default.nix b/nixpkgs/pkgs/development/libraries/gsm/default.nix new file mode 100644 index 000000000000..1405d4782ad3 --- /dev/null +++ b/nixpkgs/pkgs/development/libraries/gsm/default.nix @@ -0,0 +1,53 @@ +{ stdenv, fetchurl +, staticSupport ? false # Compile statically (support for packages that look for the static object) +}: + +let + inherit (stdenv) isDarwin; + inherit (stdenv.lib) optional optionalString; +in + +stdenv.mkDerivation rec { + pname = "gsm"; + version = "1.0.18"; + + src = fetchurl { + url = "http://www.quut.com/gsm/${pname}-${version}.tar.gz"; + sha256 = "041amvpz8cvxykl3pwqldrzxligmmzcg8ncdnxbg32rlqf3q1xh4"; + }; + + patchPhase = '' + # Fix include directory + sed -e 's,$(GSM_INSTALL_ROOT)/inc,$(GSM_INSTALL_ROOT)/include/gsm,' -i Makefile + '' + optionalString (!staticSupport) ( + (if isDarwin then '' + # Build dylib on Darwin + sed -e 's,libgsm.a,libgsm.dylib,' -i Makefile + sed -e 's,$(AR) $(ARFLAGS) $(LIBGSM) $(GSM_OBJECTS),$(LD) -o $(LIBGSM) -dynamiclib -install_name $(GSM_INSTALL_ROOT)/$(LIBGSM) $(GSM_OBJECTS) -lc,' -i Makefile + '' else '' + # Build ELF shared object by default + sed -e 's,libgsm.a,libgsm.so,' -i Makefile + sed -e 's/$(AR) $(ARFLAGS) $(LIBGSM) $(GSM_OBJECTS)/$(LD) -shared -Wl,-soname,libgsm.so -o $(LIBGSM) $(GSM_OBJECTS) -lc/' -i Makefile + '') + '' + # Remove line that is unused when building shared libraries + sed -e 's,$(RANLIB) $(LIBGSM),,' -i Makefile + '' + ); + + makeFlags = [ + "SHELL=${stdenv.shell}" + "INSTALL_ROOT=$(out)" + ] ++ optional stdenv.cc.isClang "CC=clang"; + + preInstall = "mkdir -p $out/{bin,lib,man/man1,man/man3,include/gsm}"; + + parallelBuild = false; + + meta = with stdenv.lib; { + description = "Lossy speech compression codec"; + homepage = http://www.quut.com/gsm/; + license = licenses.bsd2; + maintainers = with maintainers; [ codyopel raskin ]; + platforms = platforms.unix; + }; +} |