Remove length argument from pcre2_config; give width if where==NULL.

This commit is contained in:
Philip.Hazel 2014-10-15 16:44:12 +00:00
parent 722817013c
commit 7d0008d453
8 changed files with 87 additions and 62 deletions

View File

@ -203,7 +203,7 @@ document for an overview of all the PCRE2 documentation.
.sp .sp
.B int pcre2_pattern_info(const pcre2 *\fIcode\fP, uint32_t \fIwhat\fP, void *\fIwhere\fP); .B int pcre2_pattern_info(const pcre2 *\fIcode\fP, uint32_t \fIwhat\fP, void *\fIwhere\fP);
.sp .sp
.B int pcre2_config(uint32_t \fIwhat\fP, void *\fIwhere\fP, PCRE2_SIZE \fIlength\fP); .B int pcre2_config(uint32_t \fIwhat\fP, void *\fIwhere\fP);
.fi .fi
. .
. .
@ -746,7 +746,7 @@ supplied, otherwise the system functions.
.SH "CHECKING BUILD-TIME OPTIONS" .SH "CHECKING BUILD-TIME OPTIONS"
.rs .rs
.sp .sp
.B int pcre2_config(uint32_t \fIwhat\fP, void *\fIwhere\fP, PCRE2_SIZE \fIlength\fP); .B int pcre2_config(uint32_t \fIwhat\fP, void *\fIwhere\fP);
.P .P
The function \fBpcre2_config()\fP makes it possible for a PCRE2 client to The function \fBpcre2_config()\fP makes it possible for a PCRE2 client to
discover which optional features have been compiled into the PCRE2 library. The discover which optional features have been compiled into the PCRE2 library. The
@ -757,12 +757,11 @@ documentation has more details about these optional features.
.P .P
The first argument for \fBpcre2_config()\fP specifies which information is The first argument for \fBpcre2_config()\fP specifies which information is
required. The second argument is a pointer to memory into which the information required. The second argument is a pointer to memory into which the information
is placed, with the final argument giving the length of this memory in bytes. is placed. If NULL is passed, the function returns the number of bytes that are
For calls that return numerical values, \fIwhere\fP should point to needed for the requested information. For calls that return numerical values,
appropriately aligned memory, with \fIlength\fP set to at least the "sizeof" \fIwhere\fP should point to appropriately aligned memory.
the data type.
.P .P
The returned value from \fBpcre2_config()\fP is zero on success, or the The returned value from \fBpcre2_config()\fP is non-negative on success, or the
negative error code PCRE2_ERROR_BADOPTION if the value in the first argument is negative error code PCRE2_ERROR_BADOPTION if the value in the first argument is
not recognized. The following information is available: not recognized. The following information is available:
.sp .sp
@ -780,10 +779,12 @@ compiling is available; otherwise it is set to zero.
.sp .sp
PCRE2_CONFIG_JITTARGET PCRE2_CONFIG_JITTARGET
.sp .sp
FIXME: this needs sorting out once JIT is implemented. The \fIwhere\fP argument should point to a buffer that is at least 64 code
If JIT support is available, the string contains the name of the architecture units long. It is filled with a string that contains the name of the
for which the JIT compiler is configured, for example "x86 32bit (little endian architecture for which the JIT compiler is configured, for example "x86 32bit
+ unaligned)". If JIT support is not available, FIXME. (little endian + unaligned)". If JIT support is not available,
PCRE2_ERROR_BADOPTION is returned, otherwise the length of the string, in code
units, is returned.
.sp .sp
PCRE2_CONFIG_LINKSIZE PCRE2_CONFIG_LINKSIZE
.sp .sp
@ -848,7 +849,8 @@ heap instead of recursive function calls.
The \fIwhere\fP argument should point to a buffer that is at least 24 code The \fIwhere\fP argument should point to a buffer that is at least 24 code
units long. If PCRE2 has been compiled without Unicode support, this is filled units long. If PCRE2 has been compiled without Unicode support, this is filled
with the text "Unicode not supported". Otherwise, the Unicode version string with the text "Unicode not supported". Otherwise, the Unicode version string
(for example, "7.0.0") is returnd. The string is zero-terminated. (for example, "7.0.0") is inserted. The string is zero-terminated. The function
returns the length of the string in code units.
.sp .sp
PCRE2_CONFIG_UNICODE PCRE2_CONFIG_UNICODE
.sp .sp
@ -858,7 +860,8 @@ otherwise it is set to zero. Unicode support implies UTF support.
PCRE2_CONFIG_VERSION PCRE2_CONFIG_VERSION
.sp .sp
The \fIwhere\fP argument should point to a buffer that is at least 12 code The \fIwhere\fP argument should point to a buffer that is at least 12 code
units long. It is filled with the PCRE2 version string, zero-terminated. units long. It is filled with the PCRE2 version string, zero-terminated. The
length of the string (in code units) is returned.
. .
. .
.SH "COMPILING A PATTERN" .SH "COMPILING A PATTERN"

