forked from mirrors/nixpkgs
89023c38fc
I made a mistake merge. Reverting it inc778945806
undid the state on master, but now I realize it crippled the git merge mechanism. As the merge contained a mix of commits from `master..staging-next` and other commits from `staging-next..staging`, it got the `staging-next` branch into a state that was difficult to recover. I reconstructed the "desired" state of staging-next tree by: - checking out the last commit of the problematic range:4effe769e2
- `git rebase -i --preserve-merges a8a018ddc0` - dropping the mistaken merge commit and its revert from that range (while keeping reapplication from4effe769e2
) - merging the last unaffected staging-next commit (803ca85c20
) - fortunately no other commits have been pushed to staging-next yet - applying a diff on staging-next to get it into that state
75 lines
2.5 KiB
Nix
75 lines
2.5 KiB
Nix
{ stdenv, fetchFromGitHub, autoreconfHook, libtool
|
|
, threadingSupport ? true # multi-threading
|
|
, openglSupport ? false, freeglut ? null, libGL ? null, libGLU ? null # OpenGL (required for vwebp)
|
|
, pngSupport ? true, libpng ? null # PNG image format
|
|
, jpegSupport ? true, libjpeg ? null # JPEG image format
|
|
, tiffSupport ? true, libtiff ? null # TIFF image format
|
|
, gifSupport ? true, giflib ? null # GIF image format
|
|
#, wicSupport ? true # Windows Imaging Component
|
|
, alignedSupport ? false # Force aligned memory operations
|
|
, swap16bitcspSupport ? false # Byte swap for 16bit color spaces
|
|
, experimentalSupport ? false # Experimental code
|
|
, libwebpmuxSupport ? true # Build libwebpmux
|
|
, libwebpdemuxSupport ? true # Build libwebpdemux
|
|
, libwebpdecoderSupport ? true # Build libwebpdecoder
|
|
}:
|
|
|
|
assert openglSupport -> freeglut != null && libGL != null && libGLU != null;
|
|
assert pngSupport -> (libpng != null);
|
|
assert jpegSupport -> (libjpeg != null);
|
|
assert tiffSupport -> (libtiff != null);
|
|
assert gifSupport -> (giflib != null);
|
|
|
|
let
|
|
mkFlag = optSet: flag: if optSet then "--enable-${flag}" else "--disable-${flag}";
|
|
in
|
|
|
|
with stdenv.lib;
|
|
stdenv.mkDerivation rec {
|
|
pname = "libwebp";
|
|
version = "1.1.0";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "webmproject";
|
|
repo = pname;
|
|
rev = version;
|
|
sha256 = "1kl6qqa29ygqb2fpv140y59v539gdqx4vcf3mlaxhca2bks98qgm";
|
|
};
|
|
|
|
prePatch = "patchShebangs .";
|
|
|
|
configureFlags = [
|
|
(mkFlag threadingSupport "threading")
|
|
(mkFlag openglSupport "gl")
|
|
(mkFlag pngSupport "png")
|
|
(mkFlag jpegSupport "jpeg")
|
|
(mkFlag tiffSupport "tiff")
|
|
(mkFlag gifSupport "gif")
|
|
#(mkFlag (wicSupport && stdenv.isCygwin) "wic")
|
|
(mkFlag alignedSupport "aligned")
|
|
(mkFlag swap16bitcspSupport "swap-16bit-csp")
|
|
(mkFlag experimentalSupport "experimental")
|
|
(mkFlag libwebpmuxSupport "libwebpmux")
|
|
(mkFlag libwebpdemuxSupport "libwebpdemux")
|
|
(mkFlag libwebpdecoderSupport "libwebpdecoder")
|
|
];
|
|
|
|
nativeBuildInputs = [ autoreconfHook libtool ];
|
|
buildInputs = [ ]
|
|
++ optionals openglSupport [ freeglut libGL libGLU ]
|
|
++ optional pngSupport libpng
|
|
++ optional jpegSupport libjpeg
|
|
++ optional tiffSupport libtiff
|
|
++ optional gifSupport giflib;
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
meta = {
|
|
description = "Tools and library for the WebP image format";
|
|
homepage = "https://developers.google.com/speed/webp/";
|
|
license = licenses.bsd3;
|
|
platforms = platforms.all;
|
|
maintainers = with maintainers; [ codyopel ];
|
|
};
|
|
}
|