nixpkgs/pkgs/development/libraries/libiconv/default.nix

61 lines
1.9 KiB
Nix
Raw Normal View History

{ fetchurl, stdenv, lib }:
2016-02-09 14:23:16 +00:00
assert !stdenv.isLinux || stdenv ? cross; # TODO: improve on cross
stdenv.mkDerivation rec {
2017-02-18 00:15:08 +00:00
name = "libiconv-${version}";
version = "1.15";
src = fetchurl {
url = "mirror://gnu/libiconv/${name}.tar.gz";
2017-02-18 00:15:08 +00:00
sha256 = "0y1ij745r4p48mxq84rax40p10ln7fc7m243p8k8sia519i3dxfc";
};
patches = lib.optionals stdenv.isCygwin [
./libiconv-1.14-reloc.patch
./libiconv-1.14-wchar.patch
];
2016-02-09 14:23:16 +00:00
postPatch =
2016-07-22 19:22:08 +01:00
lib.optionalString ((stdenv ? cross && stdenv.cross.libc == "msvcrt") || stdenv.cc.nativeLibc)
2016-02-09 14:23:16 +00:00
''
sed '/^_GL_WARN_ON_USE (gets/d' -i srclib/stdio.in.h
'';
configureFlags =
# On Cygwin, Libtool produces a `.dll.a', which is not a "real" DLL
# (Windows' linker would need to be used somehow to produce an actual
# DLL.) Thus, build the static library too, and this is what Gettext
# will actually use.
lib.optional stdenv.isCygwin "--enable-static"
++ lib.optional stdenv.isFreeBSD "--with-pic";
crossAttrs = {
# Disable stripping to avoid "libiconv.a: Archive has no index" (MinGW).
dontStrip = true;
dontCrossStrip = true;
};
meta = {
description = "An iconv(3) implementation";
longDescription = ''
Some programs, like mailers and web browsers, must be able to convert
between a given text encoding and the user's encoding. Other programs
internally store strings in Unicode, to facilitate internal processing,
and need to convert between internal string representation (Unicode)
and external string representation (a traditional encoding) when they
are doing I/O. GNU libiconv is a conversion library for both kinds of
applications.
'';
homepage = http://www.gnu.org/software/libiconv/;
license = lib.licenses.lgpl2Plus;
2013-08-16 22:44:33 +01:00
maintainers = [ ];
# This library is not needed on GNU platforms.
hydraPlatforms = with lib.platforms; cygwin ++ darwin ++ freebsd;
};
}