View File

@ -336,7 +336,7 @@ expanded for each width below. Start with functions that give general
information. */ information. */
#define PCRE2_GENERAL_INFO_FUNCTIONS \ #define PCRE2_GENERAL_INFO_FUNCTIONS \
PCRE2_EXP_DECL int pcre2_config(uint32_t, void *, PCRE2_SIZE); PCRE2_EXP_DECL int pcre2_config(uint32_t, void *);
/* Functions for manipulating contexts. */ /* Functions for manipulating contexts. */

View File

@ -61,23 +61,48 @@ convenient for user programs that want to test their values. */
* Return info about what features are configured * * Return info about what features are configured *
*************************************************/ *************************************************/
/* Most of the requests return an int value; others require more memory and do /*
their own checks.
Arguments: Arguments:
what what information is required what what information is required
where where to put the information where where to put the information
length length of "where" in bytes
Returns: 0 if data returned Returns: 0 if data returned
PCRE2_ERROR_BADLENGTH if not enough memory >= 0 if where is NULL, giving length required
PCRE2_ERROR_BADOPTION if "where" not recognized PCRE2_ERROR_BADOPTION if "where" not recognized
or JIT target requested when JIT not enabled
*/ */
PCRE2_EXP_DEFN int PCRE2_CALL_CONVENTION PCRE2_EXP_DEFN int PCRE2_CALL_CONVENTION
pcre2_config(uint32_t what, void *where, size_t length) pcre2_config(uint32_t what, void *where)
{ {
if (length < sizeof(int)) return PCRE2_ERROR_BADLENGTH; if (where == NULL) /* Requests a length */
{
switch(what)
{
default:
return PCRE2_ERROR_BADOPTION;
case PCRE2_CONFIG_BSR:
case PCRE2_CONFIG_JIT:
case PCRE2_CONFIG_LINKSIZE:
case PCRE2_CONFIG_NEWLINE:
case PCRE2_CONFIG_STACKRECURSE:
case PCRE2_CONFIG_UNICODE:
return sizeof(int);
case PCRE2_CONFIG_MATCHLIMIT:
case PCRE2_CONFIG_PARENSLIMIT:
case PCRE2_CONFIG_RECURSIONLIMIT:
return sizeof(long int);
/* These are handled below */
case PCRE2_CONFIG_JITTARGET:
case PCRE2_CONFIG_UNICODE_VERSION:
case PCRE2_CONFIG_VERSION:
break;
}
}
switch (what) switch (what)
{ {
@ -102,18 +127,20 @@ switch (what)
case PCRE2_CONFIG_JITTARGET: case PCRE2_CONFIG_JITTARGET:
#ifdef SUPPORT_JIT #ifdef SUPPORT_JIT
return PRIV(strcpy_c8)((PCRE2_UCHAR *)where, BYTES2CU(length), PRIV(jit_get_target)()); {
const char *v = PRIV(jit_get_target)();
return (where == NULL)? (int)strlen(v) :
PRIV(strcpy_c8)((PCRE2_UCHAR *)where, v);
}
#else #else
*((const char **)where) = NULL; return PCRE2_ERROR_BADOPTION;
#endif #endif
break;
case PCRE2_CONFIG_LINKSIZE: case PCRE2_CONFIG_LINKSIZE:
*((int *)where) = configured_link_size; *((int *)where) = configured_link_size;
break; break;
case PCRE2_CONFIG_MATCHLIMIT: case PCRE2_CONFIG_MATCHLIMIT:
if (length < sizeof(unsigned long int)) return PCRE2_ERROR_BADLENGTH;
*((unsigned long int *)where) = MATCH_LIMIT; *((unsigned long int *)where) = MATCH_LIMIT;
break; break;
@ -122,12 +149,10 @@ switch (what)
break; break;
case PCRE2_CONFIG_PARENSLIMIT: case PCRE2_CONFIG_PARENSLIMIT:
if (length < sizeof(unsigned long int)) return PCRE2_ERROR_BADLENGTH;
*((unsigned long int *)where) = PARENS_NEST_LIMIT; *((unsigned long int *)where) = PARENS_NEST_LIMIT;
break; break;
case PCRE2_CONFIG_RECURSIONLIMIT: case PCRE2_CONFIG_RECURSIONLIMIT:
if (length < sizeof(unsigned long int)) return PCRE2_ERROR_BADLENGTH;
*((unsigned long int *)where) = MATCH_LIMIT_RECURSION; *((unsigned long int *)where) = MATCH_LIMIT_RECURSION;
break; break;
@ -146,7 +171,8 @@ switch (what)
#else #else
const char *v = "Unicode not supported"; const char *v = "Unicode not supported";
#endif #endif
return PRIV(strcpy_c8)((PCRE2_UCHAR *)where, BYTES2CU(length), v); return (where == NULL)? (int)strlen(v) :
PRIV(strcpy_c8)((PCRE2_UCHAR *)where, v);
} }
break; break;
@ -182,7 +208,8 @@ switch (what)
const char *v = (XSTRING(Z PCRE2_PRERELEASE)[1] == 0)? const char *v = (XSTRING(Z PCRE2_PRERELEASE)[1] == 0)?
XSTRING(PCRE2_MAJOR.PCRE2_MINOR PCRE2_DATE) : XSTRING(PCRE2_MAJOR.PCRE2_MINOR PCRE2_DATE) :
XSTRING(PCRE2_MAJOR.PCRE2_MINOR) XSTRING(PCRE2_PRERELEASE PCRE2_DATE); XSTRING(PCRE2_MAJOR.PCRE2_MINOR) XSTRING(PCRE2_PRERELEASE PCRE2_DATE);
return PRIV(strcpy_c8)((PCRE2_UCHAR *)where, BYTES2CU(length), v); return (where == NULL)? (int)strlen(v) :
PRIV(strcpy_c8)((PCRE2_UCHAR *)where, v);
} }
} }

