Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
C
cpython
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
cpython
Commits
a6d80faf
Kaydet (Commit)
a6d80faf
authored
Haz 12, 2006
tarafından
Neal Norwitz
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Impl ssize_t
üst
052cbcf6
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
110 additions
and
105 deletions
+110
-105
_sre.c
Modules/_sre.c
+98
-93
sre.h
Modules/sre.h
+12
-12
No files found.
Modules/_sre.c
Dosyayı görüntüle @
a6d80faf
...
@@ -39,6 +39,8 @@
...
@@ -39,6 +39,8 @@
static
char
copyright
[]
=
static
char
copyright
[]
=
" SRE 2.2.2 Copyright (c) 1997-2002 by Secret Labs AB "
;
" SRE 2.2.2 Copyright (c) 1997-2002 by Secret Labs AB "
;
#define PY_SSIZE_T_CLEAN
#include "Python.h"
#include "Python.h"
#include "structmember.h"
/* offsetof */
#include "structmember.h"
/* offsetof */
...
@@ -261,9 +263,9 @@ data_stack_dealloc(SRE_STATE* state)
...
@@ -261,9 +263,9 @@ data_stack_dealloc(SRE_STATE* state)
}
}
static
int
static
int
data_stack_grow
(
SRE_STATE
*
state
,
in
t
size
)
data_stack_grow
(
SRE_STATE
*
state
,
Py_ssize_
t
size
)
{
{
in
t
minsize
,
cursize
;
Py_ssize_
t
minsize
,
cursize
;
minsize
=
state
->
data_stack_base
+
size
;
minsize
=
state
->
data_stack_base
+
size
;
cursize
=
state
->
data_stack_size
;
cursize
=
state
->
data_stack_size
;
if
(
cursize
<
minsize
)
{
if
(
cursize
<
minsize
)
{
...
@@ -335,7 +337,7 @@ SRE_AT(SRE_STATE* state, SRE_CHAR* ptr, SRE_CODE at)
...
@@ -335,7 +337,7 @@ SRE_AT(SRE_STATE* state, SRE_CHAR* ptr, SRE_CODE at)
{
{
/* check if pointer is at given position */
/* check if pointer is at given position */
in
t
thisp
,
thatp
;
Py_ssize_
t
thisp
,
thatp
;
switch
(
at
)
{
switch
(
at
)
{
...
@@ -476,7 +478,7 @@ SRE_CHARSET(SRE_CODE* set, SRE_CODE ch)
...
@@ -476,7 +478,7 @@ SRE_CHARSET(SRE_CODE* set, SRE_CODE ch)
case
SRE_OP_BIGCHARSET
:
case
SRE_OP_BIGCHARSET
:
/* <BIGCHARSET> <blockcount> <256 blockindices> <blocks> */
/* <BIGCHARSET> <blockcount> <256 blockindices> <blocks> */
{
{
in
t
count
,
block
;
Py_ssize_
t
count
,
block
;
count
=
*
(
set
++
);
count
=
*
(
set
++
);
if
(
sizeof
(
SRE_CODE
)
==
2
)
{
if
(
sizeof
(
SRE_CODE
)
==
2
)
{
...
@@ -510,15 +512,15 @@ SRE_CHARSET(SRE_CODE* set, SRE_CODE ch)
...
@@ -510,15 +512,15 @@ SRE_CHARSET(SRE_CODE* set, SRE_CODE ch)
}
}
}
}
LOCAL
(
in
t
)
SRE_MATCH
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
);
LOCAL
(
Py_ssize_
t
)
SRE_MATCH
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
);
LOCAL
(
in
t
)
LOCAL
(
Py_ssize_
t
)
SRE_COUNT
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
,
in
t
maxcount
)
SRE_COUNT
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
,
Py_ssize_
t
maxcount
)
{
{
SRE_CODE
chr
;
SRE_CODE
chr
;
SRE_CHAR
*
ptr
=
(
SRE_CHAR
*
)
state
->
ptr
;
SRE_CHAR
*
ptr
=
(
SRE_CHAR
*
)
state
->
ptr
;
SRE_CHAR
*
end
=
(
SRE_CHAR
*
)
state
->
end
;
SRE_CHAR
*
end
=
(
SRE_CHAR
*
)
state
->
end
;
in
t
i
;
Py_ssize_
t
i
;
/* adjust end */
/* adjust end */
if
(
maxcount
<
end
-
ptr
&&
maxcount
!=
65535
)
if
(
maxcount
<
end
-
ptr
&&
maxcount
!=
65535
)
...
@@ -608,7 +610,7 @@ SRE_INFO(SRE_STATE* state, SRE_CODE* pattern)
...
@@ -608,7 +610,7 @@ SRE_INFO(SRE_STATE* state, SRE_CODE* pattern)
SRE_CHAR* end = state->end;
SRE_CHAR* end = state->end;
SRE_CHAR* ptr = state->ptr;
SRE_CHAR* ptr = state->ptr;
in
t i;
Py_ssize_
t i;
/* check minimal length */
/* check minimal length */
if (pattern[3] && (end - ptr) < pattern[3])
if (pattern[3] && (end - ptr) < pattern[3])
...
@@ -785,13 +787,13 @@ do { \
...
@@ -785,13 +787,13 @@ do { \
while (0)
/* gcc doesn't like labels at end of scopes */
\
while (0)
/* gcc doesn't like labels at end of scopes */
\
typedef
struct
{
typedef
struct
{
in
t
last_ctx_pos
;
Py_ssize_
t
last_ctx_pos
;
in
t
jump
;
Py_ssize_
t
jump
;
SRE_CHAR
*
ptr
;
SRE_CHAR
*
ptr
;
SRE_CODE
*
pattern
;
SRE_CODE
*
pattern
;
in
t
count
;
Py_ssize_
t
count
;
in
t
lastmark
;
Py_ssize_
t
lastmark
;
in
t
lastindex
;
Py_ssize_
t
lastindex
;
union
{
union
{
SRE_CODE
chr
;
SRE_CODE
chr
;
SRE_REPEAT
*
rep
;
SRE_REPEAT
*
rep
;
...
@@ -800,13 +802,13 @@ typedef struct {
...
@@ -800,13 +802,13 @@ typedef struct {
/* check if string matches the given pattern. returns <0 for
/* check if string matches the given pattern. returns <0 for
error, 0 for failure, and 1 for success */
error, 0 for failure, and 1 for success */
LOCAL
(
in
t
)
LOCAL
(
Py_ssize_
t
)
SRE_MATCH
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
)
SRE_MATCH
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
)
{
{
SRE_CHAR
*
end
=
(
SRE_CHAR
*
)
state
->
end
;
SRE_CHAR
*
end
=
(
SRE_CHAR
*
)
state
->
end
;
in
t
alloc_pos
,
ctx_pos
=
-
1
;
Py_ssize_
t
alloc_pos
,
ctx_pos
=
-
1
;
in
t
i
,
ret
=
0
;
Py_ssize_
t
i
,
ret
=
0
;
in
t
jump
;
Py_ssize_
t
jump
;
SRE_MATCH_CONTEXT
*
ctx
;
SRE_MATCH_CONTEXT
*
ctx
;
SRE_MATCH_CONTEXT
*
nextctx
;
SRE_MATCH_CONTEXT
*
nextctx
;
...
@@ -851,7 +853,7 @@ entrance:
...
@@ -851,7 +853,7 @@ entrance:
state->mark array. If it is increased by more than 1,
state->mark array. If it is increased by more than 1,
the intervening marks must be set to NULL to signal
the intervening marks must be set to NULL to signal
that these marks have not been encountered. */
that these marks have not been encountered. */
in
t
j
=
state
->
lastmark
+
1
;
Py_ssize_
t
j
=
state
->
lastmark
+
1
;
while
(
j
<
i
)
while
(
j
<
i
)
state
->
mark
[
j
++
]
=
NULL
;
state
->
mark
[
j
++
]
=
NULL
;
state
->
lastmark
=
i
;
state
->
lastmark
=
i
;
...
@@ -1037,7 +1039,7 @@ entrance:
...
@@ -1037,7 +1039,7 @@ entrance:
string. check if the rest of the pattern matches,
string. check if the rest of the pattern matches,
and backtrack if not. */
and backtrack if not. */
if
(
ctx
->
count
<
(
in
t
)
ctx
->
pattern
[
1
])
if
(
ctx
->
count
<
(
Py_ssize_
t
)
ctx
->
pattern
[
1
])
RETURN_FAILURE
;
RETURN_FAILURE
;
if
(
ctx
->
pattern
[
ctx
->
pattern
[
0
]]
==
SRE_OP_SUCCESS
)
{
if
(
ctx
->
pattern
[
ctx
->
pattern
[
0
]]
==
SRE_OP_SUCCESS
)
{
...
@@ -1053,12 +1055,12 @@ entrance:
...
@@ -1053,12 +1055,12 @@ entrance:
the rest of the pattern cannot possibly match */
the rest of the pattern cannot possibly match */
ctx
->
u
.
chr
=
ctx
->
pattern
[
ctx
->
pattern
[
0
]
+
1
];
ctx
->
u
.
chr
=
ctx
->
pattern
[
ctx
->
pattern
[
0
]
+
1
];
for
(;;)
{
for
(;;)
{
while
(
ctx
->
count
>=
(
in
t
)
ctx
->
pattern
[
1
]
&&
while
(
ctx
->
count
>=
(
Py_ssize_
t
)
ctx
->
pattern
[
1
]
&&
(
ctx
->
ptr
>=
end
||
*
ctx
->
ptr
!=
ctx
->
u
.
chr
))
{
(
ctx
->
ptr
>=
end
||
*
ctx
->
ptr
!=
ctx
->
u
.
chr
))
{
ctx
->
ptr
--
;
ctx
->
ptr
--
;
ctx
->
count
--
;
ctx
->
count
--
;
}
}
if
(
ctx
->
count
<
(
in
t
)
ctx
->
pattern
[
1
])
if
(
ctx
->
count
<
(
Py_ssize_
t
)
ctx
->
pattern
[
1
])
break
;
break
;
state
->
ptr
=
ctx
->
ptr
;
state
->
ptr
=
ctx
->
ptr
;
DO_JUMP
(
JUMP_REPEAT_ONE_1
,
jump_repeat_one_1
,
DO_JUMP
(
JUMP_REPEAT_ONE_1
,
jump_repeat_one_1
,
...
@@ -1076,7 +1078,7 @@ entrance:
...
@@ -1076,7 +1078,7 @@ entrance:
}
else
{
}
else
{
/* general case */
/* general case */
while
(
ctx
->
count
>=
(
in
t
)
ctx
->
pattern
[
1
])
{
while
(
ctx
->
count
>=
(
Py_ssize_
t
)
ctx
->
pattern
[
1
])
{
state
->
ptr
=
ctx
->
ptr
;
state
->
ptr
=
ctx
->
ptr
;
DO_JUMP
(
JUMP_REPEAT_ONE_2
,
jump_repeat_one_2
,
DO_JUMP
(
JUMP_REPEAT_ONE_2
,
jump_repeat_one_2
,
ctx
->
pattern
+
ctx
->
pattern
[
0
]);
ctx
->
pattern
+
ctx
->
pattern
[
0
]);
...
@@ -1116,7 +1118,7 @@ entrance:
...
@@ -1116,7 +1118,7 @@ entrance:
ret
=
SRE_COUNT
(
state
,
ctx
->
pattern
+
3
,
ctx
->
pattern
[
1
]);
ret
=
SRE_COUNT
(
state
,
ctx
->
pattern
+
3
,
ctx
->
pattern
[
1
]);
RETURN_ON_ERROR
(
ret
);
RETURN_ON_ERROR
(
ret
);
DATA_LOOKUP_AT
(
SRE_MATCH_CONTEXT
,
ctx
,
ctx_pos
);
DATA_LOOKUP_AT
(
SRE_MATCH_CONTEXT
,
ctx
,
ctx_pos
);
if
(
ret
<
(
in
t
)
ctx
->
pattern
[
1
])
if
(
ret
<
(
Py_ssize_
t
)
ctx
->
pattern
[
1
])
/* didn't match minimum number of times */
/* didn't match minimum number of times */
RETURN_FAILURE
;
RETURN_FAILURE
;
/* advance past minimum matches of repeat */
/* advance past minimum matches of repeat */
...
@@ -1132,8 +1134,8 @@ entrance:
...
@@ -1132,8 +1134,8 @@ entrance:
}
else
{
}
else
{
/* general case */
/* general case */
LASTMARK_SAVE
();
LASTMARK_SAVE
();
while
((
in
t
)
ctx
->
pattern
[
2
]
==
65535
while
((
Py_ssize_
t
)
ctx
->
pattern
[
2
]
==
65535
||
ctx
->
count
<=
(
in
t
)
ctx
->
pattern
[
2
])
{
||
ctx
->
count
<=
(
Py_ssize_
t
)
ctx
->
pattern
[
2
])
{
state
->
ptr
=
ctx
->
ptr
;
state
->
ptr
=
ctx
->
ptr
;
DO_JUMP
(
JUMP_MIN_REPEAT_ONE
,
jump_min_repeat_one
,
DO_JUMP
(
JUMP_MIN_REPEAT_ONE
,
jump_min_repeat_one
,
ctx
->
pattern
+
ctx
->
pattern
[
0
]);
ctx
->
pattern
+
ctx
->
pattern
[
0
]);
...
@@ -1312,7 +1314,7 @@ entrance:
...
@@ -1312,7 +1314,7 @@ entrance:
ctx
->
ptr
,
ctx
->
pattern
[
0
]));
ctx
->
ptr
,
ctx
->
pattern
[
0
]));
i
=
ctx
->
pattern
[
0
];
i
=
ctx
->
pattern
[
0
];
{
{
in
t
groupref
=
i
+
i
;
Py_ssize_
t
groupref
=
i
+
i
;
if
(
groupref
>=
state
->
lastmark
)
{
if
(
groupref
>=
state
->
lastmark
)
{
RETURN_FAILURE
;
RETURN_FAILURE
;
}
else
{
}
else
{
...
@@ -1336,7 +1338,7 @@ entrance:
...
@@ -1336,7 +1338,7 @@ entrance:
ctx
->
ptr
,
ctx
->
pattern
[
0
]));
ctx
->
ptr
,
ctx
->
pattern
[
0
]));
i
=
ctx
->
pattern
[
0
];
i
=
ctx
->
pattern
[
0
];
{
{
in
t
groupref
=
i
+
i
;
Py_ssize_
t
groupref
=
i
+
i
;
if
(
groupref
>=
state
->
lastmark
)
{
if
(
groupref
>=
state
->
lastmark
)
{
RETURN_FAILURE
;
RETURN_FAILURE
;
}
else
{
}
else
{
...
@@ -1361,7 +1363,7 @@ entrance:
...
@@ -1361,7 +1363,7 @@ entrance:
/* <GROUPREF_EXISTS> <group> <skip> codeyes <JUMP> codeno ... */
/* <GROUPREF_EXISTS> <group> <skip> codeyes <JUMP> codeno ... */
i
=
ctx
->
pattern
[
0
];
i
=
ctx
->
pattern
[
0
];
{
{
in
t
groupref
=
i
+
i
;
Py_ssize_
t
groupref
=
i
+
i
;
if
(
groupref
>=
state
->
lastmark
)
{
if
(
groupref
>=
state
->
lastmark
)
{
ctx
->
pattern
+=
ctx
->
pattern
[
1
];
ctx
->
pattern
+=
ctx
->
pattern
[
1
];
break
;
break
;
...
@@ -1474,14 +1476,14 @@ exit:
...
@@ -1474,14 +1476,14 @@ exit:
return
ret
;
/* should never get here */
return
ret
;
/* should never get here */
}
}
LOCAL
(
in
t
)
LOCAL
(
Py_ssize_
t
)
SRE_SEARCH
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
)
SRE_SEARCH
(
SRE_STATE
*
state
,
SRE_CODE
*
pattern
)
{
{
SRE_CHAR
*
ptr
=
(
SRE_CHAR
*
)
state
->
start
;
SRE_CHAR
*
ptr
=
(
SRE_CHAR
*
)
state
->
start
;
SRE_CHAR
*
end
=
(
SRE_CHAR
*
)
state
->
end
;
SRE_CHAR
*
end
=
(
SRE_CHAR
*
)
state
->
end
;
in
t
status
=
0
;
Py_ssize_
t
status
=
0
;
in
t
prefix_len
=
0
;
Py_ssize_
t
prefix_len
=
0
;
in
t
prefix_skip
=
0
;
Py_ssize_
t
prefix_skip
=
0
;
SRE_CODE
*
prefix
=
NULL
;
SRE_CODE
*
prefix
=
NULL
;
SRE_CODE
*
charset
=
NULL
;
SRE_CODE
*
charset
=
NULL
;
SRE_CODE
*
overlap
=
NULL
;
SRE_CODE
*
overlap
=
NULL
;
...
@@ -1523,7 +1525,7 @@ SRE_SEARCH(SRE_STATE* state, SRE_CODE* pattern)
...
@@ -1523,7 +1525,7 @@ SRE_SEARCH(SRE_STATE* state, SRE_CODE* pattern)
if
(
prefix_len
>
1
)
{
if
(
prefix_len
>
1
)
{
/* pattern starts with a known prefix. use the overlap
/* pattern starts with a known prefix. use the overlap
table to skip forward as fast as we possibly can */
table to skip forward as fast as we possibly can */
in
t
i
=
0
;
Py_ssize_
t
i
=
0
;
end
=
(
SRE_CHAR
*
)
state
->
end
;
end
=
(
SRE_CHAR
*
)
state
->
end
;
while
(
ptr
<
end
)
{
while
(
ptr
<
end
)
{
for
(;;)
{
for
(;;)
{
...
@@ -1604,7 +1606,7 @@ SRE_SEARCH(SRE_STATE* state, SRE_CODE* pattern)
...
@@ -1604,7 +1606,7 @@ SRE_SEARCH(SRE_STATE* state, SRE_CODE* pattern)
}
}
LOCAL
(
int
)
LOCAL
(
int
)
SRE_LITERAL_TEMPLATE
(
SRE_CHAR
*
ptr
,
in
t
len
)
SRE_LITERAL_TEMPLATE
(
SRE_CHAR
*
ptr
,
Py_ssize_
t
len
)
{
{
/* check if given string is a literal template (i.e. no escapes) */
/* check if given string is a literal template (i.e. no escapes) */
while
(
len
--
>
0
)
while
(
len
--
>
0
)
...
@@ -1625,7 +1627,7 @@ static PyObject*pattern_scanner(PatternObject*, PyObject*);
...
@@ -1625,7 +1627,7 @@ static PyObject*pattern_scanner(PatternObject*, PyObject*);
static
PyObject
*
static
PyObject
*
sre_codesize
(
PyObject
*
self
,
PyObject
*
unused
)
sre_codesize
(
PyObject
*
self
,
PyObject
*
unused
)
{
{
return
Py_BuildValue
(
"
i
"
,
sizeof
(
SRE_CODE
));
return
Py_BuildValue
(
"
l
"
,
sizeof
(
SRE_CODE
));
}
}
static
PyObject
*
static
PyObject
*
...
@@ -1660,14 +1662,15 @@ state_reset(SRE_STATE* state)
...
@@ -1660,14 +1662,15 @@ state_reset(SRE_STATE* state)
}
}
static
void
*
static
void
*
getstring
(
PyObject
*
string
,
in
t
*
p_length
,
int
*
p_charsize
)
getstring
(
PyObject
*
string
,
Py_ssize_
t
*
p_length
,
int
*
p_charsize
)
{
{
/* given a python object, return a data pointer, a length (in
/* given a python object, return a data pointer, a length (in
characters), and a character size. return NULL if the object
characters), and a character size. return NULL if the object
is not a string (or not compatible) */
is not a string (or not compatible) */
PyBufferProcs
*
buffer
;
PyBufferProcs
*
buffer
;
int
size
,
bytes
,
charsize
;
Py_ssize_t
size
,
bytes
;
int
charsize
;
void
*
ptr
;
void
*
ptr
;
#if defined(HAVE_UNICODE)
#if defined(HAVE_UNICODE)
...
@@ -1706,7 +1709,7 @@ getstring(PyObject* string, int* p_length, int* p_charsize)
...
@@ -1706,7 +1709,7 @@ getstring(PyObject* string, int* p_length, int* p_charsize)
if
(
PyString_Check
(
string
)
||
bytes
==
size
)
if
(
PyString_Check
(
string
)
||
bytes
==
size
)
charsize
=
1
;
charsize
=
1
;
#if defined(HAVE_UNICODE)
#if defined(HAVE_UNICODE)
else
if
(
bytes
==
(
in
t
)
(
size
*
sizeof
(
Py_UNICODE
)))
else
if
(
bytes
==
(
Py_ssize_
t
)
(
size
*
sizeof
(
Py_UNICODE
)))
charsize
=
sizeof
(
Py_UNICODE
);
charsize
=
sizeof
(
Py_UNICODE
);
#endif
#endif
else
{
else
{
...
@@ -1726,11 +1729,11 @@ getstring(PyObject* string, int* p_length, int* p_charsize)
...
@@ -1726,11 +1729,11 @@ getstring(PyObject* string, int* p_length, int* p_charsize)
LOCAL
(
PyObject
*
)
LOCAL
(
PyObject
*
)
state_init
(
SRE_STATE
*
state
,
PatternObject
*
pattern
,
PyObject
*
string
,
state_init
(
SRE_STATE
*
state
,
PatternObject
*
pattern
,
PyObject
*
string
,
int
start
,
in
t
end
)
Py_ssize_t
start
,
Py_ssize_
t
end
)
{
{
/* prepare state object */
/* prepare state object */
in
t
length
;
Py_ssize_
t
length
;
int
charsize
;
int
charsize
;
void
*
ptr
;
void
*
ptr
;
...
@@ -1792,9 +1795,9 @@ state_fini(SRE_STATE* state)
...
@@ -1792,9 +1795,9 @@ state_fini(SRE_STATE* state)
(((char*)(member) - (char*)(state)->beginning) / (state)->charsize)
(((char*)(member) - (char*)(state)->beginning) / (state)->charsize)
LOCAL
(
PyObject
*
)
LOCAL
(
PyObject
*
)
state_getslice
(
SRE_STATE
*
state
,
in
t
index
,
PyObject
*
string
,
int
empty
)
state_getslice
(
SRE_STATE
*
state
,
Py_ssize_
t
index
,
PyObject
*
string
,
int
empty
)
{
{
in
t
i
,
j
;
Py_ssize_
t
i
,
j
;
index
=
(
index
-
1
)
*
2
;
index
=
(
index
-
1
)
*
2
;
...
@@ -1854,10 +1857,10 @@ pattern_match(PatternObject* self, PyObject* args, PyObject* kw)
...
@@ -1854,10 +1857,10 @@ pattern_match(PatternObject* self, PyObject* args, PyObject* kw)
int
status
;
int
status
;
PyObject
*
string
;
PyObject
*
string
;
in
t
start
=
0
;
Py_ssize_
t
start
=
0
;
int
end
=
IN
T_MAX
;
Py_ssize_t
end
=
PY_SSIZE_
T_MAX
;
static
char
*
kwlist
[]
=
{
"pattern"
,
"pos"
,
"endpos"
,
NULL
};
static
char
*
kwlist
[]
=
{
"pattern"
,
"pos"
,
"endpos"
,
NULL
};
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
ii
:match"
,
kwlist
,
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
nn
:match"
,
kwlist
,
&
string
,
&
start
,
&
end
))
&
string
,
&
start
,
&
end
))
return
NULL
;
return
NULL
;
...
@@ -1891,10 +1894,10 @@ pattern_search(PatternObject* self, PyObject* args, PyObject* kw)
...
@@ -1891,10 +1894,10 @@ pattern_search(PatternObject* self, PyObject* args, PyObject* kw)
int
status
;
int
status
;
PyObject
*
string
;
PyObject
*
string
;
in
t
start
=
0
;
Py_ssize_
t
start
=
0
;
int
end
=
IN
T_MAX
;
Py_ssize_t
end
=
PY_SSIZE_
T_MAX
;
static
char
*
kwlist
[]
=
{
"pattern"
,
"pos"
,
"endpos"
,
NULL
};
static
char
*
kwlist
[]
=
{
"pattern"
,
"pos"
,
"endpos"
,
NULL
};
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
ii
:search"
,
kwlist
,
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
nn
:search"
,
kwlist
,
&
string
,
&
start
,
&
end
))
&
string
,
&
start
,
&
end
))
return
NULL
;
return
NULL
;
...
@@ -2029,13 +2032,13 @@ pattern_findall(PatternObject* self, PyObject* args, PyObject* kw)
...
@@ -2029,13 +2032,13 @@ pattern_findall(PatternObject* self, PyObject* args, PyObject* kw)
SRE_STATE
state
;
SRE_STATE
state
;
PyObject
*
list
;
PyObject
*
list
;
int
status
;
int
status
;
in
t
i
,
b
,
e
;
Py_ssize_
t
i
,
b
,
e
;
PyObject
*
string
;
PyObject
*
string
;
in
t
start
=
0
;
Py_ssize_
t
start
=
0
;
int
end
=
IN
T_MAX
;
Py_ssize_t
end
=
PY_SSIZE_
T_MAX
;
static
char
*
kwlist
[]
=
{
"source"
,
"pos"
,
"endpos"
,
NULL
};
static
char
*
kwlist
[]
=
{
"source"
,
"pos"
,
"endpos"
,
NULL
};
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
ii
:findall"
,
kwlist
,
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
nn
:findall"
,
kwlist
,
&
string
,
&
start
,
&
end
))
&
string
,
&
start
,
&
end
))
return
NULL
;
return
NULL
;
...
@@ -2154,18 +2157,18 @@ pattern_split(PatternObject* self, PyObject* args, PyObject* kw)
...
@@ -2154,18 +2157,18 @@ pattern_split(PatternObject* self, PyObject* args, PyObject* kw)
PyObject
*
list
;
PyObject
*
list
;
PyObject
*
item
;
PyObject
*
item
;
int
status
;
int
status
;
in
t
n
;
Py_ssize_
t
n
;
in
t
i
;
Py_ssize_
t
i
;
void
*
last
;
void
*
last
;
PyObject
*
string
;
PyObject
*
string
;
in
t
maxsplit
=
0
;
Py_ssize_
t
maxsplit
=
0
;
static
char
*
kwlist
[]
=
{
"source"
,
"maxsplit"
,
NULL
};
static
char
*
kwlist
[]
=
{
"source"
,
"maxsplit"
,
NULL
};
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
i
:split"
,
kwlist
,
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"O|
n
:split"
,
kwlist
,
&
string
,
&
maxsplit
))
&
string
,
&
maxsplit
))
return
NULL
;
return
NULL
;
string
=
state_init
(
&
state
,
self
,
string
,
0
,
IN
T_MAX
);
string
=
state_init
(
&
state
,
self
,
string
,
0
,
PY_SSIZE_
T_MAX
);
if
(
!
string
)
if
(
!
string
)
return
NULL
;
return
NULL
;
...
@@ -2259,7 +2262,7 @@ error:
...
@@ -2259,7 +2262,7 @@ error:
static
PyObject
*
static
PyObject
*
pattern_subx
(
PatternObject
*
self
,
PyObject
*
ptemplate
,
PyObject
*
string
,
pattern_subx
(
PatternObject
*
self
,
PyObject
*
ptemplate
,
PyObject
*
string
,
int
count
,
in
t
subn
)
Py_ssize_t
count
,
Py_ssize_
t
subn
)
{
{
SRE_STATE
state
;
SRE_STATE
state
;
PyObject
*
list
;
PyObject
*
list
;
...
@@ -2269,8 +2272,9 @@ pattern_subx(PatternObject* self, PyObject* ptemplate, PyObject* string,
...
@@ -2269,8 +2272,9 @@ pattern_subx(PatternObject* self, PyObject* ptemplate, PyObject* string,
PyObject
*
match
;
PyObject
*
match
;
void
*
ptr
;
void
*
ptr
;
int
status
;
int
status
;
int
n
;
Py_ssize_t
n
;
int
i
,
b
,
e
;
Py_ssize_t
i
,
b
,
e
;
int
bint
;
int
filter_is_callable
;
int
filter_is_callable
;
if
(
PyCallable_Check
(
ptemplate
))
{
if
(
PyCallable_Check
(
ptemplate
))
{
...
@@ -2281,7 +2285,8 @@ pattern_subx(PatternObject* self, PyObject* ptemplate, PyObject* string,
...
@@ -2281,7 +2285,8 @@ pattern_subx(PatternObject* self, PyObject* ptemplate, PyObject* string,
}
else
{
}
else
{
/* if not callable, check if it's a literal string */
/* if not callable, check if it's a literal string */
int
literal
;
int
literal
;
ptr
=
getstring
(
ptemplate
,
&
n
,
&
b
);
ptr
=
getstring
(
ptemplate
,
&
n
,
&
bint
);
b
=
bint
;
if
(
ptr
)
{
if
(
ptr
)
{
if
(
b
==
1
)
{
if
(
b
==
1
)
{
literal
=
sre_literal_template
((
unsigned
char
*
)
ptr
,
n
);
literal
=
sre_literal_template
((
unsigned
char
*
)
ptr
,
n
);
...
@@ -2310,7 +2315,7 @@ pattern_subx(PatternObject* self, PyObject* ptemplate, PyObject* string,
...
@@ -2310,7 +2315,7 @@ pattern_subx(PatternObject* self, PyObject* ptemplate, PyObject* string,
}
}
}
}
string
=
state_init
(
&
state
,
self
,
string
,
0
,
IN
T_MAX
);
string
=
state_init
(
&
state
,
self
,
string
,
0
,
PY_SSIZE_
T_MAX
);
if
(
!
string
)
{
if
(
!
string
)
{
Py_DECREF
(
filter
);
Py_DECREF
(
filter
);
return
NULL
;
return
NULL
;
...
@@ -2443,9 +2448,9 @@ pattern_sub(PatternObject* self, PyObject* args, PyObject* kw)
...
@@ -2443,9 +2448,9 @@ pattern_sub(PatternObject* self, PyObject* args, PyObject* kw)
{
{
PyObject
*
ptemplate
;
PyObject
*
ptemplate
;
PyObject
*
string
;
PyObject
*
string
;
in
t
count
=
0
;
Py_ssize_
t
count
=
0
;
static
char
*
kwlist
[]
=
{
"repl"
,
"string"
,
"count"
,
NULL
};
static
char
*
kwlist
[]
=
{
"repl"
,
"string"
,
"count"
,
NULL
};
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"OO|
i
:sub"
,
kwlist
,
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"OO|
n
:sub"
,
kwlist
,
&
ptemplate
,
&
string
,
&
count
))
&
ptemplate
,
&
string
,
&
count
))
return
NULL
;
return
NULL
;
...
@@ -2457,9 +2462,9 @@ pattern_subn(PatternObject* self, PyObject* args, PyObject* kw)
...
@@ -2457,9 +2462,9 @@ pattern_subn(PatternObject* self, PyObject* args, PyObject* kw)
{
{
PyObject
*
ptemplate
;
PyObject
*
ptemplate
;
PyObject
*
string
;
PyObject
*
string
;
in
t
count
=
0
;
Py_ssize_
t
count
=
0
;
static
char
*
kwlist
[]
=
{
"repl"
,
"string"
,
"count"
,
NULL
};
static
char
*
kwlist
[]
=
{
"repl"
,
"string"
,
"count"
,
NULL
};
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"OO|
i
:subn"
,
kwlist
,
if
(
!
PyArg_ParseTupleAndKeywords
(
args
,
kw
,
"OO|
n
:subn"
,
kwlist
,
&
ptemplate
,
&
string
,
&
count
))
&
ptemplate
,
&
string
,
&
count
))
return
NULL
;
return
NULL
;
...
@@ -2642,15 +2647,15 @@ _compile(PyObject* self_, PyObject* args)
...
@@ -2642,15 +2647,15 @@ _compile(PyObject* self_, PyObject* args)
/* "compile" pattern descriptor to pattern object */
/* "compile" pattern descriptor to pattern object */
PatternObject
*
self
;
PatternObject
*
self
;
in
t
i
,
n
;
Py_ssize_
t
i
,
n
;
PyObject
*
pattern
;
PyObject
*
pattern
;
int
flags
=
0
;
int
flags
=
0
;
PyObject
*
code
;
PyObject
*
code
;
in
t
groups
=
0
;
Py_ssize_
t
groups
=
0
;
PyObject
*
groupindex
=
NULL
;
PyObject
*
groupindex
=
NULL
;
PyObject
*
indexgroup
=
NULL
;
PyObject
*
indexgroup
=
NULL
;
if
(
!
PyArg_ParseTuple
(
args
,
"OiO!|
i
OO"
,
&
pattern
,
&
flags
,
if
(
!
PyArg_ParseTuple
(
args
,
"OiO!|
n
OO"
,
&
pattern
,
&
flags
,
&
PyList_Type
,
&
code
,
&
groups
,
&
PyList_Type
,
&
code
,
&
groups
,
&
groupindex
,
&
indexgroup
))
&
groupindex
,
&
indexgroup
))
return
NULL
;
return
NULL
;
...
@@ -2711,7 +2716,7 @@ match_dealloc(MatchObject* self)
...
@@ -2711,7 +2716,7 @@ match_dealloc(MatchObject* self)
}
}
static
PyObject
*
static
PyObject
*
match_getslice_by_index
(
MatchObject
*
self
,
in
t
index
,
PyObject
*
def
)
match_getslice_by_index
(
MatchObject
*
self
,
Py_ssize_
t
index
,
PyObject
*
def
)
{
{
if
(
index
<
0
||
index
>=
self
->
groups
)
{
if
(
index
<
0
||
index
>=
self
->
groups
)
{
/* raise IndexError if we were given a bad group number */
/* raise IndexError if we were given a bad group number */
...
@@ -2735,21 +2740,21 @@ match_getslice_by_index(MatchObject* self, int index, PyObject* def)
...
@@ -2735,21 +2740,21 @@ match_getslice_by_index(MatchObject* self, int index, PyObject* def)
);
);
}
}
static
in
t
static
Py_ssize_
t
match_getindex
(
MatchObject
*
self
,
PyObject
*
index
)
match_getindex
(
MatchObject
*
self
,
PyObject
*
index
)
{
{
in
t
i
;
Py_ssize_
t
i
;
if
(
PyInt_Check
(
index
))
if
(
PyInt_Check
(
index
))
return
(
int
)
PyInt_AS_LONG
(
index
);
return
PyInt_AsSsize_t
(
index
);
i
=
-
1
;
i
=
-
1
;
if
(
self
->
pattern
->
groupindex
)
{
if
(
self
->
pattern
->
groupindex
)
{
index
=
PyObject_GetItem
(
self
->
pattern
->
groupindex
,
index
);
index
=
PyObject_GetItem
(
self
->
pattern
->
groupindex
,
index
);
if
(
index
)
{
if
(
index
)
{
if
(
PyInt_Check
(
index
))
if
(
PyInt_Check
(
index
)
||
PyLong_Check
(
index
)
)
i
=
(
int
)
PyInt_AS_LONG
(
index
);
i
=
PyInt_AsSsize_t
(
index
);
Py_DECREF
(
index
);
Py_DECREF
(
index
);
}
else
}
else
PyErr_Clear
();
PyErr_Clear
();
...
@@ -2778,7 +2783,7 @@ static PyObject*
...
@@ -2778,7 +2783,7 @@ static PyObject*
match_group
(
MatchObject
*
self
,
PyObject
*
args
)
match_group
(
MatchObject
*
self
,
PyObject
*
args
)
{
{
PyObject
*
result
;
PyObject
*
result
;
in
t
i
,
size
;
Py_ssize_
t
i
,
size
;
size
=
PyTuple_GET_SIZE
(
args
);
size
=
PyTuple_GET_SIZE
(
args
);
...
@@ -2813,7 +2818,7 @@ static PyObject*
...
@@ -2813,7 +2818,7 @@ static PyObject*
match_groups
(
MatchObject
*
self
,
PyObject
*
args
,
PyObject
*
kw
)
match_groups
(
MatchObject
*
self
,
PyObject
*
args
,
PyObject
*
kw
)
{
{
PyObject
*
result
;
PyObject
*
result
;
in
t
index
;
Py_ssize_
t
index
;
PyObject
*
def
=
Py_None
;
PyObject
*
def
=
Py_None
;
static
char
*
kwlist
[]
=
{
"default"
,
NULL
};
static
char
*
kwlist
[]
=
{
"default"
,
NULL
};
...
@@ -2842,7 +2847,7 @@ match_groupdict(MatchObject* self, PyObject* args, PyObject* kw)
...
@@ -2842,7 +2847,7 @@ match_groupdict(MatchObject* self, PyObject* args, PyObject* kw)
{
{
PyObject
*
result
;
PyObject
*
result
;
PyObject
*
keys
;
PyObject
*
keys
;
in
t
index
;
Py_ssize_
t
index
;
PyObject
*
def
=
Py_None
;
PyObject
*
def
=
Py_None
;
static
char
*
kwlist
[]
=
{
"default"
,
NULL
};
static
char
*
kwlist
[]
=
{
"default"
,
NULL
};
...
@@ -2888,7 +2893,7 @@ failed:
...
@@ -2888,7 +2893,7 @@ failed:
static
PyObject
*
static
PyObject
*
match_start
(
MatchObject
*
self
,
PyObject
*
args
)
match_start
(
MatchObject
*
self
,
PyObject
*
args
)
{
{
in
t
index
;
Py_ssize_
t
index
;
PyObject
*
index_
=
Py_False
;
/* zero */
PyObject
*
index_
=
Py_False
;
/* zero */
if
(
!
PyArg_UnpackTuple
(
args
,
"start"
,
0
,
1
,
&
index_
))
if
(
!
PyArg_UnpackTuple
(
args
,
"start"
,
0
,
1
,
&
index_
))
...
@@ -2911,7 +2916,7 @@ match_start(MatchObject* self, PyObject* args)
...
@@ -2911,7 +2916,7 @@ match_start(MatchObject* self, PyObject* args)
static
PyObject
*
static
PyObject
*
match_end
(
MatchObject
*
self
,
PyObject
*
args
)
match_end
(
MatchObject
*
self
,
PyObject
*
args
)
{
{
in
t
index
;
Py_ssize_
t
index
;
PyObject
*
index_
=
Py_False
;
/* zero */
PyObject
*
index_
=
Py_False
;
/* zero */
if
(
!
PyArg_UnpackTuple
(
args
,
"end"
,
0
,
1
,
&
index_
))
if
(
!
PyArg_UnpackTuple
(
args
,
"end"
,
0
,
1
,
&
index_
))
...
@@ -2932,7 +2937,7 @@ match_end(MatchObject* self, PyObject* args)
...
@@ -2932,7 +2937,7 @@ match_end(MatchObject* self, PyObject* args)
}
}
LOCAL
(
PyObject
*
)
LOCAL
(
PyObject
*
)
_pair
(
int
i1
,
in
t
i2
)
_pair
(
Py_ssize_t
i1
,
Py_ssize_
t
i2
)
{
{
PyObject
*
pair
;
PyObject
*
pair
;
PyObject
*
item
;
PyObject
*
item
;
...
@@ -2941,12 +2946,12 @@ _pair(int i1, int i2)
...
@@ -2941,12 +2946,12 @@ _pair(int i1, int i2)
if
(
!
pair
)
if
(
!
pair
)
return
NULL
;
return
NULL
;
item
=
PyInt_From
Long
(
i1
);
item
=
PyInt_From
Ssize_t
(
i1
);
if
(
!
item
)
if
(
!
item
)
goto
error
;
goto
error
;
PyTuple_SET_ITEM
(
pair
,
0
,
item
);
PyTuple_SET_ITEM
(
pair
,
0
,
item
);
item
=
PyInt_From
Long
(
i2
);
item
=
PyInt_From
Ssize_t
(
i2
);
if
(
!
item
)
if
(
!
item
)
goto
error
;
goto
error
;
PyTuple_SET_ITEM
(
pair
,
1
,
item
);
PyTuple_SET_ITEM
(
pair
,
1
,
item
);
...
@@ -2961,7 +2966,7 @@ _pair(int i1, int i2)
...
@@ -2961,7 +2966,7 @@ _pair(int i1, int i2)
static
PyObject
*
static
PyObject
*
match_span
(
MatchObject
*
self
,
PyObject
*
args
)
match_span
(
MatchObject
*
self
,
PyObject
*
args
)
{
{
in
t
index
;
Py_ssize_
t
index
;
PyObject
*
index_
=
Py_False
;
/* zero */
PyObject
*
index_
=
Py_False
;
/* zero */
if
(
!
PyArg_UnpackTuple
(
args
,
"span"
,
0
,
1
,
&
index_
))
if
(
!
PyArg_UnpackTuple
(
args
,
"span"
,
0
,
1
,
&
index_
))
...
@@ -2986,7 +2991,7 @@ match_regs(MatchObject* self)
...
@@ -2986,7 +2991,7 @@ match_regs(MatchObject* self)
{
{
PyObject
*
regs
;
PyObject
*
regs
;
PyObject
*
item
;
PyObject
*
item
;
in
t
index
;
Py_ssize_
t
index
;
regs
=
PyTuple_New
(
self
->
groups
);
regs
=
PyTuple_New
(
self
->
groups
);
if
(
!
regs
)
if
(
!
regs
)
...
@@ -3012,7 +3017,7 @@ match_copy(MatchObject* self, PyObject *unused)
...
@@ -3012,7 +3017,7 @@ match_copy(MatchObject* self, PyObject *unused)
{
{
#ifdef USE_BUILTIN_COPY
#ifdef USE_BUILTIN_COPY
MatchObject
*
copy
;
MatchObject
*
copy
;
in
t
slots
,
offset
;
Py_ssize_
t
slots
,
offset
;
slots
=
2
*
(
self
->
pattern
->
groups
+
1
);
slots
=
2
*
(
self
->
pattern
->
groups
+
1
);
...
@@ -3029,7 +3034,7 @@ match_copy(MatchObject* self, PyObject *unused)
...
@@ -3029,7 +3034,7 @@ match_copy(MatchObject* self, PyObject *unused)
Py_XINCREF
(
self
->
regs
);
Py_XINCREF
(
self
->
regs
);
memcpy
((
char
*
)
copy
+
offset
,
(
char
*
)
self
+
offset
,
memcpy
((
char
*
)
copy
+
offset
,
(
char
*
)
self
+
offset
,
sizeof
(
MatchObject
)
+
slots
*
sizeof
(
in
t
)
-
offset
);
sizeof
(
MatchObject
)
+
slots
*
sizeof
(
Py_ssize_
t
)
-
offset
);
return
(
PyObject
*
)
copy
;
return
(
PyObject
*
)
copy
;
#else
#else
...
@@ -3144,7 +3149,7 @@ match_getattr(MatchObject* self, char* name)
...
@@ -3144,7 +3149,7 @@ match_getattr(MatchObject* self, char* name)
statichere
PyTypeObject
Match_Type
=
{
statichere
PyTypeObject
Match_Type
=
{
PyObject_HEAD_INIT
(
NULL
)
PyObject_HEAD_INIT
(
NULL
)
0
,
"_"
SRE_MODULE
".SRE_Match"
,
0
,
"_"
SRE_MODULE
".SRE_Match"
,
sizeof
(
MatchObject
),
sizeof
(
in
t
),
sizeof
(
MatchObject
),
sizeof
(
Py_ssize_
t
),
(
destructor
)
match_dealloc
,
/*tp_dealloc*/
(
destructor
)
match_dealloc
,
/*tp_dealloc*/
0
,
/*tp_print*/
0
,
/*tp_print*/
(
getattrfunc
)
match_getattr
/*tp_getattr*/
(
getattrfunc
)
match_getattr
/*tp_getattr*/
...
@@ -3156,7 +3161,7 @@ pattern_new_match(PatternObject* pattern, SRE_STATE* state, int status)
...
@@ -3156,7 +3161,7 @@ pattern_new_match(PatternObject* pattern, SRE_STATE* state, int status)
/* create match object (from state object) */
/* create match object (from state object) */
MatchObject
*
match
;
MatchObject
*
match
;
in
t
i
,
j
;
Py_ssize_
t
i
,
j
;
char
*
base
;
char
*
base
;
int
n
;
int
n
;
...
@@ -3329,9 +3334,9 @@ pattern_scanner(PatternObject* pattern, PyObject* args)
...
@@ -3329,9 +3334,9 @@ pattern_scanner(PatternObject* pattern, PyObject* args)
ScannerObject
*
self
;
ScannerObject
*
self
;
PyObject
*
string
;
PyObject
*
string
;
in
t
start
=
0
;
Py_ssize_
t
start
=
0
;
int
end
=
IN
T_MAX
;
Py_ssize_t
end
=
PY_SSIZE_
T_MAX
;
if
(
!
PyArg_ParseTuple
(
args
,
"O|
ii
:scanner"
,
&
string
,
&
start
,
&
end
))
if
(
!
PyArg_ParseTuple
(
args
,
"O|
nn
:scanner"
,
&
string
,
&
start
,
&
end
))
return
NULL
;
return
NULL
;
/* create scanner object */
/* create scanner object */
...
...
Modules/sre.h
Dosyayı görüntüle @
a6d80faf
...
@@ -23,7 +23,7 @@
...
@@ -23,7 +23,7 @@
typedef
struct
{
typedef
struct
{
PyObject_VAR_HEAD
PyObject_VAR_HEAD
in
t
groups
;
/* must be first! */
Py_ssize_
t
groups
;
/* must be first! */
PyObject
*
groupindex
;
PyObject
*
groupindex
;
PyObject
*
indexgroup
;
PyObject
*
indexgroup
;
/* compatibility */
/* compatibility */
...
@@ -31,7 +31,7 @@ typedef struct {
...
@@ -31,7 +31,7 @@ typedef struct {
int
flags
;
/* flags used when compiling pattern source */
int
flags
;
/* flags used when compiling pattern source */
PyObject
*
weakreflist
;
/* List of weak references */
PyObject
*
weakreflist
;
/* List of weak references */
/* pattern code */
/* pattern code */
in
t
codesize
;
Py_ssize_
t
codesize
;
SRE_CODE
code
[
1
];
SRE_CODE
code
[
1
];
}
PatternObject
;
}
PatternObject
;
...
@@ -42,10 +42,10 @@ typedef struct {
...
@@ -42,10 +42,10 @@ typedef struct {
PyObject
*
string
;
/* link to the target string (must be first) */
PyObject
*
string
;
/* link to the target string (must be first) */
PyObject
*
regs
;
/* cached list of matching spans */
PyObject
*
regs
;
/* cached list of matching spans */
PatternObject
*
pattern
;
/* link to the regex (pattern) object */
PatternObject
*
pattern
;
/* link to the regex (pattern) object */
in
t
pos
,
endpos
;
/* current target slice */
Py_ssize_
t
pos
,
endpos
;
/* current target slice */
in
t
lastindex
;
/* last index marker seen by the engine (-1 if none) */
Py_ssize_
t
lastindex
;
/* last index marker seen by the engine (-1 if none) */
in
t
groups
;
/* number of groups (start/end marks) */
Py_ssize_
t
groups
;
/* number of groups (start/end marks) */
in
t
mark
[
1
];
Py_ssize_
t
mark
[
1
];
}
MatchObject
;
}
MatchObject
;
typedef
unsigned
int
(
*
SRE_TOLOWER_HOOK
)(
unsigned
int
ch
);
typedef
unsigned
int
(
*
SRE_TOLOWER_HOOK
)(
unsigned
int
ch
);
...
@@ -54,7 +54,7 @@ typedef unsigned int (*SRE_TOLOWER_HOOK)(unsigned int ch);
...
@@ -54,7 +54,7 @@ typedef unsigned int (*SRE_TOLOWER_HOOK)(unsigned int ch);
#define SRE_MARK_SIZE 200
#define SRE_MARK_SIZE 200
typedef
struct
SRE_REPEAT_T
{
typedef
struct
SRE_REPEAT_T
{
in
t
count
;
Py_ssize_
t
count
;
SRE_CODE
*
pattern
;
/* points to REPEAT operator arguments */
SRE_CODE
*
pattern
;
/* points to REPEAT operator arguments */
void
*
last_ptr
;
/* helper to check for infinite loops */
void
*
last_ptr
;
/* helper to check for infinite loops */
struct
SRE_REPEAT_T
*
prev
;
/* points to previous repeat context */
struct
SRE_REPEAT_T
*
prev
;
/* points to previous repeat context */
...
@@ -68,17 +68,17 @@ typedef struct {
...
@@ -68,17 +68,17 @@ typedef struct {
void
*
end
;
/* end of original string */
void
*
end
;
/* end of original string */
/* attributes for the match object */
/* attributes for the match object */
PyObject
*
string
;
PyObject
*
string
;
in
t
pos
,
endpos
;
Py_ssize_
t
pos
,
endpos
;
/* character size */
/* character size */
int
charsize
;
int
charsize
;
/* registers */
/* registers */
in
t
lastindex
;
Py_ssize_
t
lastindex
;
in
t
lastmark
;
Py_ssize_
t
lastmark
;
void
*
mark
[
SRE_MARK_SIZE
];
void
*
mark
[
SRE_MARK_SIZE
];
/* dynamically allocated stuff */
/* dynamically allocated stuff */
char
*
data_stack
;
char
*
data_stack
;
unsigned
in
t
data_stack_size
;
size_
t
data_stack_size
;
unsigned
in
t
data_stack_base
;
size_
t
data_stack_base
;
/* current repeat context */
/* current repeat context */
SRE_REPEAT
*
repeat
;
SRE_REPEAT
*
repeat
;
/* hooks */
/* hooks */
...
...
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