Commit e50fe4c9 authored by Serhiy Storchaka's avatar Serhiy Storchaka

Issue #20283: RE pattern methods now accept the string keyword parameters

as documented.  The pattern and source keyword parameters are left as
deprecated aliases.
parent 09f4f253
...@@ -933,6 +933,19 @@ class ReTests(unittest.TestCase): ...@@ -933,6 +933,19 @@ class ReTests(unittest.TestCase):
self.assertEqual(out.getvalue().splitlines(), self.assertEqual(out.getvalue().splitlines(),
['literal 102', 'literal 111', 'literal 111']) ['literal 102', 'literal 111', 'literal 111'])
def test_keyword_parameters(self):
# Issue #20283: Accepting the string keyword parameter.
pat = re.compile(r'(ab)')
self.assertEqual(
pat.match(string='abracadabra', pos=7, endpos=10).span(), (7, 9))
self.assertEqual(
pat.search(string='abracadabra', pos=3, endpos=10).span(), (7, 9))
self.assertEqual(
pat.findall(string='abracadabra', pos=3, endpos=10), ['ab'])
self.assertEqual(
pat.split(string='abracadabra', maxsplit=1),
['', 'ab', 'racadabra'])
def run_re_tests(): def run_re_tests():
from test.re_tests import tests, SUCCEED, FAIL, SYNTAX_ERROR from test.re_tests import tests, SUCCEED, FAIL, SYNTAX_ERROR
......
...@@ -40,6 +40,10 @@ Core and Builtins ...@@ -40,6 +40,10 @@ Core and Builtins
Library Library
------- -------
- Issue #20283: RE pattern methods now accept the string keyword parameters
as documented. The pattern and source keyword parameters are left as
deprecated aliases.
- Issue #15618: Make turtle.py compatible with 'from __future__ import - Issue #15618: Make turtle.py compatible with 'from __future__ import
unicode_literals'. Initial patch by Juancarlo Añez. unicode_literals'. Initial patch by Juancarlo Añez.
......
...@@ -1875,18 +1875,62 @@ pattern_dealloc(PatternObject* self) ...@@ -1875,18 +1875,62 @@ pattern_dealloc(PatternObject* self)
PyObject_DEL(self); PyObject_DEL(self);
} }
static int
check_args_size(const char *name, PyObject* args, PyObject* kw, int n)
{
Py_ssize_t m = PyTuple_GET_SIZE(args) + (kw ? PyDict_Size(kw) : 0);
if (m <= n)
return 1;
PyErr_Format(PyExc_TypeError,
"%s() takes at most %d positional arguments (%zd given)",
name, n, m);
return 0;
}
static PyObject*
fix_string_param(PyObject *string, PyObject *string2, const char *oldname)
{
if (string2 != NULL) {
char buf[100];
if (string != NULL) {
PyErr_Format(PyExc_TypeError,
"Argument given by name ('%s') and position (1)",
oldname);
return NULL;
}
sprintf(buf, "The '%s' keyword parameter name is deprecated. "
"Use 'string' instead.", oldname);
if (PyErr_Warn(PyExc_DeprecationWarning, buf) < 0)
return NULL;
return string2;
}
if (string == NULL) {
PyErr_SetString(PyExc_TypeError,
"Required argument 'string' (pos 1) not found");
return NULL;
}
return string;
}
static PyObject* static PyObject*
pattern_match(PatternObject* self, PyObject* args, PyObject* kw) pattern_match(PatternObject* self, PyObject* args, PyObject* kw)
{ {
SRE_STATE state; SRE_STATE state;
int status; int status;
PyObject* string; PyObject *string = NULL, *string2 = NULL;
Py_ssize_t start = 0; Py_ssize_t start = 0;
Py_ssize_t end = PY_SSIZE_T_MAX; Py_ssize_t end = PY_SSIZE_T_MAX;
static char* kwlist[] = { "pattern", "pos", "endpos", NULL }; static char* kwlist[] = { "string", "pos", "endpos", "pattern", NULL };
if (!PyArg_ParseTupleAndKeywords(args, kw, "O|nn:match", kwlist, if (!check_args_size("match", args, kw, 3))
&string, &start, &end)) return NULL;
if (!PyArg_ParseTupleAndKeywords(args, kw, "|OnnO:match", kwlist,
&string, &start, &end, &string2))
return NULL;
string = fix_string_param(string, string2, "pattern");
if (!string)
return NULL; return NULL;
string = state_init(&state, self, string, start, end); string = state_init(&state, self, string, start, end);
...@@ -1920,12 +1964,19 @@ pattern_search(PatternObject* self, PyObject* args, PyObject* kw) ...@@ -1920,12 +1964,19 @@ pattern_search(PatternObject* self, PyObject* args, PyObject* kw)
SRE_STATE state; SRE_STATE state;
int status; int status;
PyObject* string; PyObject *string = NULL, *string2 = NULL;
Py_ssize_t start = 0; Py_ssize_t start = 0;
Py_ssize_t end = PY_SSIZE_T_MAX; Py_ssize_t end = PY_SSIZE_T_MAX;
static char* kwlist[] = { "pattern", "pos", "endpos", NULL }; static char* kwlist[] = { "string", "pos", "endpos", "pattern", NULL };
if (!PyArg_ParseTupleAndKeywords(args, kw, "O|nn:search", kwlist, if (!check_args_size("search", args, kw, 3))
&string, &start, &end)) return NULL;
if (!PyArg_ParseTupleAndKeywords(args, kw, "|OnnO:search", kwlist,
&string, &start, &end, &string2))
return NULL;
string = fix_string_param(string, string2, "pattern");
if (!string)
return NULL; return NULL;
string = state_init(&state, self, string, start, end); string = state_init(&state, self, string, start, end);
...@@ -2055,12 +2106,19 @@ pattern_findall(PatternObject* self, PyObject* args, PyObject* kw) ...@@ -2055,12 +2106,19 @@ pattern_findall(PatternObject* self, PyObject* args, PyObject* kw)
int status; int status;
Py_ssize_t i, b, e; Py_ssize_t i, b, e;
PyObject* string; PyObject *string = NULL, *string2 = NULL;
Py_ssize_t start = 0; Py_ssize_t start = 0;
Py_ssize_t end = PY_SSIZE_T_MAX; Py_ssize_t end = PY_SSIZE_T_MAX;
static char* kwlist[] = { "source", "pos", "endpos", NULL }; static char* kwlist[] = { "string", "pos", "endpos", "source", NULL };
if (!PyArg_ParseTupleAndKeywords(args, kw, "O|nn:findall", kwlist, if (!check_args_size("findall", args, kw, 3))
&string, &start, &end)) return NULL;
if (!PyArg_ParseTupleAndKeywords(args, kw, "|OnnO:findall", kwlist,
&string, &start, &end, &string2))
return NULL;
string = fix_string_param(string, string2, "source");
if (!string)
return NULL; return NULL;
string = state_init(&state, self, string, start, end); string = state_init(&state, self, string, start, end);
...@@ -2185,11 +2243,18 @@ pattern_split(PatternObject* self, PyObject* args, PyObject* kw) ...@@ -2185,11 +2243,18 @@ pattern_split(PatternObject* self, PyObject* args, PyObject* kw)
Py_ssize_t i; Py_ssize_t i;
void* last; void* last;
PyObject* string; PyObject *string = NULL, *string2 = NULL;
Py_ssize_t maxsplit = 0; Py_ssize_t maxsplit = 0;
static char* kwlist[] = { "source", "maxsplit", NULL }; static char* kwlist[] = { "string", "maxsplit", "source", NULL };
if (!PyArg_ParseTupleAndKeywords(args, kw, "O|n:split", kwlist, if (!check_args_size("split", args, kw, 2))
&string, &maxsplit)) return NULL;
if (!PyArg_ParseTupleAndKeywords(args, kw, "|OnO:split", kwlist,
&string, &maxsplit, &string2))
return NULL;
string = fix_string_param(string, string2, "source");
if (!string)
return NULL; return NULL;
string = state_init(&state, self, string, 0, PY_SSIZE_T_MAX); string = state_init(&state, self, string, 0, PY_SSIZE_T_MAX);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment