Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
48636f09
Commit
48636f09
authored
Apr 26, 2018
by
Sergei Golubchik
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'merge-pcre' into 10.0
parents
5ae2656b
cf242ade
Changes
19
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
638 additions
and
337 deletions
+638
-337
pcre/AUTHORS
pcre/AUTHORS
+3
-3
pcre/ChangeLog
pcre/ChangeLog
+53
-0
pcre/INSTALL
pcre/INSTALL
+159
-161
pcre/LICENCE
pcre/LICENCE
+3
-3
pcre/NEWS
pcre/NEWS
+6
-0
pcre/NON-AUTOTOOLS-BUILD
pcre/NON-AUTOTOOLS-BUILD
+8
-7
pcre/configure.ac
pcre/configure.ac
+19
-7
pcre/doc/html/NON-AUTOTOOLS-BUILD.txt
pcre/doc/html/NON-AUTOTOOLS-BUILD.txt
+8
-7
pcre/pcre.h.in
pcre/pcre.h.in
+4
-4
pcre/pcre_compile.c
pcre/pcre_compile.c
+1
-1
pcre/pcre_dfa_exec.c
pcre/pcre_dfa_exec.c
+3
-1
pcre/pcre_exec.c
pcre/pcre_exec.c
+4
-4
pcre/pcre_jit_compile.c
pcre/pcre_jit_compile.c
+288
-119
pcre/pcregrep.c
pcre/pcregrep.c
+38
-17
pcre/pcreposix.c
pcre/pcreposix.c
+3
-3
pcre/testdata/testinput2
pcre/testdata/testinput2
+8
-0
pcre/testdata/testinput5
pcre/testdata/testinput5
+6
-0
pcre/testdata/testoutput2
pcre/testdata/testoutput2
+16
-0
pcre/testdata/testoutput5
pcre/testdata/testoutput5
+8
-0
No files found.
pcre/AUTHORS
View file @
48636f09
...
@@ -8,7 +8,7 @@ Email domain: cam.ac.uk
...
@@ -8,7 +8,7 @@ Email domain: cam.ac.uk
University of Cambridge Computing Service,
University of Cambridge Computing Service,
Cambridge, England.
Cambridge, England.
Copyright (c) 1997-201
7
University of Cambridge
Copyright (c) 1997-201
8
University of Cambridge
All rights reserved
All rights reserved
...
@@ -19,7 +19,7 @@ Written by: Zoltan Herczeg
...
@@ -19,7 +19,7 @@ Written by: Zoltan Herczeg
Email local part: hzmester
Email local part: hzmester
Emain domain: freemail.hu
Emain domain: freemail.hu
Copyright(c) 2010-201
7
Zoltan Herczeg
Copyright(c) 2010-201
8
Zoltan Herczeg
All rights reserved.
All rights reserved.
...
@@ -30,7 +30,7 @@ Written by: Zoltan Herczeg
...
@@ -30,7 +30,7 @@ Written by: Zoltan Herczeg
Email local part: hzmester
Email local part: hzmester
Emain domain: freemail.hu
Emain domain: freemail.hu
Copyright(c) 2009-201
7
Zoltan Herczeg
Copyright(c) 2009-201
8
Zoltan Herczeg
All rights reserved.
All rights reserved.
...
...
pcre/ChangeLog
View file @
48636f09
...
@@ -4,6 +4,59 @@ ChangeLog for PCRE
...
@@ -4,6 +4,59 @@ ChangeLog for PCRE
Note that the PCRE 8.xx series (PCRE1) is now in a bugfix-only state. All
Note that the PCRE 8.xx series (PCRE1) is now in a bugfix-only state. All
development is happening in the PCRE2 10.xx series.
development is happening in the PCRE2 10.xx series.
Version 8.42 20-March-2018
--------------------------
1. Fixed a MIPS issue in the JIT compiler reported by Joshua Kinard.
2. Fixed outdated real_pcre definitions in pcre.h.in (patch by Evgeny Kotkov).
3. pcregrep was truncating components of file names to 128 characters when
processing files with the -r option, and also (some very odd code) truncating
path names to 512 characters. There is now a check on the absolute length of
full path file names, which may be up to 2047 characters long.
4. Using pcre_dfa_exec(), in UTF mode when UCP support was not defined, there
was the possibility of a false positive match when caselessly matching a "not
this character" item such as [^\x{1234}] (with a code point greater than 127)
because the "other case" variable was not being initialized.
5. Although pcre_jit_exec checks whether the pattern is compiled
in a given mode, it was also expected that at least one mode is available.
This is fixed and pcre_jit_exec returns with PCRE_ERROR_JIT_BADOPTION
when the pattern is not optimized by JIT at all.
6. The line number and related variables such as match counts in pcregrep
were all int variables, causing overflow when files with more than 2147483647
lines were processed (assuming 32-bit ints). They have all been changed to
unsigned long ints.
7. If a backreference with a minimum repeat count of zero was first in a
pattern, apart from assertions, an incorrect first matching character could be
recorded. For example, for the pattern /(?=(a))\1?b/, "b" was incorrectly set
as the first character of a match.
8. Fix out-of-bounds read for partial matching of /./ against an empty string
when the newline type is CRLF.
9. When matching using the the REG_STARTEND feature of the POSIX API with a
non-zero starting offset, unset capturing groups with lower numbers than a
group that did capture something were not being correctly returned as "unset"
(that is, with offset values of -1).
10. Matching the pattern /(*UTF)\C[^\v]+\x80/ against an 8-bit string
containing multi-code-unit characters caused bad behaviour and possibly a
crash. This issue was fixed for other kinds of repeat in release 8.37 by change
38, but repeating character classes were overlooked.
11. A small fix to pcregrep to avoid compiler warnings for -Wformat-overflow=2.
12. Added --enable-jit=auto support to configure.ac.
13. Fix misleading error message in configure.ac.
Version 8.41 05-July-2017
Version 8.41 05-July-2017
-------------------------
-------------------------
...
...
pcre/INSTALL
View file @
48636f09
This diff is collapsed.
Click to expand it.
pcre/LICENCE
View file @
48636f09
...
@@ -25,7 +25,7 @@ Email domain: cam.ac.uk
...
@@ -25,7 +25,7 @@ Email domain: cam.ac.uk
University of Cambridge Computing Service,
University of Cambridge Computing Service,
Cambridge, England.
Cambridge, England.
Copyright (c) 1997-201
7
University of Cambridge
Copyright (c) 1997-201
8
University of Cambridge
All rights reserved.
All rights reserved.
...
@@ -36,7 +36,7 @@ Written by: Zoltan Herczeg
...
@@ -36,7 +36,7 @@ Written by: Zoltan Herczeg
Email local part: hzmester
Email local part: hzmester
Emain domain: freemail.hu
Emain domain: freemail.hu
Copyright(c) 2010-201
7
Zoltan Herczeg
Copyright(c) 2010-201
8
Zoltan Herczeg
All rights reserved.
All rights reserved.
...
@@ -47,7 +47,7 @@ Written by: Zoltan Herczeg
...
@@ -47,7 +47,7 @@ Written by: Zoltan Herczeg
Email local part: hzmester
Email local part: hzmester
Emain domain: freemail.hu
Emain domain: freemail.hu
Copyright(c) 2009-201
7
Zoltan Herczeg
Copyright(c) 2009-201
8
Zoltan Herczeg
All rights reserved.
All rights reserved.
...
...
pcre/NEWS
View file @
48636f09
News about PCRE releases
News about PCRE releases
------------------------
------------------------
Release 8.42 20-March-2018
--------------------------
This is a bug-fix release.
Release 8.41 13-June-2017
Release 8.41 13-June-2017
-------------------------
-------------------------
...
...
pcre/NON-AUTOTOOLS-BUILD
View file @
48636f09
...
@@ -760,13 +760,14 @@ The character code used is EBCDIC, not ASCII or Unicode. In z/OS, UNIX APIs and
...
@@ -760,13 +760,14 @@ The character code used is EBCDIC, not ASCII or Unicode. In z/OS, UNIX APIs and
applications can be supported through UNIX System Services, and in such an
applications can be supported through UNIX System Services, and in such an
environment PCRE can be built in the same way as in other systems. However, in
environment PCRE can be built in the same way as in other systems. However, in
native z/OS (without UNIX System Services) and in z/VM, special ports are
native z/OS (without UNIX System Services) and in z/VM, special ports are
required.
For details, please see this web
site:
required.
PCRE1 version 8.39 is available in file 882 on this
site:
http://www.
zaconsultants.net
http://www.
cbttape.org
You may download PCRE from WWW.CBTTAPE.ORG, file 882. Everything, source and
Everything, source and executable, is in EBCDIC and native z/OS file formats.
executable, is in EBCDIC and native z/OS file formats and this is th
e
However, this software is not maintained and will not be upgraded. If you ar
e
recommended download site
.
new to PCRE you should be looking at PCRE2 (version 10.30 or later)
.
==========================
===============================
Last Updated: 25 June 2015
Last Updated: 13 September 2017
===============================
pcre/configure.ac
View file @
48636f09
...
@@ -9,18 +9,18 @@ dnl The PCRE_PRERELEASE feature is for identifying release candidates. It might
...
@@ -9,18 +9,18 @@ dnl The PCRE_PRERELEASE feature is for identifying release candidates. It might
dnl be defined as -RC2, for example. For real releases, it should be empty.
dnl be defined as -RC2, for example. For real releases, it should be empty.
m4_define(pcre_major, [8])
m4_define(pcre_major, [8])
m4_define(pcre_minor, [4
1
])
m4_define(pcre_minor, [4
2
])
m4_define(pcre_prerelease, [])
m4_define(pcre_prerelease, [])
m4_define(pcre_date, [201
7-07-05
])
m4_define(pcre_date, [201
8-03-20
])
# NOTE: The CMakeLists.txt file searches for the above variables in the first
# NOTE: The CMakeLists.txt file searches for the above variables in the first
# 50 lines of this file. Please update that if the variables above are moved.
# 50 lines of this file. Please update that if the variables above are moved.
# Libtool shared library interface versions (current:revision:age)
# Libtool shared library interface versions (current:revision:age)
m4_define(libpcre_version, [3:
9
:2])
m4_define(libpcre_version, [3:
10
:2])
m4_define(libpcre16_version, [2:
9
:2])
m4_define(libpcre16_version, [2:
10
:2])
m4_define(libpcre32_version, [0:
9
:0])
m4_define(libpcre32_version, [0:
10
:0])
m4_define(libpcreposix_version, [0:
5
:0])
m4_define(libpcreposix_version, [0:
6
:0])
m4_define(libpcrecpp_version, [0:1:0])
m4_define(libpcrecpp_version, [0:1:0])
AC_PREREQ(2.57)
AC_PREREQ(2.57)
...
@@ -155,6 +155,18 @@ AC_ARG_ENABLE(jit,
...
@@ -155,6 +155,18 @@ AC_ARG_ENABLE(jit,
[enable Just-In-Time compiling support]),
[enable Just-In-Time compiling support]),
, enable_jit=no)
, enable_jit=no)
# This code enables JIT if the hardware supports it.
if test "$enable_jit" = "auto"; then
AC_LANG(C)
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
#define SLJIT_CONFIG_AUTO 1
#include "sljit/sljitConfigInternal.h"
#if (defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED)
#error unsupported
#endif]])], enable_jit=yes, enable_jit=no)
fi
# Handle --disable-pcregrep-jit (enabled by default)
# Handle --disable-pcregrep-jit (enabled by default)
AC_ARG_ENABLE(pcregrep-jit,
AC_ARG_ENABLE(pcregrep-jit,
AS_HELP_STRING([--disable-pcregrep-jit],
AS_HELP_STRING([--disable-pcregrep-jit],
...
@@ -469,7 +481,7 @@ pcre_have_type_traits="0"
...
@@ -469,7 +481,7 @@ pcre_have_type_traits="0"
pcre_have_bits_type_traits="0"
pcre_have_bits_type_traits="0"
if test "x$enable_cpp" = "xyes" -a -z "$CXX"; then
if test "x$enable_cpp" = "xyes" -a -z "$CXX"; then
AC_MSG_ERROR([
You need a C++ compiler for C++ support.
])
AC_MSG_ERROR([
Invalid C++ compiler or C++ compiler flags
])
fi
fi
if test "x$enable_cpp" = "xyes" -a -n "$CXX"
if test "x$enable_cpp" = "xyes" -a -n "$CXX"
...
...
pcre/doc/html/NON-AUTOTOOLS-BUILD.txt
View file @
48636f09
...
@@ -760,13 +760,14 @@ The character code used is EBCDIC, not ASCII or Unicode. In z/OS, UNIX APIs and
...
@@ -760,13 +760,14 @@ The character code used is EBCDIC, not ASCII or Unicode. In z/OS, UNIX APIs and
applications can be supported through UNIX System Services, and in such an
applications can be supported through UNIX System Services, and in such an
environment PCRE can be built in the same way as in other systems. However, in
environment PCRE can be built in the same way as in other systems. However, in
native z/OS (without UNIX System Services) and in z/VM, special ports are
native z/OS (without UNIX System Services) and in z/VM, special ports are
required.
For details, please see this web
site:
required.
PCRE1 version 8.39 is available in file 882 on this
site:
http://www.
zaconsultants.net
http://www.
cbttape.org
You may download PCRE from WWW.CBTTAPE.ORG, file 882. Everything, source and
Everything, source and executable, is in EBCDIC and native z/OS file formats.
executable, is in EBCDIC and native z/OS file formats and this is th
e
However, this software is not maintained and will not be upgraded. If you ar
e
recommended download site
.
new to PCRE you should be looking at PCRE2 (version 10.30 or later)
.
==========================
===============================
Last Updated: 25 June 2015
Last Updated: 13 September 2017
===============================
pcre/pcre.h.in
View file @
48636f09
...
@@ -321,11 +321,11 @@ these bits, just add new ones on the end, in order to remain compatible. */
...
@@ -321,11 +321,11 @@ these bits, just add new ones on the end, in order to remain compatible. */
/* Types */
/* Types */
struct real_pcre
;
/* declaration; the definition is private */
struct real_pcre
8_or_16;
/* declaration; the definition is private */
typedef struct real_pcre pcre;
typedef struct real_pcre
8_or_16
pcre;
struct real_pcre
16;
/* declaration; the definition is private */
struct real_pcre
8_or_16;
/* declaration; the definition is private */
typedef struct real_pcre16 pcre16;
typedef struct real_pcre
8_or_
16 pcre16;
struct real_pcre32; /* declaration; the definition is private */
struct real_pcre32; /* declaration; the definition is private */
typedef struct real_pcre32 pcre32;
typedef struct real_pcre32 pcre32;
...
...
pcre/pcre_compile.c
View file @
48636f09
...
@@ -8063,7 +8063,7 @@ for (;; ptr++)
...
@@ -8063,7 +8063,7 @@ for (;; ptr++)
single group (i.e. not to a duplicated name. */
single group (i.e. not to a duplicated name. */
HANDLE_REFERENCE:
HANDLE_REFERENCE:
if
(
firstcharflags
==
REQ_UNSET
)
firstcharflags
=
REQ_NONE
;
if
(
firstcharflags
==
REQ_UNSET
)
zerofirstcharflags
=
firstcharflags
=
REQ_NONE
;
previous
=
code
;
previous
=
code
;
item_hwm_offset
=
cd
->
hwm
-
cd
->
start_workspace
;
item_hwm_offset
=
cd
->
hwm
-
cd
->
start_workspace
;
*
code
++
=
((
options
&
PCRE_CASELESS
)
!=
0
)
?
OP_REFI
:
OP_REF
;
*
code
++
=
((
options
&
PCRE_CASELESS
)
!=
0
)
?
OP_REFI
:
OP_REF
;
...
...
pcre/pcre_dfa_exec.c
View file @
48636f09
...
@@ -2287,12 +2287,14 @@ for (;;)
...
@@ -2287,12 +2287,14 @@ for (;;)
case
OP_NOTI
:
case
OP_NOTI
:
if
(
clen
>
0
)
if
(
clen
>
0
)
{
{
unsigned
int
otherd
;
pcre_uint32
otherd
;
#ifdef SUPPORT_UTF
#ifdef SUPPORT_UTF
if
(
utf
&&
d
>=
128
)
if
(
utf
&&
d
>=
128
)
{
{
#ifdef SUPPORT_UCP
#ifdef SUPPORT_UCP
otherd
=
UCD_OTHERCASE
(
d
);
otherd
=
UCD_OTHERCASE
(
d
);
#else
otherd
=
d
;
#endif
/* SUPPORT_UCP */
#endif
/* SUPPORT_UCP */
}
}
else
else
...
...
pcre/pcre_exec.c
View file @
48636f09
...
@@ -6,7 +6,7 @@
...
@@ -6,7 +6,7 @@
and semantics are as close as possible to those of the Perl 5 language.
and semantics are as close as possible to those of the Perl 5 language.
Written by Philip Hazel
Written by Philip Hazel
Copyright (c) 1997-201
4
University of Cambridge
Copyright (c) 1997-201
8
University of Cambridge
-----------------------------------------------------------------------------
-----------------------------------------------------------------------------
Redistribution and use in source and binary forms, with or without
Redistribution and use in source and binary forms, with or without
...
@@ -2313,7 +2313,7 @@ for (;;)
...
@@ -2313,7 +2313,7 @@ for (;;)
case
OP_ANY
:
case
OP_ANY
:
if
(
IS_NEWLINE
(
eptr
))
RRETURN
(
MATCH_NOMATCH
);
if
(
IS_NEWLINE
(
eptr
))
RRETURN
(
MATCH_NOMATCH
);
if
(
md
->
partial
!=
0
&&
if
(
md
->
partial
!=
0
&&
eptr
+
1
>=
md
->
end_subject
&&
eptr
==
md
->
end_subject
-
1
&&
NLBLOCK
->
nltype
==
NLTYPE_FIXED
&&
NLBLOCK
->
nltype
==
NLTYPE_FIXED
&&
NLBLOCK
->
nllen
==
2
&&
NLBLOCK
->
nllen
==
2
&&
UCHAR21TEST
(
eptr
)
==
NLBLOCK
->
nl
[
0
])
UCHAR21TEST
(
eptr
)
==
NLBLOCK
->
nl
[
0
])
...
@@ -3061,7 +3061,7 @@ for (;;)
...
@@ -3061,7 +3061,7 @@ for (;;)
{
{
RMATCH
(
eptr
,
ecode
,
offset_top
,
md
,
eptrb
,
RM18
);
RMATCH
(
eptr
,
ecode
,
offset_top
,
md
,
eptrb
,
RM18
);
if
(
rrc
!=
MATCH_NOMATCH
)
RRETURN
(
rrc
);
if
(
rrc
!=
MATCH_NOMATCH
)
RRETURN
(
rrc
);
if
(
eptr
--
=
=
pp
)
break
;
/* Stop if tried at original pos */
if
(
eptr
--
<
=
pp
)
break
;
/* Stop if tried at original pos */
BACKCHAR
(
eptr
);
BACKCHAR
(
eptr
);
}
}
}
}
...
@@ -3218,7 +3218,7 @@ for (;;)
...
@@ -3218,7 +3218,7 @@ for (;;)
{
{
RMATCH
(
eptr
,
ecode
,
offset_top
,
md
,
eptrb
,
RM21
);
RMATCH
(
eptr
,
ecode
,
offset_top
,
md
,
eptrb
,
RM21
);
if
(
rrc
!=
MATCH_NOMATCH
)
RRETURN
(
rrc
);
if
(
rrc
!=
MATCH_NOMATCH
)
RRETURN
(
rrc
);
if
(
eptr
--
=
=
pp
)
break
;
/* Stop if tried at original pos */
if
(
eptr
--
<
=
pp
)
break
;
/* Stop if tried at original pos */
#ifdef SUPPORT_UTF
#ifdef SUPPORT_UTF
if
(
utf
)
BACKCHAR
(
eptr
);
if
(
utf
)
BACKCHAR
(
eptr
);
#endif
#endif
...
...
pcre/pcre_jit_compile.c
View file @
48636f09
This diff is collapsed.
Click to expand it.
pcre/pcregrep.c
View file @
48636f09
...
@@ -1387,8 +1387,8 @@ Returns: nothing
...
@@ -1387,8 +1387,8 @@ Returns: nothing
*/
*/
static
void
static
void
do_after_lines
(
int
lastmatchnumber
,
char
*
lastmatchrestart
,
char
*
endptr
,
do_after_lines
(
unsigned
long
int
lastmatchnumber
,
char
*
lastmatchrestart
,
char
*
printname
)
char
*
endptr
,
char
*
printname
)
{
{
if
(
after_context
>
0
&&
lastmatchnumber
>
0
)
if
(
after_context
>
0
&&
lastmatchnumber
>
0
)
{
{
...
@@ -1398,7 +1398,7 @@ if (after_context > 0 && lastmatchnumber > 0)
...
@@ -1398,7 +1398,7 @@ if (after_context > 0 && lastmatchnumber > 0)
int
ellength
;
int
ellength
;
char
*
pp
=
lastmatchrestart
;
char
*
pp
=
lastmatchrestart
;
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s-"
,
printname
);
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s-"
,
printname
);
if
(
number
)
fprintf
(
stdout
,
"%
d
-"
,
lastmatchnumber
++
);
if
(
number
)
fprintf
(
stdout
,
"%
lu
-"
,
lastmatchnumber
++
);
pp
=
end_of_line
(
pp
,
endptr
,
&
ellength
);
pp
=
end_of_line
(
pp
,
endptr
,
&
ellength
);
FWRITE
(
lastmatchrestart
,
1
,
pp
-
lastmatchrestart
,
stdout
);
FWRITE
(
lastmatchrestart
,
1
,
pp
-
lastmatchrestart
,
stdout
);
lastmatchrestart
=
pp
;
lastmatchrestart
=
pp
;
...
@@ -1502,11 +1502,11 @@ static int
...
@@ -1502,11 +1502,11 @@ static int
pcregrep
(
void
*
handle
,
int
frtype
,
char
*
filename
,
char
*
printname
)
pcregrep
(
void
*
handle
,
int
frtype
,
char
*
filename
,
char
*
printname
)
{
{
int
rc
=
1
;
int
rc
=
1
;
int
linenumber
=
1
;
int
lastmatchnumber
=
0
;
int
count
=
0
;
int
filepos
=
0
;
int
filepos
=
0
;
int
offsets
[
OFFSET_SIZE
];
int
offsets
[
OFFSET_SIZE
];
unsigned
long
int
linenumber
=
1
;
unsigned
long
int
lastmatchnumber
=
0
;
unsigned
long
int
count
=
0
;
char
*
lastmatchrestart
=
NULL
;
char
*
lastmatchrestart
=
NULL
;
char
*
ptr
=
main_buffer
;
char
*
ptr
=
main_buffer
;
char
*
endptr
;
char
*
endptr
;
...
@@ -1609,7 +1609,7 @@ while (ptr < endptr)
...
@@ -1609,7 +1609,7 @@ while (ptr < endptr)
if
(
endlinelength
==
0
&&
t
==
main_buffer
+
bufsize
)
if
(
endlinelength
==
0
&&
t
==
main_buffer
+
bufsize
)
{
{
fprintf
(
stderr
,
"pcregrep: line %
d
%s%s is too long for the internal buffer
\n
"
fprintf
(
stderr
,
"pcregrep: line %
lu
%s%s is too long for the internal buffer
\n
"
"pcregrep: check the --buffer-size option
\n
"
,
"pcregrep: check the --buffer-size option
\n
"
,
linenumber
,
linenumber
,
(
filename
==
NULL
)
?
""
:
" of file "
,
(
filename
==
NULL
)
?
""
:
" of file "
,
...
@@ -1747,7 +1747,7 @@ while (ptr < endptr)
...
@@ -1747,7 +1747,7 @@ while (ptr < endptr)
prevoffsets
[
1
]
=
offsets
[
1
];
prevoffsets
[
1
]
=
offsets
[
1
];
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s:"
,
printname
);
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s:"
,
printname
);
if
(
number
)
fprintf
(
stdout
,
"%
d
:"
,
linenumber
);
if
(
number
)
fprintf
(
stdout
,
"%
lu
:"
,
linenumber
);
/* Handle --line-offsets */
/* Handle --line-offsets */
...
@@ -1862,7 +1862,7 @@ while (ptr < endptr)
...
@@ -1862,7 +1862,7 @@ while (ptr < endptr)
{
{
char
*
pp
=
lastmatchrestart
;
char
*
pp
=
lastmatchrestart
;
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s-"
,
printname
);
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s-"
,
printname
);
if
(
number
)
fprintf
(
stdout
,
"%
d
-"
,
lastmatchnumber
++
);
if
(
number
)
fprintf
(
stdout
,
"%
lu
-"
,
lastmatchnumber
++
);
pp
=
end_of_line
(
pp
,
endptr
,
&
ellength
);
pp
=
end_of_line
(
pp
,
endptr
,
&
ellength
);
FWRITE
(
lastmatchrestart
,
1
,
pp
-
lastmatchrestart
,
stdout
);
FWRITE
(
lastmatchrestart
,
1
,
pp
-
lastmatchrestart
,
stdout
);
lastmatchrestart
=
pp
;
lastmatchrestart
=
pp
;
...
@@ -1902,7 +1902,7 @@ while (ptr < endptr)
...
@@ -1902,7 +1902,7 @@ while (ptr < endptr)
int
ellength
;
int
ellength
;
char
*
pp
=
p
;
char
*
pp
=
p
;
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s-"
,
printname
);
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s-"
,
printname
);
if
(
number
)
fprintf
(
stdout
,
"%
d
-"
,
linenumber
-
linecount
--
);
if
(
number
)
fprintf
(
stdout
,
"%
lu
-"
,
linenumber
-
linecount
--
);
pp
=
end_of_line
(
pp
,
endptr
,
&
ellength
);
pp
=
end_of_line
(
pp
,
endptr
,
&
ellength
);
FWRITE
(
p
,
1
,
pp
-
p
,
stdout
);
FWRITE
(
p
,
1
,
pp
-
p
,
stdout
);
p
=
pp
;
p
=
pp
;
...
@@ -1916,7 +1916,7 @@ while (ptr < endptr)
...
@@ -1916,7 +1916,7 @@ while (ptr < endptr)
endhyphenpending
=
TRUE
;
endhyphenpending
=
TRUE
;
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s:"
,
printname
);
if
(
printname
!=
NULL
)
fprintf
(
stdout
,
"%s:"
,
printname
);
if
(
number
)
fprintf
(
stdout
,
"%
d
:"
,
linenumber
);
if
(
number
)
fprintf
(
stdout
,
"%
lu
:"
,
linenumber
);
/* In multiline mode, we want to print to the end of the line in which
/* In multiline mode, we want to print to the end of the line in which
the end of the matched string is found, so we adjust linelength and the
the end of the matched string is found, so we adjust linelength and the
...
@@ -2112,7 +2112,7 @@ if (count_only && !quiet)
...
@@ -2112,7 +2112,7 @@ if (count_only && !quiet)
{
{
if
(
printname
!=
NULL
&&
filenames
!=
FN_NONE
)
if
(
printname
!=
NULL
&&
filenames
!=
FN_NONE
)
fprintf
(
stdout
,
"%s:"
,
printname
);
fprintf
(
stdout
,
"%s:"
,
printname
);
fprintf
(
stdout
,
"%
d
\n
"
,
count
);
fprintf
(
stdout
,
"%
lu
\n
"
,
count
);
}
}
}
}
...
@@ -2234,7 +2234,7 @@ if (isdirectory(pathname))
...
@@ -2234,7 +2234,7 @@ if (isdirectory(pathname))
if
(
dee_action
==
dee_RECURSE
)
if
(
dee_action
==
dee_RECURSE
)
{
{
char
buffer
[
1024
];
char
buffer
[
2048
];
char
*
nextfile
;
char
*
nextfile
;
directory_type
*
dir
=
opendirectory
(
pathname
);
directory_type
*
dir
=
opendirectory
(
pathname
);
...
@@ -2249,7 +2249,14 @@ if (isdirectory(pathname))
...
@@ -2249,7 +2249,14 @@ if (isdirectory(pathname))
while
((
nextfile
=
readdirectory
(
dir
))
!=
NULL
)
while
((
nextfile
=
readdirectory
(
dir
))
!=
NULL
)
{
{
int
frc
;
int
frc
;
sprintf
(
buffer
,
"%.512s%c%.128s"
,
pathname
,
FILESEP
,
nextfile
);
int
fnlength
=
strlen
(
pathname
)
+
strlen
(
nextfile
)
+
2
;
if
(
fnlength
>
2048
)
{
fprintf
(
stderr
,
"pcre2grep: recursive filename is too long
\n
"
);
rc
=
2
;
break
;
}
sprintf
(
buffer
,
"%s%c%s"
,
pathname
,
FILESEP
,
nextfile
);
frc
=
grep_or_recurse
(
buffer
,
dir_recurse
,
FALSE
);
frc
=
grep_or_recurse
(
buffer
,
dir_recurse
,
FALSE
);
if
(
frc
>
1
)
rc
=
frc
;
if
(
frc
>
1
)
rc
=
frc
;
else
if
(
frc
==
0
&&
rc
==
1
)
rc
=
0
;
else
if
(
frc
==
0
&&
rc
==
1
)
rc
=
0
;
...
@@ -2520,7 +2527,14 @@ if ((popts & PO_FIXED_STRINGS) != 0)
...
@@ -2520,7 +2527,14 @@ if ((popts & PO_FIXED_STRINGS) != 0)
}
}
}
}
sprintf
(
buffer
,
"%s%.*s%s"
,
prefix
[
popts
],
patlen
,
ps
,
suffix
[
popts
]);
if
(
snprintf
(
buffer
,
PATBUFSIZE
,
"%s%.*s%s"
,
prefix
[
popts
],
patlen
,
ps
,
suffix
[
popts
])
>
PATBUFSIZE
)
{
fprintf
(
stderr
,
"pcregrep: Buffer overflow while compiling
\"
%s
\"\n
"
,
ps
);
return
FALSE
;
}
p
->
compiled
=
pcre_compile
(
buffer
,
options
,
&
error
,
&
errptr
,
pcretables
);
p
->
compiled
=
pcre_compile
(
buffer
,
options
,
&
error
,
&
errptr
,
pcretables
);
if
(
p
->
compiled
!=
NULL
)
return
TRUE
;
if
(
p
->
compiled
!=
NULL
)
return
TRUE
;
...
@@ -2756,8 +2770,15 @@ for (i = 1; i < argc; i++)
...
@@ -2756,8 +2770,15 @@ for (i = 1; i < argc; i++)
int
arglen
=
(
argequals
==
NULL
||
equals
==
NULL
)
?
int
arglen
=
(
argequals
==
NULL
||
equals
==
NULL
)
?
(
int
)
strlen
(
arg
)
:
(
int
)(
argequals
-
arg
);
(
int
)
strlen
(
arg
)
:
(
int
)(
argequals
-
arg
);
sprintf
(
buff1
,
"%.*s"
,
baselen
,
op
->
long_name
);
if
(
snprintf
(
buff1
,
sizeof
(
buff1
),
"%.*s"
,
baselen
,
op
->
long_name
)
>
sprintf
(
buff2
,
"%s%.*s"
,
buff1
,
fulllen
-
baselen
-
2
,
opbra
+
1
);
(
int
)
sizeof
(
buff1
)
||
snprintf
(
buff2
,
sizeof
(
buff2
),
"%s%.*s"
,
buff1
,
fulllen
-
baselen
-
2
,
opbra
+
1
)
>
(
int
)
sizeof
(
buff2
))
{
fprintf
(
stderr
,
"pcregrep: Buffer overflow when parsing %s option
\n
"
,
op
->
long_name
);
pcregrep_exit
(
2
);
}
if
(
strncmp
(
arg
,
buff1
,
arglen
)
==
0
||
if
(
strncmp
(
arg
,
buff1
,
arglen
)
==
0
||
strncmp
(
arg
,
buff2
,
arglen
)
==
0
)
strncmp
(
arg
,
buff2
,
arglen
)
==
0
)
...
...
pcre/pcreposix.c
View file @
48636f09
...
@@ -6,7 +6,7 @@
...
@@ -6,7 +6,7 @@
and semantics are as close as possible to those of the Perl 5 language.
and semantics are as close as possible to those of the Perl 5 language.
Written by Philip Hazel
Written by Philip Hazel
Copyright (c) 1997-201
7
University of Cambridge
Copyright (c) 1997-201
8
University of Cambridge
-----------------------------------------------------------------------------
-----------------------------------------------------------------------------
Redistribution and use in source and binary forms, with or without
Redistribution and use in source and binary forms, with or without
...
@@ -389,8 +389,8 @@ if (rc >= 0)
...
@@ -389,8 +389,8 @@ if (rc >= 0)
{
{
for
(
i
=
0
;
i
<
(
size_t
)
rc
;
i
++
)
for
(
i
=
0
;
i
<
(
size_t
)
rc
;
i
++
)
{
{
pmatch
[
i
].
rm_so
=
ovector
[
i
*
2
]
+
so
;
pmatch
[
i
].
rm_so
=
(
ovector
[
i
*
2
]
<
0
)
?
-
1
:
ovector
[
i
*
2
]
+
so
;
pmatch
[
i
].
rm_eo
=
ovector
[
i
*
2
+
1
]
+
so
;
pmatch
[
i
].
rm_eo
=
(
ovector
[
i
*
2
+
1
]
<
0
)
?
-
1
:
ovector
[
i
*
2
+
1
]
+
so
;
}
}
if
(
allocated_ovector
)
free
(
ovector
);
if
(
allocated_ovector
)
free
(
ovector
);
for
(;
i
<
nmatch
;
i
++
)
pmatch
[
i
].
rm_so
=
pmatch
[
i
].
rm_eo
=
-
1
;
for
(;
i
<
nmatch
;
i
++
)
pmatch
[
i
].
rm_so
=
pmatch
[
i
].
rm_eo
=
-
1
;
...
...
pcre/testdata/testinput2
View file @
48636f09
...
@@ -4249,4 +4249,12 @@ backtracking verbs. --/
...
@@ -4249,4 +4249,12 @@ backtracking verbs. --/
/(?=.*[A-Z])/I
/(?=.*[A-Z])/I
"(?<=(a))\1?b"
ab
aaab
"(?=(a))\1?b"
ab
aaab
/-- End of testinput2 --/
/-- End of testinput2 --/
pcre/testdata/testinput5
View file @
48636f09
...
@@ -798,4 +798,10 @@
...
@@ -798,4 +798,10 @@
/(?<=\K\x{17f})/8G+
/(?<=\K\x{17f})/8G+
\x{17f}\x{17f}\x{17f}\x{17f}\x{17f}
\x{17f}\x{17f}\x{17f}\x{17f}\x{17f}
/\C[^\v]+\x80/8
[AΏBŀC]
/\C[^\d]+\x80/8
[AΏBŀC]
/-- End of testinput5 --/
/-- End of testinput5 --/
...
...
pcre/testdata/testoutput2
View file @
48636f09
...
@@ -14705,4 +14705,20 @@ No options
...
@@ -14705,4 +14705,20 @@ No options
No first char
No first char
No need char
No need char
"(?<=(a))\1?b"
ab
0: b
1: a
aaab
0: ab
1: a
"(?=(a))\1?b"
ab
0: ab
1: a
aaab
0: ab
1: a
/-- End of testinput2 --/
/-- End of testinput2 --/
pcre/testdata/testoutput5
View file @
48636f09
...
@@ -1942,4 +1942,12 @@ Need char = 'z'
...
@@ -1942,4 +1942,12 @@ Need char = 'z'
0: \x{17f}
0: \x{17f}
0+
0+
/\C[^\v]+\x80/8
[AΏBŀC]
No match
/\C[^\d]+\x80/8
[AΏBŀC]
No match
/-- End of testinput5 --/
/-- End of testinput5 --/
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment