3
0
Fork 0
forked from mirrors/nixpkgs
nixpkgs/pkgs/tools/compression/zstd/default.nix
Tobias Geerinckx-Rice 550b878e46
zstd: 0.5.1 -> 0.6.0
Changes:
- Stronger high compression modes
- Changed : highest compression modes require --ultra command to
  remove memory restrictions
- API: ZSTD_getFrameParams() provides size of decompressed content
- Fixed: zstd cli return error code > 0 and removes dst file artifact
  when decompression fails
- Various fixes and small performance improvements
2016-04-14 02:37:53 +02:00

46 lines
1.5 KiB
Nix

{ stdenv, fetchFromGitHub
, legacySupport ? false }:
stdenv.mkDerivation rec {
name = "zstd-${version}";
version = "0.6.0";
src = fetchFromGitHub {
sha256 = "1r1l4pak289bjnkak2yrw65yhxfvqcmdsh10c1k0hi0wm7k3qcbw";
rev = "v${version}";
repo = "zstd";
owner = "Cyan4973";
};
# The Makefiles don't properly use file targets, but blindly rebuild
# all dependencies on every make invocation. So no nice phases. :-(
phases = [ "unpackPhase" "installPhase" "fixupPhase" ];
makeFlags = [
"ZSTD_LEGACY_SUPPORT=${if legacySupport then "1" else "0"}"
];
installFlags = [
"PREFIX=$(out)"
];
meta = with stdenv.lib; {
description = "Zstandard real-time compression algorithm";
longDescription = ''
Zstd, short for Zstandard, is a fast lossless compression algorithm,
targeting real-time compression scenarios at zlib-level compression
ratio. Zstd can also offer stronger compression ratio at the cost of
compression speed. Speed/ratio trade-off is configurable by small
increment, to fit different situations. Note however that decompression
speed is preserved and remain roughly the same at all settings, a
property shared by most LZ compression algorithms, such as zlib.
'';
homepage = http://www.zstd.net/;
# The licence of the CLI programme is GPLv2+, that of the library BSD-2.
license = with licenses; [ gpl2Plus bsd2 ];
platforms = platforms.linux;
maintainers = with maintainers; [ nckx ];
};
}