Updated to PCRE 6.1
This commit is contained in:
parent
ffbf9fdca6
commit
c4f097bb36
Binary file not shown.
Binary file not shown.
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
// Module info
|
// Module info
|
||||||
#define MODULE_NAME "RegEx"
|
#define MODULE_NAME "RegEx"
|
||||||
#define MODULE_VERSION "1.01"
|
#define MODULE_VERSION "1.10RC1"
|
||||||
#define MODULE_AUTHOR "AMX Mod X Dev Team"
|
#define MODULE_AUTHOR "AMX Mod X Dev Team"
|
||||||
#define MODULE_URL "http://www.amxmodx.org/"
|
#define MODULE_URL "http://www.amxmodx.org/"
|
||||||
#define MODULE_LOGTAG "REGEX"
|
#define MODULE_LOGTAG "REGEX"
|
||||||
|
@ -2,7 +2,39 @@
|
|||||||
* Perl-Compatible Regular Expressions *
|
* Perl-Compatible Regular Expressions *
|
||||||
*************************************************/
|
*************************************************/
|
||||||
|
|
||||||
/* Copyright (c) 1997-2003 University of Cambridge */
|
/* In its original form, this is the .in file that is transformed by
|
||||||
|
"configure" into pcre.h.
|
||||||
|
|
||||||
|
Copyright (c) 1997-2005 University of Cambridge
|
||||||
|
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
* Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in the
|
||||||
|
documentation and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
* Neither the name of the University of Cambridge nor the names of its
|
||||||
|
contributors may be used to endorse or promote products derived from
|
||||||
|
this software without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
#ifndef _PCRE_H
|
#ifndef _PCRE_H
|
||||||
#define _PCRE_H
|
#define _PCRE_H
|
||||||
@ -10,11 +42,11 @@
|
|||||||
/* The file pcre.h is build by "configure". Do not edit it; instead
|
/* The file pcre.h is build by "configure". Do not edit it; instead
|
||||||
make changes to pcre.in. */
|
make changes to pcre.in. */
|
||||||
|
|
||||||
#define PCRE_MAJOR 4
|
#define PCRE_MAJOR 6
|
||||||
#define PCRE_MINOR 5
|
#define PCRE_MINOR 1
|
||||||
#define PCRE_DATE 01-December-2003
|
#define PCRE_DATE 21-Jun-2005
|
||||||
|
|
||||||
/* Win32 uses DLL by default */
|
/* Win32 uses DLL by default; it needs special stuff for exported functions. */
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
# ifdef PCRE_DEFINITION
|
# ifdef PCRE_DEFINITION
|
||||||
@ -27,8 +59,15 @@ make changes to pcre.in. */
|
|||||||
# endif
|
# endif
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* For other operating systems, we use the standard "extern". */
|
||||||
|
|
||||||
#ifndef PCRE_DATA_SCOPE
|
#ifndef PCRE_DATA_SCOPE
|
||||||
# define PCRE_DATA_SCOPE extern
|
# ifdef __cplusplus
|
||||||
|
# define PCRE_DATA_SCOPE extern "C"
|
||||||
|
# else
|
||||||
|
# define PCRE_DATA_SCOPE extern
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Have to include stdlib.h in order to ensure that size_t is defined;
|
/* Have to include stdlib.h in order to ensure that size_t is defined;
|
||||||
@ -44,20 +83,25 @@ extern "C" {
|
|||||||
|
|
||||||
/* Options */
|
/* Options */
|
||||||
|
|
||||||
#define PCRE_CASELESS 0x0001
|
#define PCRE_CASELESS 0x00000001
|
||||||
#define PCRE_MULTILINE 0x0002
|
#define PCRE_MULTILINE 0x00000002
|
||||||
#define PCRE_DOTALL 0x0004
|
#define PCRE_DOTALL 0x00000004
|
||||||
#define PCRE_EXTENDED 0x0008
|
#define PCRE_EXTENDED 0x00000008
|
||||||
#define PCRE_ANCHORED 0x0010
|
#define PCRE_ANCHORED 0x00000010
|
||||||
#define PCRE_DOLLAR_ENDONLY 0x0020
|
#define PCRE_DOLLAR_ENDONLY 0x00000020
|
||||||
#define PCRE_EXTRA 0x0040
|
#define PCRE_EXTRA 0x00000040
|
||||||
#define PCRE_NOTBOL 0x0080
|
#define PCRE_NOTBOL 0x00000080
|
||||||
#define PCRE_NOTEOL 0x0100
|
#define PCRE_NOTEOL 0x00000100
|
||||||
#define PCRE_UNGREEDY 0x0200
|
#define PCRE_UNGREEDY 0x00000200
|
||||||
#define PCRE_NOTEMPTY 0x0400
|
#define PCRE_NOTEMPTY 0x00000400
|
||||||
#define PCRE_UTF8 0x0800
|
#define PCRE_UTF8 0x00000800
|
||||||
#define PCRE_NO_AUTO_CAPTURE 0x1000
|
#define PCRE_NO_AUTO_CAPTURE 0x00001000
|
||||||
#define PCRE_NO_UTF8_CHECK 0x2000
|
#define PCRE_NO_UTF8_CHECK 0x00002000
|
||||||
|
#define PCRE_AUTO_CALLOUT 0x00004000
|
||||||
|
#define PCRE_PARTIAL 0x00008000
|
||||||
|
#define PCRE_DFA_SHORTEST 0x00010000
|
||||||
|
#define PCRE_DFA_RESTART 0x00020000
|
||||||
|
#define PCRE_FIRSTLINE 0x00040000
|
||||||
|
|
||||||
/* Exec-time and get/set-time error codes */
|
/* Exec-time and get/set-time error codes */
|
||||||
|
|
||||||
@ -72,6 +116,15 @@ extern "C" {
|
|||||||
#define PCRE_ERROR_CALLOUT (-9) /* Never used by PCRE itself */
|
#define PCRE_ERROR_CALLOUT (-9) /* Never used by PCRE itself */
|
||||||
#define PCRE_ERROR_BADUTF8 (-10)
|
#define PCRE_ERROR_BADUTF8 (-10)
|
||||||
#define PCRE_ERROR_BADUTF8_OFFSET (-11)
|
#define PCRE_ERROR_BADUTF8_OFFSET (-11)
|
||||||
|
#define PCRE_ERROR_PARTIAL (-12)
|
||||||
|
#define PCRE_ERROR_BADPARTIAL (-13)
|
||||||
|
#define PCRE_ERROR_INTERNAL (-14)
|
||||||
|
#define PCRE_ERROR_BADCOUNT (-15)
|
||||||
|
#define PCRE_ERROR_DFA_UITEM (-16)
|
||||||
|
#define PCRE_ERROR_DFA_UCOND (-17)
|
||||||
|
#define PCRE_ERROR_DFA_UMLIMIT (-18)
|
||||||
|
#define PCRE_ERROR_DFA_WSSIZE (-19)
|
||||||
|
#define PCRE_ERROR_DFA_RECURSE (-20)
|
||||||
|
|
||||||
/* Request types for pcre_fullinfo() */
|
/* Request types for pcre_fullinfo() */
|
||||||
|
|
||||||
@ -87,6 +140,7 @@ extern "C" {
|
|||||||
#define PCRE_INFO_NAMECOUNT 8
|
#define PCRE_INFO_NAMECOUNT 8
|
||||||
#define PCRE_INFO_NAMETABLE 9
|
#define PCRE_INFO_NAMETABLE 9
|
||||||
#define PCRE_INFO_STUDYSIZE 10
|
#define PCRE_INFO_STUDYSIZE 10
|
||||||
|
#define PCRE_INFO_DEFAULT_TABLES 11
|
||||||
|
|
||||||
/* Request types for pcre_config() */
|
/* Request types for pcre_config() */
|
||||||
|
|
||||||
@ -96,12 +150,14 @@ extern "C" {
|
|||||||
#define PCRE_CONFIG_POSIX_MALLOC_THRESHOLD 3
|
#define PCRE_CONFIG_POSIX_MALLOC_THRESHOLD 3
|
||||||
#define PCRE_CONFIG_MATCH_LIMIT 4
|
#define PCRE_CONFIG_MATCH_LIMIT 4
|
||||||
#define PCRE_CONFIG_STACKRECURSE 5
|
#define PCRE_CONFIG_STACKRECURSE 5
|
||||||
|
#define PCRE_CONFIG_UNICODE_PROPERTIES 6
|
||||||
|
|
||||||
/* Bit flags for the pcre_extra structure */
|
/* Bit flags for the pcre_extra structure */
|
||||||
|
|
||||||
#define PCRE_EXTRA_STUDY_DATA 0x0001
|
#define PCRE_EXTRA_STUDY_DATA 0x0001
|
||||||
#define PCRE_EXTRA_MATCH_LIMIT 0x0002
|
#define PCRE_EXTRA_MATCH_LIMIT 0x0002
|
||||||
#define PCRE_EXTRA_CALLOUT_DATA 0x0004
|
#define PCRE_EXTRA_CALLOUT_DATA 0x0004
|
||||||
|
#define PCRE_EXTRA_TABLES 0x0008
|
||||||
|
|
||||||
/* Types */
|
/* Types */
|
||||||
|
|
||||||
@ -109,13 +165,15 @@ struct real_pcre; /* declaration; the definition is private */
|
|||||||
typedef struct real_pcre pcre;
|
typedef struct real_pcre pcre;
|
||||||
|
|
||||||
/* The structure for passing additional data to pcre_exec(). This is defined in
|
/* The structure for passing additional data to pcre_exec(). This is defined in
|
||||||
such as way as to be extensible. */
|
such as way as to be extensible. Always add new fields at the end, in order to
|
||||||
|
remain compatible. */
|
||||||
|
|
||||||
typedef struct pcre_extra {
|
typedef struct pcre_extra {
|
||||||
unsigned long int flags; /* Bits for which fields are set */
|
unsigned long int flags; /* Bits for which fields are set */
|
||||||
void *study_data; /* Opaque data from pcre_study() */
|
void *study_data; /* Opaque data from pcre_study() */
|
||||||
unsigned long int match_limit; /* Maximum number of calls to match() */
|
unsigned long int match_limit; /* Maximum number of calls to match() */
|
||||||
void *callout_data; /* Data passed back in callouts */
|
void *callout_data; /* Data passed back in callouts */
|
||||||
|
const unsigned char *tables; /* Pointer to character tables */
|
||||||
} pcre_extra;
|
} pcre_extra;
|
||||||
|
|
||||||
/* The structure for passing out data via the pcre_callout_function. We use a
|
/* The structure for passing out data via the pcre_callout_function. We use a
|
||||||
@ -131,19 +189,21 @@ typedef struct pcre_callout_block {
|
|||||||
const char *subject; /* The subject being matched */
|
const char *subject; /* The subject being matched */
|
||||||
int subject_length; /* The length of the subject */
|
int subject_length; /* The length of the subject */
|
||||||
int start_match; /* Offset to start of this match attempt */
|
int start_match; /* Offset to start of this match attempt */
|
||||||
int current_position; /* Where we currently are */
|
int current_position; /* Where we currently are in the subject */
|
||||||
int capture_top; /* Max current capture */
|
int capture_top; /* Max current capture */
|
||||||
int capture_last; /* Most recently closed capture */
|
int capture_last; /* Most recently closed capture */
|
||||||
void *callout_data; /* Data passed in with the call */
|
void *callout_data; /* Data passed in with the call */
|
||||||
|
/* ------------------- Added for Version 1 -------------------------- */
|
||||||
|
int pattern_position; /* Offset to next item in the pattern */
|
||||||
|
int next_item_length; /* Length of next item in the pattern */
|
||||||
/* ------------------------------------------------------------------ */
|
/* ------------------------------------------------------------------ */
|
||||||
} pcre_callout_block;
|
} pcre_callout_block;
|
||||||
|
|
||||||
/* Indirection for store get and free functions. These can be set to
|
/* Indirection for store get and free functions. These can be set to
|
||||||
alternative malloc/free functions if required. Special ones are used in the
|
alternative malloc/free functions if required. Special ones are used in the
|
||||||
non-recursive case for "frames". There is also an optional callout function
|
non-recursive case for "frames". There is also an optional callout function
|
||||||
that is triggered by the (?) regex item. Some magic is required for Win32 DLL;
|
that is triggered by the (?) regex item. For Virtual Pascal, these definitions
|
||||||
it is null on other OS. For Virtual Pascal, these have to be different again.
|
have to take another form. */
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef VPCOMPAT
|
#ifndef VPCOMPAT
|
||||||
PCRE_DATA_SCOPE void *(*pcre_malloc)(size_t);
|
PCRE_DATA_SCOPE void *(*pcre_malloc)(size_t);
|
||||||
@ -152,39 +212,44 @@ PCRE_DATA_SCOPE void *(*pcre_stack_malloc)(size_t);
|
|||||||
PCRE_DATA_SCOPE void (*pcre_stack_free)(void *);
|
PCRE_DATA_SCOPE void (*pcre_stack_free)(void *);
|
||||||
PCRE_DATA_SCOPE int (*pcre_callout)(pcre_callout_block *);
|
PCRE_DATA_SCOPE int (*pcre_callout)(pcre_callout_block *);
|
||||||
#else /* VPCOMPAT */
|
#else /* VPCOMPAT */
|
||||||
extern void *pcre_malloc(size_t);
|
PCRE_DATA_SCOPE void *pcre_malloc(size_t);
|
||||||
extern void pcre_free(void *);
|
PCRE_DATA_SCOPE void pcre_free(void *);
|
||||||
extern void *pcre_stack_malloc(size_t);
|
PCRE_DATA_SCOPE void *pcre_stack_malloc(size_t);
|
||||||
extern void pcre_stack_free(void *);
|
PCRE_DATA_SCOPE void pcre_stack_free(void *);
|
||||||
extern int pcre_callout(pcre_callout_block *);
|
PCRE_DATA_SCOPE int pcre_callout(pcre_callout_block *);
|
||||||
#endif /* VPCOMPAT */
|
#endif /* VPCOMPAT */
|
||||||
|
|
||||||
/* Exported PCRE functions */
|
/* Exported PCRE functions */
|
||||||
|
|
||||||
extern pcre *pcre_compile(const char *, int, const char **,
|
PCRE_DATA_SCOPE pcre *pcre_compile(const char *, int, const char **, int *,
|
||||||
int *, const unsigned char *);
|
const unsigned char *);
|
||||||
extern int pcre_config(int, void *);
|
PCRE_DATA_SCOPE pcre *pcre_compile2(const char *, int, int *, const char **,
|
||||||
extern int pcre_copy_named_substring(const pcre *, const char *,
|
int *, const unsigned char *);
|
||||||
int *, int, const char *, char *, int);
|
PCRE_DATA_SCOPE int pcre_config(int, void *);
|
||||||
extern int pcre_copy_substring(const char *, int *, int, int,
|
PCRE_DATA_SCOPE int pcre_copy_named_substring(const pcre *, const char *,
|
||||||
char *, int);
|
int *, int, const char *, char *, int);
|
||||||
extern int pcre_exec(const pcre *, const pcre_extra *,
|
PCRE_DATA_SCOPE int pcre_copy_substring(const char *, int *, int, int, char *,
|
||||||
const char *, int, int, int, int *, int);
|
int);
|
||||||
extern void pcre_free_substring(const char *);
|
PCRE_DATA_SCOPE int pcre_dfa_exec(const pcre *, const pcre_extra *,
|
||||||
extern void pcre_free_substring_list(const char **);
|
const char *, int, int, int, int *, int , int *, int);
|
||||||
extern int pcre_fullinfo(const pcre *, const pcre_extra *, int,
|
PCRE_DATA_SCOPE int pcre_exec(const pcre *, const pcre_extra *, const char *,
|
||||||
void *);
|
int, int, int, int *, int);
|
||||||
extern int pcre_get_named_substring(const pcre *, const char *,
|
PCRE_DATA_SCOPE void pcre_free_substring(const char *);
|
||||||
int *, int, const char *, const char **);
|
PCRE_DATA_SCOPE void pcre_free_substring_list(const char **);
|
||||||
extern int pcre_get_stringnumber(const pcre *, const char *);
|
PCRE_DATA_SCOPE int pcre_fullinfo(const pcre *, const pcre_extra *, int,
|
||||||
extern int pcre_get_substring(const char *, int *, int, int,
|
void *);
|
||||||
const char **);
|
PCRE_DATA_SCOPE int pcre_get_named_substring(const pcre *, const char *,
|
||||||
extern int pcre_get_substring_list(const char *, int *, int,
|
int *, int, const char *, const char **);
|
||||||
const char ***);
|
PCRE_DATA_SCOPE int pcre_get_stringnumber(const pcre *, const char *);
|
||||||
extern int pcre_info(const pcre *, int *, int *);
|
PCRE_DATA_SCOPE int pcre_get_substring(const char *, int *, int, int,
|
||||||
extern const unsigned char *pcre_maketables(void);
|
const char **);
|
||||||
extern pcre_extra *pcre_study(const pcre *, int, const char **);
|
PCRE_DATA_SCOPE int pcre_get_substring_list(const char *, int *, int,
|
||||||
extern const char *pcre_version(void);
|
const char ***);
|
||||||
|
PCRE_DATA_SCOPE int pcre_info(const pcre *, int *, int *);
|
||||||
|
PCRE_DATA_SCOPE const unsigned char *pcre_maketables(void);
|
||||||
|
PCRE_DATA_SCOPE int pcre_refcount(pcre *, int);
|
||||||
|
PCRE_DATA_SCOPE pcre_extra *pcre_study(const pcre *, int, const char **);
|
||||||
|
PCRE_DATA_SCOPE const char *pcre_version(void);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
} /* extern "C" */
|
} /* extern "C" */
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
Optimization="0"
|
Optimization="0"
|
||||||
PreprocessorDefinitions="WIN32;_DEBUG;_WINDOWS;_USRDLL;REGEX_EXPORTS"
|
PreprocessorDefinitions="WIN32;_DEBUG;_WINDOWS;_USRDLL;REGEX_EXPORTS;PCRE_STATIC"
|
||||||
MinimalRebuild="TRUE"
|
MinimalRebuild="TRUE"
|
||||||
BasicRuntimeChecks="3"
|
BasicRuntimeChecks="3"
|
||||||
RuntimeLibrary="5"
|
RuntimeLibrary="5"
|
||||||
@ -68,7 +68,7 @@
|
|||||||
CharacterSet="2">
|
CharacterSet="2">
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCCLCompilerTool"
|
Name="VCCLCompilerTool"
|
||||||
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;REGEX_EXPORTS"
|
PreprocessorDefinitions="WIN32;NDEBUG;_WINDOWS;_USRDLL;REGEX_EXPORTS;PCRE_STATIC"
|
||||||
RuntimeLibrary="4"
|
RuntimeLibrary="4"
|
||||||
UsePrecompiledHeader="0"
|
UsePrecompiledHeader="0"
|
||||||
WarningLevel="3"
|
WarningLevel="3"
|
||||||
|
Loading…
Reference in New Issue
Block a user