View File

@ -1888,7 +1888,7 @@ extern void *_pcre2_memctl_malloc(size_t, pcre2_memctl *);
extern unsigned int _pcre2_ord2utf(uint32_t, PCRE2_UCHAR *); extern unsigned int _pcre2_ord2utf(uint32_t, PCRE2_UCHAR *);
extern int _pcre2_strcmp(PCRE2_SPTR, PCRE2_SPTR); extern int _pcre2_strcmp(PCRE2_SPTR, PCRE2_SPTR);
extern int _pcre2_strcmp_c8(PCRE2_SPTR, const char *); extern int _pcre2_strcmp_c8(PCRE2_SPTR, const char *);
extern int _pcre2_strcpy_c8(PCRE2_UCHAR *, size_t, const char *); extern int _pcre2_strcpy_c8(PCRE2_UCHAR *, const char *);
extern int _pcre2_strlen(PCRE2_SPTR); extern int _pcre2_strlen(PCRE2_SPTR);
extern int _pcre2_strncmp(PCRE2_SPTR, PCRE2_SPTR, size_t); extern int _pcre2_strncmp(PCRE2_SPTR, PCRE2_SPTR, size_t);
extern int _pcre2_strncmp_c8(PCRE2_SPTR, const char *, size_t); extern int _pcre2_strncmp_c8(PCRE2_SPTR, const char *, size_t);

View File

