mirror of
https://github.com/python/cpython.git
synced 2025-07-15 23:35:23 +00:00
#6780: merge with 3.2.
This commit is contained in:
commit
bf1253b25a
6 changed files with 53 additions and 9 deletions
|
@ -305,6 +305,11 @@ class BaseBytesTest(unittest.TestCase):
|
||||||
self.assertTrue(b.startswith(b"h"))
|
self.assertTrue(b.startswith(b"h"))
|
||||||
self.assertFalse(b.startswith(b"hellow"))
|
self.assertFalse(b.startswith(b"hellow"))
|
||||||
self.assertFalse(b.startswith(b"ha"))
|
self.assertFalse(b.startswith(b"ha"))
|
||||||
|
with self.assertRaises(TypeError) as cm:
|
||||||
|
b.startswith([b'h'])
|
||||||
|
exc = str(cm.exception)
|
||||||
|
self.assertIn('bytes', exc)
|
||||||
|
self.assertIn('tuple', exc)
|
||||||
|
|
||||||
def test_endswith(self):
|
def test_endswith(self):
|
||||||
b = self.type2test(b'hello')
|
b = self.type2test(b'hello')
|
||||||
|
@ -314,6 +319,11 @@ class BaseBytesTest(unittest.TestCase):
|
||||||
self.assertTrue(b.endswith(b"o"))
|
self.assertTrue(b.endswith(b"o"))
|
||||||
self.assertFalse(b.endswith(b"whello"))
|
self.assertFalse(b.endswith(b"whello"))
|
||||||
self.assertFalse(b.endswith(b"no"))
|
self.assertFalse(b.endswith(b"no"))
|
||||||
|
with self.assertRaises(TypeError) as cm:
|
||||||
|
b.endswith([b'o'])
|
||||||
|
exc = str(cm.exception)
|
||||||
|
self.assertIn('bytes', exc)
|
||||||
|
self.assertIn('tuple', exc)
|
||||||
|
|
||||||
def test_find(self):
|
def test_find(self):
|
||||||
b = self.type2test(b'mississippi')
|
b = self.type2test(b'mississippi')
|
||||||
|
|
|
@ -819,6 +819,14 @@ class UnicodeTest(string_tests.CommonTest,
|
||||||
self.assertEqual('%f' % INF, 'inf')
|
self.assertEqual('%f' % INF, 'inf')
|
||||||
self.assertEqual('%F' % INF, 'INF')
|
self.assertEqual('%F' % INF, 'INF')
|
||||||
|
|
||||||
|
def test_startswith_endswith_errors(self):
|
||||||
|
for meth in ('foo'.startswith, 'foo'.endswith):
|
||||||
|
with self.assertRaises(TypeError) as cm:
|
||||||
|
meth(['f'])
|
||||||
|
exc = str(cm.exception)
|
||||||
|
self.assertIn('str', exc)
|
||||||
|
self.assertIn('tuple', exc)
|
||||||
|
|
||||||
@support.run_with_locale('LC_ALL', 'de_DE', 'fr_FR')
|
@support.run_with_locale('LC_ALL', 'de_DE', 'fr_FR')
|
||||||
def test_format_float(self):
|
def test_format_float(self):
|
||||||
# should not format with a comma, but always with C locale
|
# should not format with a comma, but always with C locale
|
||||||
|
|
|
@ -10,6 +10,9 @@ What's New in Python 3.3 Alpha 1?
|
||||||
Core and Builtins
|
Core and Builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- Issue #6780: fix starts/endswith error message to mention that tuples are
|
||||||
|
accepted too.
|
||||||
|
|
||||||
- Issue #5057: fix a bug in the peepholer that led to non-portable pyc files
|
- Issue #5057: fix a bug in the peepholer that led to non-portable pyc files
|
||||||
between narrow and wide builds while optimizing BINARY_SUBSCR on non-BMP
|
between narrow and wide builds while optimizing BINARY_SUBSCR on non-BMP
|
||||||
chars (e.g. "\U00012345"[0]).
|
chars (e.g. "\U00012345"[0]).
|
||||||
|
|
|
@ -1304,7 +1304,7 @@ PyDoc_STRVAR(startswith__doc__,
|
||||||
Return True if B starts with the specified prefix, False otherwise.\n\
|
Return True if B starts with the specified prefix, False otherwise.\n\
|
||||||
With optional start, test B beginning at that position.\n\
|
With optional start, test B beginning at that position.\n\
|
||||||
With optional end, stop comparing B at that position.\n\
|
With optional end, stop comparing B at that position.\n\
|
||||||
prefix can also be a tuple of strings to try.");
|
prefix can also be a tuple of bytes to try.");
|
||||||
|
|
||||||
static PyObject *
|
static PyObject *
|
||||||
bytearray_startswith(PyByteArrayObject *self, PyObject *args)
|
bytearray_startswith(PyByteArrayObject *self, PyObject *args)
|
||||||
|
@ -1331,8 +1331,12 @@ bytearray_startswith(PyByteArrayObject *self, PyObject *args)
|
||||||
Py_RETURN_FALSE;
|
Py_RETURN_FALSE;
|
||||||
}
|
}
|
||||||
result = _bytearray_tailmatch(self, subobj, start, end, -1);
|
result = _bytearray_tailmatch(self, subobj, start, end, -1);
|
||||||
if (result == -1)
|
if (result == -1) {
|
||||||
|
if (PyErr_ExceptionMatches(PyExc_TypeError))
|
||||||
|
PyErr_Format(PyExc_TypeError, "startswith first arg must be bytes "
|
||||||
|
"or a tuple of bytes, not %s", Py_TYPE(subobj)->tp_name);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return PyBool_FromLong(result);
|
return PyBool_FromLong(result);
|
||||||
}
|
}
|
||||||
|
@ -1343,7 +1347,7 @@ PyDoc_STRVAR(endswith__doc__,
|
||||||
Return True if B ends with the specified suffix, False otherwise.\n\
|
Return True if B ends with the specified suffix, False otherwise.\n\
|
||||||
With optional start, test B beginning at that position.\n\
|
With optional start, test B beginning at that position.\n\
|
||||||
With optional end, stop comparing B at that position.\n\
|
With optional end, stop comparing B at that position.\n\
|
||||||
suffix can also be a tuple of strings to try.");
|
suffix can also be a tuple of bytes to try.");
|
||||||
|
|
||||||
static PyObject *
|
static PyObject *
|
||||||
bytearray_endswith(PyByteArrayObject *self, PyObject *args)
|
bytearray_endswith(PyByteArrayObject *self, PyObject *args)
|
||||||
|
@ -1370,8 +1374,12 @@ bytearray_endswith(PyByteArrayObject *self, PyObject *args)
|
||||||
Py_RETURN_FALSE;
|
Py_RETURN_FALSE;
|
||||||
}
|
}
|
||||||
result = _bytearray_tailmatch(self, subobj, start, end, +1);
|
result = _bytearray_tailmatch(self, subobj, start, end, +1);
|
||||||
if (result == -1)
|
if (result == -1) {
|
||||||
|
if (PyErr_ExceptionMatches(PyExc_TypeError))
|
||||||
|
PyErr_Format(PyExc_TypeError, "endswith first arg must be bytes or "
|
||||||
|
"a tuple of bytes, not %s", Py_TYPE(subobj)->tp_name);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return PyBool_FromLong(result);
|
return PyBool_FromLong(result);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2224,8 +2224,12 @@ bytes_startswith(PyBytesObject *self, PyObject *args)
|
||||||
Py_RETURN_FALSE;
|
Py_RETURN_FALSE;
|
||||||
}
|
}
|
||||||
result = _bytes_tailmatch(self, subobj, start, end, -1);
|
result = _bytes_tailmatch(self, subobj, start, end, -1);
|
||||||
if (result == -1)
|
if (result == -1) {
|
||||||
|
if (PyErr_ExceptionMatches(PyExc_TypeError))
|
||||||
|
PyErr_Format(PyExc_TypeError, "startswith first arg must be bytes "
|
||||||
|
"or a tuple of bytes, not %s", Py_TYPE(subobj)->tp_name);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return PyBool_FromLong(result);
|
return PyBool_FromLong(result);
|
||||||
}
|
}
|
||||||
|
@ -2264,8 +2268,12 @@ bytes_endswith(PyBytesObject *self, PyObject *args)
|
||||||
Py_RETURN_FALSE;
|
Py_RETURN_FALSE;
|
||||||
}
|
}
|
||||||
result = _bytes_tailmatch(self, subobj, start, end, +1);
|
result = _bytes_tailmatch(self, subobj, start, end, +1);
|
||||||
if (result == -1)
|
if (result == -1) {
|
||||||
|
if (PyErr_ExceptionMatches(PyExc_TypeError))
|
||||||
|
PyErr_Format(PyExc_TypeError, "endswith first arg must be bytes or "
|
||||||
|
"a tuple of bytes, not %s", Py_TYPE(subobj)->tp_name);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return PyBool_FromLong(result);
|
return PyBool_FromLong(result);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9101,8 +9101,12 @@ unicode_startswith(PyUnicodeObject *self,
|
||||||
Py_RETURN_FALSE;
|
Py_RETURN_FALSE;
|
||||||
}
|
}
|
||||||
substring = (PyUnicodeObject *)PyUnicode_FromObject(subobj);
|
substring = (PyUnicodeObject *)PyUnicode_FromObject(subobj);
|
||||||
if (substring == NULL)
|
if (substring == NULL) {
|
||||||
|
if (PyErr_ExceptionMatches(PyExc_TypeError))
|
||||||
|
PyErr_Format(PyExc_TypeError, "startswith first arg must be str or "
|
||||||
|
"a tuple of str, not %s", Py_TYPE(subobj)->tp_name);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
result = tailmatch(self, substring, start, end, -1);
|
result = tailmatch(self, substring, start, end, -1);
|
||||||
Py_DECREF(substring);
|
Py_DECREF(substring);
|
||||||
return PyBool_FromLong(result);
|
return PyBool_FromLong(result);
|
||||||
|
@ -9145,9 +9149,12 @@ unicode_endswith(PyUnicodeObject *self,
|
||||||
Py_RETURN_FALSE;
|
Py_RETURN_FALSE;
|
||||||
}
|
}
|
||||||
substring = (PyUnicodeObject *)PyUnicode_FromObject(subobj);
|
substring = (PyUnicodeObject *)PyUnicode_FromObject(subobj);
|
||||||
if (substring == NULL)
|
if (substring == NULL) {
|
||||||
|
if (PyErr_ExceptionMatches(PyExc_TypeError))
|
||||||
|
PyErr_Format(PyExc_TypeError, "endswith first arg must be str or "
|
||||||
|
"a tuple of str, not %s", Py_TYPE(subobj)->tp_name);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
}
|
||||||
result = tailmatch(self, substring, start, end, +1);
|
result = tailmatch(self, substring, start, end, +1);
|
||||||
Py_DECREF(substring);
|
Py_DECREF(substring);
|
||||||
return PyBool_FromLong(result);
|
return PyBool_FromLong(result);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue