--- /dev/null
+diff -x {arch} -x .arch-ids -urN orig/apache2/Makefile.in mod/apache2/Makefile.in
+--- orig/apache2/Makefile.in 2004-03-07 03:18:24.000000000 -0500
++++ mod/apache2/Makefile.in 2004-03-07 01:18:10.000000000 -0500
+@@ -178,7 +178,9 @@
+ @cp -p $(srcdir)/modules/http/mod_core.h $(DESTDIR)$(includedir)
+ @cp -p $(srcdir)/modules/proxy/mod_proxy.h $(DESTDIR)$(includedir)
+ @cp -p $(srcdir)/modules/ssl/*.h $(DESTDIR)$(includedir)
+- @cp -p $(srcdir)/srclib/pcre/pcre*.h $(DESTDIR)$(includedir)
++ @if test "$(AP_EXTERN_PCRE)" != "0"; then \
++ cp -p $(srcdir)/srclib/pcre/pcre*.h $(DESTDIR)$(includedir); \
++ fi;
+ @cp -p $(srcdir)/os/$(OS_DIR)/*.h $(DESTDIR)$(includedir)
+ @chmod 644 $(DESTDIR)$(includedir)/*.h
+
+diff -x {arch} -x .arch-ids -urN orig/apache2/acinclude.m4 mod/apache2/acinclude.m4
+--- orig/apache2/acinclude.m4 2004-03-07 03:18:24.000000000 -0500
++++ mod/apache2/acinclude.m4 2004-03-07 01:18:09.000000000 -0500
+@@ -494,6 +494,58 @@
+ ])
+
+ dnl
++dnl APACHE_CHECK_PCRE
++dnl Apache includes it's own version of PCRE; however, if PCRE exists
++dnl on the build system, we link against that instead of building
++dnl Apache's own PCRE.
++dnl
++AC_DEFUN(APACHE_CHECK_PCRE, [
++ AC_MSG_CHECKING(for external PCRE library)
++ ap_pcre_base=""
++ ap_test_pcre=1
++ AP_EXTERN_PCRE=0
++
++ AC_ARG_WITH([pcre], AS_HELP_STRING([--with-external-pcre],
++ [use external libpcre (versus apache-supplied pcre)]), [
++ if test "x$withval" = "xno"; then
++ ap_test_pcre=0;
++ elif test "x$withval" != "xyes" -a "x$withval" != "x"; then
++ ap_pcre_base="$withval"
++ fi
++ ])
++
++ if test "$ap_test_pcre" != "0"; then
++ ap_pcre_conf="pcre-config"
++ if test -f "$ap_pcre_base"; then
++ ap_pcre_conf="$ap_pcre_base";
++ elif test -f "$ap_pcre_base/pcre-config"; then
++ ap_pcre_conf="$ap_pcre_base/pcre-config";
++ elif test -f "$ap_pcre_base/bin/pcre-config"; then
++ ap_pcre_conf="$ap_pcre_base/bin/pcre-config";
++ fi
++
++ ap_save_CFLAGS="$CFLAGS"
++ ap_save_LIBS="$LIBS"
++ CFLAGS="$CFLAGS `$ap_pcre_conf --cflags 2>/dev/null`"
++ LIBS="$LIBS `$ap_pcre_conf --libs 2>/dev/null`"
++ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <pcre.h>]],
++ [[char *foo = pcre_version();]])], [
++ AP_EXTERN_PCRE=1
++ ], [
++ CFLAGS="$ap_save_CFLAGS"
++ LIBS="$ap_save_LIBS"
++ ])
++ fi
++
++ if test "$AP_EXTERN_PCRE" = "1"; then
++ AC_MSG_RESULT(yes)
++ else
++ AC_MSG_RESULT(no)
++ fi
++ AC_SUBST(AP_EXTERN_PCRE)
++])
++
++dnl
+ dnl APACHE_EXPORT_ARGUMENTS
+ dnl Export (via APACHE_SUBST) the various path-related variables that
+ dnl apache will use while generating scripts like autoconf and apxs and
+diff -x {arch} -x .arch-ids -urN orig/apache2/configure.in mod/apache2/configure.in
+--- orig/apache2/configure.in 2004-03-07 03:18:27.000000000 -0500
++++ mod/apache2/configure.in 2004-03-07 01:18:08.000000000 -0500
+@@ -114,10 +114,14 @@
+ AC_PROG_CC
+ AC_PROG_CPP
+
+-echo $ac_n "${nl}Configuring PCRE regular expression library ...${nl}"
+-
+-APR_SUBDIR_CONFIG(srclib/pcre,
+- [--prefix=$prefix --exec-prefix=$exec_prefix --libdir=$libdir --includedir=$includedir --bindir=$bindir])
++APACHE_CHECK_PCRE
++if test "$AP_EXTERN_PCRE" = "0"; then
++ echo $ac_n "${nl}Configuring PCRE regular expression library ...${nl}"
++ APR_SUBDIR_CONFIG(srclib/pcre,
++ [--prefix=$prefix --exec-prefix=$exec_prefix --libdir=$libdir --includedir=$includedir --bindir=$bindir])
++ AP_BUILD_SRCLIB_DIRS="$AP_BUILD_SRCLIB_DIRS pcre"
++ AP_CLEAN_SRCLIB_DIRS="pcre $AP_CLEAN_SRCLIB_DIRS"
++fi
+
+ echo $ac_n "${nl}Configuring Apache httpd ...${nl}"
+
+@@ -466,9 +470,6 @@
+ APACHE_HELP_STRING(--with-suexec-umask,umask for suexec'd process),[
+ AC_DEFINE_UNQUOTED(AP_SUEXEC_UMASK, 0$withval, [umask for suexec'd process] ) ] )
+
+-dnl AP_LIBS specifies the actual libraries. note we have some required libs.
+-AP_LIBS="$abs_builddir/srclib/pcre/libpcre.la $AP_LIBS"
+-
+ dnl APR should go after the other libs, so the right symbols can be picked up
+ AP_LIBS="$AP_LIBS `$apu_config --link-libtool --libs` `$apr_config --link-libtool --libs`"
+ APACHE_SUBST(AP_LIBS)
+diff -x {arch} -x .arch-ids -urN orig/apache2/server/Makefile.in mod/apache2/server/Makefile.in
+--- orig/apache2/server/Makefile.in 2004-03-07 03:18:46.000000000 -0500
++++ mod/apache2/server/Makefile.in 2004-03-07 02:52:53.000000000 -0500
+@@ -9,7 +9,7 @@
+ LTLIBRARY_NAME = libmain.la
+ LTLIBRARY_SOURCES = \
+ test_char.h \
+- config.c log.c main.c vhost.c util.c \
++ config.c log.c main.c vhost.c util.c util_pcre.c \
+ util_script.c util_md5.c util_cfgtree.c util_ebcdic.c util_time.c \
+ rfc1413.c connection.c listen.c \
+ mpm_common.c util_charset.c util_debug.c util_xml.c \
+diff -x {arch} -x .arch-ids -urN orig/apache2/server/util.c mod/apache2/server/util.c
+--- orig/apache2/server/util.c 2004-03-07 03:18:48.000000000 -0500
++++ mod/apache2/server/util.c 2004-03-07 03:03:54.000000000 -0500
+@@ -298,7 +298,7 @@
+
+ static apr_status_t regex_cleanup(void *preg)
+ {
+- regfree((regex_t *) preg);
++ ap_regfree((regex_t *) preg);
+ return APR_SUCCESS;
+ }
+
+@@ -307,7 +307,7 @@
+ {
+ regex_t *preg = apr_palloc(p, sizeof(regex_t));
+
+- if (regcomp(preg, pattern, cflags)) {
++ if (ap_regcomp(preg, pattern, cflags)) {
+ return NULL;
+ }
+
+@@ -319,7 +319,7 @@
+
+ AP_DECLARE(void) ap_pregfree(apr_pool_t *p, regex_t * reg)
+ {
+- regfree(reg);
++ ap_regfree(reg);
+ apr_pool_cleanup_kill(p, (void *) reg, regex_cleanup);
+ }
+
+@@ -386,25 +386,6 @@
+ return bigstring;
+ }
+
+-/*
+- * Apache stub function for the regex libraries regexec() to make sure the
+- * whole regex(3) API is available through the Apache (exported) namespace.
+- * This is especially important for the DSO situations of modules.
+- * DO NOT MAKE A MACRO OUT OF THIS FUNCTION!
+- */
+-AP_DECLARE(int) ap_regexec(regex_t *preg, const char *string,
+- size_t nmatch, regmatch_t pmatch[], int eflags)
+-{
+- return regexec(preg, string, nmatch, pmatch, eflags);
+-}
+-
+-AP_DECLARE(size_t) ap_regerror(int errcode, const regex_t *preg, char *errbuf,
+- size_t errbuf_size)
+-{
+- return regerror(errcode, preg, errbuf, errbuf_size);
+-}
+-
+-
+ /* This function substitutes for $0-$9, filling in regular expression
+ * submatches. Pass it the same nmatch and pmatch arguments that you
+ * passed ap_regexec(). pmatch should not be greater than the maximum number
+diff -x {arch} -x .arch-ids -urN orig/apache2/server/util_pcre.c mod/apache2/server/util_pcre.c
+--- orig/apache2/server/util_pcre.c 1969-12-31 19:00:00.000000000 -0500
++++ mod/apache2/server/util_pcre.c 2004-03-07 03:14:49.000000000 -0500
+@@ -0,0 +1,254 @@
++/*************************************************
++* Perl-Compatible Regular Expressions *
++*************************************************/
++
++/*
++This is a library of functions to support regular expressions whose syntax
++and semantics are as close as possible to those of the Perl 5 language. See
++the file Tech.Notes for some information on the internals.
++
++This module is a wrapper that provides a POSIX API to the underlying PCRE
++functions.
++
++Written by: Philip Hazel <ph10@cam.ac.uk>
++
++ Copyright (c) 1997-2003 University of Cambridge
++ Copyright (C) 2004 Andres Salomon <dilinger@voxel.net>
++
++-----------------------------------------------------------------------------
++Permission is granted to anyone to use this software for any purpose on any
++computer system, and to redistribute it freely, subject to the following
++restrictions:
++
++1. This software is distributed in the hope that it will be useful,
++ but WITHOUT ANY WARRANTY; without even the implied warranty of
++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
++
++2. The origin of this software must not be misrepresented, either by
++ explicit claim or by omission.
++
++3. Altered versions must be plainly marked as such, and must not be
++ misrepresented as being the original software.
++
++4. If PCRE is embedded in any software that is released under the GNU
++ General Purpose Licence (GPL), then the terms of that licence shall
++ supersede any condition above with which it is incompatible.
++----------------------------------------------------------------------------
++*/
++
++#include "apr.h"
++#include "apr_strings.h"
++#include "apr_lib.h"
++
++#define APR_WANT_STDIO
++#define APR_WANT_STRFUNC
++#include "apr_want.h"
++
++#if APR_HAVE_UNISTD_H
++#include <unistd.h>
++#endif
++#if APR_HAVE_NETDB_H
++#include <netdb.h> /* for gethostbyname() */
++#endif
++
++#define CORE_PRIVATE
++
++#include "ap_config.h"
++#include "apr_base64.h"
++#include "httpd.h"
++#include "http_main.h"
++#include "http_log.h"
++#include "http_protocol.h"
++#include "http_config.h"
++#include "util_ebcdic.h"
++
++#include <pcre.h>
++
++#ifndef PCRE_CONFIG_POSIX_MALLOC_THRESHOLD
++#define PCRE_CONFIG_POSIX_MALLOC_THRESHOLD 3
++#endif
++
++/* Table of texts corresponding to POSIX error codes */
++
++static const char *pstring[] = {
++ "", /* Dummy for value 0 */
++ "internal error", /* REG_ASSERT */
++ "invalid repeat counts in {}", /* BADBR */
++ "pattern error", /* BADPAT */
++ "? * + invalid", /* BADRPT */
++ "unbalanced {}", /* EBRACE */
++ "unbalanced []", /* EBRACK */
++ "collation error - not relevant", /* ECOLLATE */
++ "bad class", /* ECTYPE */
++ "bad escape sequence", /* EESCAPE */
++ "empty expression", /* EMPTY */
++ "unbalanced ()", /* EPAREN */
++ "bad range inside []", /* ERANGE */
++ "expression too big", /* ESIZE */
++ "failed to get memory", /* ESPACE */
++ "bad back reference", /* ESUBREG */
++ "bad argument", /* INVARG */
++ "match failed" /* NOMATCH */
++};
++
++
++
++
++/*************************************************
++* Translate error code to string *
++*************************************************/
++
++AP_DECLARE(size_t)
++ap_regerror(int errcode, const regex_t *preg, char *errbuf, size_t errbuf_size)
++{
++const char *message, *addmessage;
++size_t length, addlength;
++
++message = (errcode >= (int)(sizeof(pstring)/sizeof(char *)))?
++ "unknown error code" : pstring[errcode];
++length = strlen(message) + 1;
++
++addmessage = " at offset ";
++addlength = (preg != NULL && (int)preg->re_erroffset != -1)?
++ strlen(addmessage) + 6 : 0;
++
++if (errbuf_size > 0)
++ {
++ if (addlength > 0 && errbuf_size >= length + addlength)
++ sprintf(errbuf, "%s%s%-6d", message, addmessage, (int)preg->re_erroffset);
++ else
++ {
++ strncpy(errbuf, message, errbuf_size - 1);
++ errbuf[errbuf_size-1] = 0;
++ }
++ }
++
++return length + addlength;
++}
++
++
++
++
++/*************************************************
++* Free store held by a regex *
++*************************************************/
++
++void
++ap_regfree(regex_t *preg)
++{
++(pcre_free)(preg->re_pcre);
++}
++
++
++
++
++/*************************************************
++* Compile a regular expression *
++*************************************************/
++
++/*
++Arguments:
++ preg points to a structure for recording the compiled expression
++ pattern the pattern to compile
++ cflags compilation flags
++
++Returns: 0 on success
++ various non-zero codes on failure
++*/
++
++int
++ap_regcomp(regex_t *preg, const char *pattern, int cflags)
++{
++const char *errorptr;
++int erroffset;
++int options = 0;
++
++if ((cflags & REG_ICASE) != 0) options |= PCRE_CASELESS;
++if ((cflags & REG_NEWLINE) != 0) options |= PCRE_MULTILINE;
++
++preg->re_pcre = pcre_compile(pattern, options, &errorptr, &erroffset, NULL);
++preg->re_erroffset = erroffset;
++
++if (preg->re_pcre == NULL) return 1;
++
++preg->re_nsub = pcre_info(preg->re_pcre, NULL, NULL);
++return 0;
++}
++
++
++
++
++/*************************************************
++* Match a regular expression *
++*************************************************/
++
++/* Unfortunately, PCRE requires 3 ints of working space for each captured
++substring, so we have to get and release working store instead of just using
++the POSIX structures as was done in earlier releases when PCRE needed only 2
++ints. However, if the number of possible capturing brackets is small, use a
++block of store on the stack, to reduce the use of malloc/free. The threshold is
++in a macro that can be changed at configure time. */
++
++AP_DECLARE(int)
++ap_regexec(regex_t *preg, const char *string, size_t nmatch,
++ regmatch_t pmatch[], int eflags)
++{
++int rc;
++int options = 0;
++int *ovector = NULL;
++int small_ovector[PCRE_CONFIG_POSIX_MALLOC_THRESHOLD * 3];
++int allocated_ovector = 0;
++
++if ((eflags & REG_NOTBOL) != 0) options |= PCRE_NOTBOL;
++if ((eflags & REG_NOTEOL) != 0) options |= PCRE_NOTEOL;
++
++((regex_t *)preg)->re_erroffset = (size_t)(-1); /* Only has meaning after compile */
++
++if (nmatch > 0)
++ {
++ if (nmatch <= PCRE_CONFIG_POSIX_MALLOC_THRESHOLD)
++ {
++ ovector = &(small_ovector[0]);
++ }
++ else
++ {
++ ovector = (int *)malloc(sizeof(int) * nmatch * 3);
++ if (ovector == NULL) return REG_ESPACE;
++ allocated_ovector = 1;
++ }
++ }
++
++rc = pcre_exec(preg->re_pcre, NULL, string, (int)strlen(string), 0, options,
++ ovector, nmatch * 3);
++
++if (rc == 0) rc = nmatch; /* All captured slots were filled in */
++
++if (rc >= 0)
++ {
++ size_t i;
++ for (i = 0; i < (size_t)rc; i++)
++ {
++ pmatch[i].rm_so = ovector[i*2];
++ pmatch[i].rm_eo = ovector[i*2+1];
++ }
++ if (allocated_ovector) free(ovector);
++ for (; i < nmatch; i++) pmatch[i].rm_so = pmatch[i].rm_eo = -1;
++ return 0;
++ }
++
++else
++ {
++ if (allocated_ovector) free(ovector);
++ switch(rc)
++ {
++ case PCRE_ERROR_NOMATCH: return REG_NOMATCH;
++ case PCRE_ERROR_NULL: return REG_INVARG;
++ case PCRE_ERROR_BADOPTION: return REG_INVARG;
++ case PCRE_ERROR_BADMAGIC: return REG_INVARG;
++ case PCRE_ERROR_UNKNOWN_NODE: return REG_ASSERT;
++ case PCRE_ERROR_NOMEMORY: return REG_ESPACE;
++ default: return REG_ASSERT;
++ }
++ }
++}
++
+diff -x {arch} -x .arch-ids -urN orig/apache2/srclib/Makefile.in mod/apache2/srclib/Makefile.in
+--- orig/apache2/srclib/Makefile.in 2004-03-07 03:18:49.000000000 -0500
++++ mod/apache2/srclib/Makefile.in 2004-03-07 01:18:07.000000000 -0500
+@@ -1,5 +1,5 @@
+
+-SUBDIRS = pcre
++SUBDIRS =
+ BUILD_SUBDIRS = $(AP_BUILD_SRCLIB_DIRS)
+ CLEAN_SUBDIRS = $(AP_CLEAN_SRCLIB_DIRS)