@ -98,11 +98,11 @@ int main(void)
{ {
int jit = 0; int jit = 0;
#if defined SUPPORT_PCRE2_8 #if defined SUPPORT_PCRE2_8
pcre2_config_8(PCRE2_CONFIG_JIT, &jit, sizeof(int)); pcre2_config_8(PCRE2_CONFIG_JIT, &jit);
#elif defined SUPPORT_PCRE2_16 #elif defined SUPPORT_PCRE2_16
pcre2_config_16(PCRE2_CONFIG_JIT, &jit, sizeof(int)); pcre2_config_16(PCRE2_CONFIG_JIT, &jit);
#elif defined SUPPORT_PCRE2_32 #elif defined SUPPORT_PCRE2_32
pcre2_config_32(PCRE2_CONFIG_JIT, &jit, sizeof(int)); pcre2_config_32(PCRE2_CONFIG_JIT, &jit);
#endif #endif
if (!jit) { if (!jit) {
printf("JIT must be enabled to run pcre_jit_test\n"); printf("JIT must be enabled to run pcre_jit_test\n");
@ -1123,11 +1123,11 @@ static int regression_tests(void)
still considered successful from pcre_jit_test point of view. */ still considered successful from pcre_jit_test point of view. */
#if defined SUPPORT_PCRE2_8 #if defined SUPPORT_PCRE2_8
pcre2_config_8(PCRE2_CONFIG_JITTARGET, &cpu_info, 128 * sizeof(PCRE2_UCHAR8)); pcre2_config_8(PCRE2_CONFIG_JITTARGET, &cpu_info);
#elif defined SUPPORT_PCRE2_16 #elif defined SUPPORT_PCRE2_16
pcre2_config_16(PCRE2_CONFIG_JITTARGET, &cpu_info, 128 * sizeof(PCRE2_UCHAR16)); pcre2_config_16(PCRE2_CONFIG_JITTARGET, &cpu_info);
#elif defined SUPPORT_PCRE2_32 #elif defined SUPPORT_PCRE2_32
pcre2_config_32(PCRE2_CONFIG_JITTARGET, &cpu_info, 128 * sizeof(PCRE2_UCHAR32)); pcre2_config_32(PCRE2_CONFIG_JITTARGET, &cpu_info));
#endif #endif
printf("Running JIT regression tests\n"); printf("Running JIT regression tests\n");
@ -1137,11 +1137,11 @@ static int regression_tests(void)
printf("\n"); printf("\n");
#if defined SUPPORT_PCRE2_8 #if defined SUPPORT_PCRE2_8
pcre2_config_8(PCRE2_CONFIG_UNICODE, &utf, sizeof(int)); pcre2_config_8(PCRE2_CONFIG_UNICODE, &utf);
#elif defined SUPPORT_PCRE2_16 #elif defined SUPPORT_PCRE2_16
pcre2_config_16(PCRE2_CONFIG_UNICODE, &utf, sizeof(int)); pcre2_config_16(PCRE2_CONFIG_UNICODE, &utf);
#elif defined SUPPORT_PCRE2_32 #elif defined SUPPORT_PCRE2_32
pcre2_config_32(PCRE2_CONFIG_UNICODE, &utf, sizeof(int)); pcre2_config_32(PCRE2_CONFIG_UNICODE, &utf);
#endif #endif
if (!utf) if (!utf)

View File

@ -184,18 +184,15 @@ return c;
/* Arguments: /* Arguments:
str1 buffer to receive the string str1 buffer to receive the string
length length of buffer in code units
str2 8-bit string to be copied str2 8-bit string to be copied
Returns: the number of code units used (excluding trailing zero) Returns: the number of code units used (excluding trailing zero)
PCRE2_ERROR_BADLENGTH (a negative number) if buffer is too small
*/ */
int int
PRIV(strcpy_c8)(PCRE2_UCHAR *str1, size_t length, const char *str2) PRIV(strcpy_c8)(PCRE2_UCHAR *str1, const char *str2)
{ {
PCRE2_UCHAR *t = str1; PCRE2_UCHAR *t = str1;
if (strlen(str2) >= length - 1) return PCRE2_ERROR_BADLENGTH;
while (*str2 != 0) *t++ = *str2++; while (*str2 != 0) *t++ = *str2++;
*t = 0; *t = 0;
return t - str1; return t - str1;

View File

@ -2379,7 +2379,7 @@ switch(letter)
case 'V': case 'V':
{ {
unsigned char buffer[128]; unsigned char buffer[128];
(void)pcre2_config(PCRE2_CONFIG_VERSION, buffer, 128); (void)pcre2_config(PCRE2_CONFIG_VERSION, buffer);
fprintf(stdout, "pcre2grep version %s\n", buffer); fprintf(stdout, "pcre2grep version %s\n", buffer);
} }
pcre2grep_exit(0); pcre2grep_exit(0);
@ -3026,7 +3026,7 @@ if (newline_arg != NULL)
else else
{ {
(void)pcre2_config(PCRE2_CONFIG_NEWLINE, &endlinetype, sizeof(endlinetype)); (void)pcre2_config(PCRE2_CONFIG_NEWLINE, &endlinetype);
} }
/* Interpret the text values for -d and -D */ /* Interpret the text values for -d and -D */

View File

@ -5257,7 +5257,7 @@ if (arg != NULL)
switch (coptlist[i].type) switch (coptlist[i].type)
{ {
case CONF_BSR: case CONF_BSR:
(void)PCRE2_CONFIG(coptlist[i].value, &rc, sizeof(rc)); (void)PCRE2_CONFIG(coptlist[i].value, &rc);
printf("%s\n", rc? "ANYCRLF" : "ANY"); printf("%s\n", rc? "ANYCRLF" : "ANY");
break; break;
@ -5272,12 +5272,12 @@ if (arg != NULL)
break; break;
case CONF_INT: case CONF_INT:
(void)PCRE2_CONFIG(coptlist[i].value, &yield, sizeof(yield)); (void)PCRE2_CONFIG(coptlist[i].value, &yield);
printf("%d\n", yield); printf("%d\n", yield);
break; break;
case CONF_NL: case CONF_NL:
(void)PCRE2_CONFIG(coptlist[i].value, &rc, sizeof(rc)); (void)PCRE2_CONFIG(coptlist[i].value, &rc);
print_newline_config(rc, TRUE); print_newline_config(rc, TRUE);
break; break;
} }
@ -5316,7 +5316,7 @@ printf(" 16-bit support\n");
printf(" 32-bit support\n"); printf(" 32-bit support\n");
#endif #endif
(void)PCRE2_CONFIG(PCRE2_CONFIG_UNICODE, &rc, sizeof(rc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_UNICODE, &rc);
if (rc != 0) if (rc != 0)
{ {
printf(" UTF and UCP support ("); printf(" UTF and UCP support (");
@ -5325,7 +5325,7 @@ if (rc != 0)
} }
else printf(" No UTF or UCP support\n"); else printf(" No UTF or UCP support\n");
(void)PCRE2_CONFIG(PCRE2_CONFIG_JIT, &rc, sizeof(rc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_JIT, &rc);
if (rc != 0) if (rc != 0)
{ {
printf(" Just-in-time compiler support: "); printf(" Just-in-time compiler support: ");
@ -5337,20 +5337,20 @@ else
printf(" No just-in-time compiler support\n"); printf(" No just-in-time compiler support\n");
} }
(void)PCRE2_CONFIG(PCRE2_CONFIG_NEWLINE, &rc, sizeof(rc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_NEWLINE, &rc);
print_newline_config(rc, FALSE); print_newline_config(rc, FALSE);
(void)PCRE2_CONFIG(PCRE2_CONFIG_BSR, &rc, sizeof(rc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_BSR, &rc);
printf(" \\R matches %s\n", rc? "CR, LF, or CRLF only" : printf(" \\R matches %s\n", rc? "CR, LF, or CRLF only" :
"all Unicode newlines"); "all Unicode newlines");
(void)PCRE2_CONFIG(PCRE2_CONFIG_LINKSIZE, &rc, sizeof(rc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_LINKSIZE, &rc);
printf(" Internal link size = %d\n", rc); printf(" Internal link size = %d\n", rc);
(void)PCRE2_CONFIG(PCRE2_CONFIG_PARENSLIMIT, &lrc, sizeof(lrc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_PARENSLIMIT, &lrc);
printf(" Parentheses nest limit = %ld\n", lrc); printf(" Parentheses nest limit = %ld\n", lrc);
(void)PCRE2_CONFIG(PCRE2_CONFIG_MATCHLIMIT, &lrc, sizeof(lrc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_MATCHLIMIT, &lrc);
printf(" Default match limit = %ld\n", lrc); printf(" Default match limit = %ld\n", lrc);
(void)PCRE2_CONFIG(PCRE2_CONFIG_RECURSIONLIMIT, &lrc, sizeof(lrc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_RECURSIONLIMIT, &lrc);
printf(" Default recursion depth limit = %ld\n", lrc); printf(" Default recursion depth limit = %ld\n", lrc);
(void)PCRE2_CONFIG(PCRE2_CONFIG_STACKRECURSE, &rc, sizeof(rc)); (void)PCRE2_CONFIG(PCRE2_CONFIG_STACKRECURSE, &rc);
printf(" Match recursion uses %s", rc? "stack" : "heap"); printf(" Match recursion uses %s", rc? "stack" : "heap");
printf("\n"); printf("\n");
@ -5391,11 +5391,9 @@ if (PO(options) != DO(options) || PO(control) != DO(control))
/* Get the PCRE2 and Unicode version number and JIT target information. */ /* Get the PCRE2 and Unicode version number and JIT target information. */
PCRE2_CONFIG(PCRE2_CONFIG_VERSION, version, sizeof(VERSION_TYPE)*VERSION_SIZE); PCRE2_CONFIG(PCRE2_CONFIG_VERSION, version);
PCRE2_CONFIG(PCRE2_CONFIG_UNICODE_VERSION, uversion, PCRE2_CONFIG(PCRE2_CONFIG_UNICODE_VERSION, uversion);
sizeof(VERSION_TYPE)*VERSION_SIZE); PCRE2_CONFIG(PCRE2_CONFIG_JITTARGET, jittarget);
PCRE2_CONFIG(PCRE2_CONFIG_JITTARGET, jittarget,
sizeof(VERSION_TYPE)*VERSION_SIZE);
/* Get buffers from malloc() so that valgrind will check their misuse when /* Get buffers from malloc() so that valgrind will check their misuse when
debugging. They grow automatically when very long lines are read. The 16- debugging. They grow automatically when very long lines are read. The 16-