diff options
| author | Ilia Alshanetsky <iliaa@php.net> | 2010-07-02 17:17:16 +0000 | 
|---|---|---|
| committer | Ilia Alshanetsky <iliaa@php.net> | 2010-07-02 17:17:16 +0000 | 
| commit | ef22824315adad31f09a5e56c4d8b3b2d418c283 (patch) | |
| tree | e9902aa708bfd1cbf60a1d2b3b201ef49ede98bc /ext/pcre/pcrelib/pcreposix.c | |
| parent | 8584b90199289013c79bf33e019981083ad5d103 (diff) | |
| download | php-git-ef22824315adad31f09a5e56c4d8b3b2d418c283.tar.gz | |
Upgraded bundled PCRE to version 8.10
Diffstat (limited to 'ext/pcre/pcrelib/pcreposix.c')
| -rw-r--r-- | ext/pcre/pcrelib/pcreposix.c | 20 | 
1 files changed, 14 insertions, 6 deletions
| diff --git a/ext/pcre/pcrelib/pcreposix.c b/ext/pcre/pcrelib/pcreposix.c index bae2054164..29d8446829 100644 --- a/ext/pcre/pcrelib/pcreposix.c +++ b/ext/pcre/pcrelib/pcreposix.c @@ -6,7 +6,7 @@  and semantics are as close as possible to those of the Perl 5 language.                         Written by Philip Hazel -           Copyright (c) 1997-2009 University of Cambridge +           Copyright (c) 1997-2010 University of Cambridge  -----------------------------------------------------------------------------  Redistribution and use in source and binary forms, with or without @@ -55,6 +55,11 @@ previously been set. */  #  define PCREPOSIX_EXP_DEFN __declspec(dllexport)  #endif +/* We include pcre.h before pcre_internal.h so that the PCRE library functions +are declared as "import" for Windows by defining PCRE_EXP_DECL as "import". +This is needed even though pcre_internal.h itself includes pcre.h, because it +does so after it has set PCRE_EXP_DECL to "export" if it is not already set. */ +  #include "pcre.h"  #include "pcre_internal.h"  #include "pcreposix.h" @@ -133,7 +138,7 @@ static const int eint[] = {    REG_INVARG,  /* inconsistent NEWLINE options */    REG_BADPAT,  /* \g is not followed followed by an (optionally braced) non-zero number */    REG_BADPAT,  /* a numbered reference must not be zero */ -  REG_BADPAT,  /* (*VERB) with an argument is not supported */ +  REG_BADPAT,  /* an argument is not allowed for (*ACCEPT), (*FAIL), or (*COMMIT) */    /* 60 */    REG_BADPAT,  /* (*VERB) not recognized */    REG_BADPAT,  /* number is too big */ @@ -141,7 +146,9 @@ static const int eint[] = {    REG_BADPAT,  /* digit expected after (?+ */    REG_BADPAT,  /* ] is an invalid data character in JavaScript compatibility mode */    /* 65 */ -  REG_BADPAT   /* different names for subpatterns of the same number are not allowed */ +  REG_BADPAT,  /* different names for subpatterns of the same number are not allowed */ +  REG_BADPAT,  /* (*MARK) must have an argument */ +  REG_INVARG,  /* this version of PCRE is not compiled with PCRE_UCP support */  };  /* Table of texts corresponding to POSIX error codes */ @@ -245,6 +252,7 @@ if ((cflags & REG_NEWLINE) != 0)  options |= PCRE_MULTILINE;  if ((cflags & REG_DOTALL) != 0)   options |= PCRE_DOTALL;  if ((cflags & REG_NOSUB) != 0)    options |= PCRE_NO_AUTO_CAPTURE;  if ((cflags & REG_UTF8) != 0)     options |= PCRE_UTF8; +if ((cflags & REG_UCP) != 0)      options |= PCRE_UCP;  if ((cflags & REG_UNGREEDY) != 0) options |= PCRE_UNGREEDY;  preg->re_pcre = pcre_compile2(pattern, options, &errorcode, &errorptr, @@ -334,13 +342,13 @@ if ((eflags & REG_STARTEND) != 0)  else    {    so = 0; -  eo = strlen(string); +  eo = (int)strlen(string);    }  rc = pcre_exec((const pcre *)preg->re_pcre, NULL, string + so, (eo - so), -  0, options, ovector, nmatch * 3); +  0, options, ovector, (int)(nmatch * 3)); -if (rc == 0) rc = nmatch;    /* All captured slots were filled in */ +if (rc == 0) rc = (int)nmatch;    /* All captured slots were filled in */  /* Successful match */ | 
