2011-12-14 13:36:38 +00:00
|
|
|
{ stdenv, fetchurl, unicodeSupport ? true, cplusplusSupport ? true }:
|
* 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 {
|
2012-11-21 14:57:46 +00:00
|
|
|
name = "pcre-8.31";
|
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";
|
2012-11-21 14:57:46 +00:00
|
|
|
sha256 = "5778a02535473c7ee7838ea598c19f451e63cf5eec0bf0307a688301c9078c3c";
|
2003-11-03 10:22:00 +00:00
|
|
|
};
|
2010-05-20 11:32:56 +01:00
|
|
|
|
2010-10-05 14:57:31 +01:00
|
|
|
# The compiler on Darwin crashes with an internal error while building the
|
|
|
|
# C++ interface. Disabling optimizations on that platform remedies the
|
|
|
|
# problem. In case we ever update the Darwin GCC version, the exception for
|
|
|
|
# that platform ought to be removed.
|
2008-10-07 13:41:36 +01:00
|
|
|
configureFlags = ''
|
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 ""}
|
2010-10-06 11:29:45 +01:00
|
|
|
'' + stdenv.lib.optionalString stdenv.isDarwin "CXXFLAGS=-O0";
|
2009-03-25 17:41:02 +00:00
|
|
|
|
2012-05-24 16:03:54 +01:00
|
|
|
doCheck = !stdenv.isCygwin; # XXX: test failure on Cygwin
|
2010-10-05 14:57:31 +01:00
|
|
|
|
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";
|
2010-10-05 14:16:53 +01:00
|
|
|
license = "BSD-3";
|
|
|
|
|
|
|
|
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.
|
|
|
|
'';
|
|
|
|
|
|
|
|
platforms = stdenv.lib.platforms.all;
|
|
|
|
maintainers = [ stdenv.lib.maintainers.simons ];
|
2009-03-25 17:41:02 +00:00
|
|
|
};
|
2003-11-03 10:22:00 +00:00
|
|
|
}
|