2015-09-25 10:38:26 +01:00
|
|
|
{ stdenv, fetchurl, unicodeSupport ? true, cplusplusSupport ? true
|
2014-02-24 04:01:29 +00:00
|
|
|
, windows ? null
|
|
|
|
}:
|
|
|
|
|
|
|
|
with stdenv.lib;
|
* The stdenv setup script now defines a generic builder that allows
builders for typical Autoconf-style to be much shorten, e.g.,
. $stdenv/setup
genericBuild
The generic builder does lots of stuff automatically:
- Unpacks source archives specified by $src or $srcs (it knows about
gzip, bzip2, tar, zip, and unpacked source trees).
- Determines the source tree.
- Applies patches specified by $patches.
- Fixes libtool not to search for libraries in /lib etc.
- Runs `configure'.
- Runs `make'.
- Runs `make install'.
- Strips debug information from static libraries.
- Writes nested log information (in the format accepted by
`log2xml').
There are also lots of hooks and variables to customise the generic
builder. See `stdenv/generic/docs.txt'.
* Adapted the base packages (i.e., the ones used by stdenv) to use the
generic builder.
* We now use `curl' instead of `wget' to download files in `fetchurl'.
* Neither `curl' nor `wget' are part of stdenv. We shouldn't
encourage people to download stuff in builders (impure!).
* Updated some packages.
* `buildinputs' is now `buildInputs' (but the old name also works).
* `findInputs' in the setup script now prevents inputs from being
processed multiple times (which could happen, e.g., if an input was
a propagated input of several other inputs; this caused the size
variables like $PATH to blow up exponentially in the worst case).
* Patched GNU Make to write nested log information in the format
accepted by `log2xml'. Also, prior to writing the build command,
Make now writes a line `building X' to indicate what is being
built. This is unfortunately often obscured by the gigantic tool
invocations in many Makefiles. The actual build commands are marked
`unimportant' so that they don't clutter pages generated by
`log2html'.
svn path=/nixpkgs/trunk/; revision=845
2004-03-19 16:53:04 +00:00
|
|
|
|
2011-12-14 13:36:38 +00:00
|
|
|
stdenv.mkDerivation rec {
|
2015-05-05 07:18:13 +01:00
|
|
|
name = "pcre-8.37";
|
2010-05-20 11:32:56 +01:00
|
|
|
|
2003-11-03 10:22:00 +00:00
|
|
|
src = fetchurl {
|
2011-12-14 13:36:38 +00:00
|
|
|
url = "ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/${name}.tar.bz2";
|
2015-05-05 07:18:13 +01:00
|
|
|
sha256 = "17bqykp604p7376wj3q2nmjdhrb6v1ny8q08zdwi7qvc02l9wrsi";
|
2003-11-03 10:22:00 +00:00
|
|
|
};
|
2010-05-20 11:32:56 +01:00
|
|
|
|
2015-09-25 10:53:19 +01:00
|
|
|
patches =
|
|
|
|
[ ./cve-2015-3210.patch
|
|
|
|
./cve-2015-5073.patch
|
|
|
|
];
|
|
|
|
|
2015-07-26 23:25:53 +01:00
|
|
|
outputs = [ "out" "doc" "man" ];
|
|
|
|
|
2008-10-07 13:41:36 +01:00
|
|
|
configureFlags = ''
|
2013-02-26 09:06:20 +00:00
|
|
|
--enable-jit
|
2009-04-22 00:18:09 +01:00
|
|
|
${if unicodeSupport then "--enable-unicode-properties" else ""}
|
2008-10-07 13:41:36 +01:00
|
|
|
${if !cplusplusSupport then "--disable-cpp" else ""}
|
2015-02-19 03:18:47 +00:00
|
|
|
'';
|
2009-03-25 17:41:02 +00:00
|
|
|
|
2013-10-08 19:58:34 +01:00
|
|
|
doCheck = with stdenv; !(isCygwin || isFreeBSD);
|
|
|
|
# XXX: test failure on Cygwin
|
|
|
|
# we are running out of stack on both freeBSDs on Hydra
|
2010-10-05 14:57:31 +01:00
|
|
|
|
2014-03-03 21:31:18 +00:00
|
|
|
crossAttrs = optionalAttrs (stdenv.cross.libc == "msvcrt") {
|
2014-02-24 04:01:29 +00:00
|
|
|
buildInputs = [ windows.mingw_w64_pthreads.crossDrv ];
|
|
|
|
};
|
|
|
|
|
2009-03-25 17:41:02 +00:00
|
|
|
meta = {
|
2010-10-05 14:16:53 +01:00
|
|
|
homepage = "http://www.pcre.org/";
|
2009-03-25 17:41:02 +00:00
|
|
|
description = "A library for Perl Compatible Regular Expressions";
|
2014-06-19 05:19:00 +01:00
|
|
|
license = stdenv.lib.licenses.bsd3;
|
2010-10-05 14:16:53 +01:00
|
|
|
|
|
|
|
longDescription = ''
|
|
|
|
The PCRE library is a set of functions that implement regular
|
|
|
|
expression pattern matching using the same syntax and semantics as
|
|
|
|
Perl 5. PCRE has its own native API, as well as a set of wrapper
|
|
|
|
functions that correspond to the POSIX regular expression API. The
|
|
|
|
PCRE library is free, even for building proprietary software.
|
|
|
|
'';
|
|
|
|
|
2014-02-24 04:01:29 +00:00
|
|
|
platforms = platforms.all;
|
|
|
|
maintainers = [ maintainers.simons ];
|
2009-03-25 17:41:02 +00:00
|
|
|
};
|
2003-11-03 10:22:00 +00:00
|
|
|
}
|