Commit 96e12d5f authored by Min ho Kim's avatar Min ho Kim Committed by Terry Jan Reedy

Fix typos in docs, comments and test assert messages (#14872)

parent 8e3a7380
...@@ -1175,7 +1175,7 @@ Keep in mind that retrieving sub-objects from Structure, Unions, and Arrays ...@@ -1175,7 +1175,7 @@ Keep in mind that retrieving sub-objects from Structure, Unions, and Arrays
doesn't *copy* the sub-object, instead it retrieves a wrapper object accessing doesn't *copy* the sub-object, instead it retrieves a wrapper object accessing
the root-object's underlying buffer. the root-object's underlying buffer.
Another example that may behave different from what one would expect is this:: Another example that may behave differently from what one would expect is this::
>>> s = c_char_p() >>> s = c_char_p()
>>> s.value = b"abc def ghi" >>> s.value = b"abc def ghi"
......
...@@ -1243,7 +1243,7 @@ class ThreadedChildWatcher(AbstractChildWatcher): ...@@ -1243,7 +1243,7 @@ class ThreadedChildWatcher(AbstractChildWatcher):
It doesn't require subscription on POSIX signal It doesn't require subscription on POSIX signal
but a thread creation is not free. but a thread creation is not free.
The watcher has O(1) complexity, its perfomance doesn't depend The watcher has O(1) complexity, its performance doesn't depend
on amount of spawn processes. on amount of spawn processes.
""" """
......
...@@ -440,7 +440,7 @@ def namedtuple(typename, field_names, *, rename=False, defaults=None, module=Non ...@@ -440,7 +440,7 @@ def namedtuple(typename, field_names, *, rename=False, defaults=None, module=Non
'__slots__': (), '__slots__': (),
'_fields': field_names, '_fields': field_names,
'_field_defaults': field_defaults, '_field_defaults': field_defaults,
# alternate spelling for backward compatiblity # alternate spelling for backward compatibility
'_fields_defaults': field_defaults, '_fields_defaults': field_defaults,
'__new__': __new__, '__new__': __new__,
'_make': _make, '_make': _make,
......
...@@ -1189,7 +1189,7 @@ def make_dataclass(cls_name, fields, *, bases=(), namespace=None, init=True, ...@@ -1189,7 +1189,7 @@ def make_dataclass(cls_name, fields, *, bases=(), namespace=None, init=True,
raise TypeError(f'Invalid field: {item!r}') raise TypeError(f'Invalid field: {item!r}')
if not isinstance(name, str) or not name.isidentifier(): if not isinstance(name, str) or not name.isidentifier():
raise TypeError(f'Field names must be valid identifers: {name!r}') raise TypeError(f'Field names must be valid identifiers: {name!r}')
if keyword.iskeyword(name): if keyword.iskeyword(name):
raise TypeError(f'Field names must not be keywords: {name!r}') raise TypeError(f'Field names must not be keywords: {name!r}')
if name in seen: if name in seen:
......
...@@ -245,7 +245,7 @@ class BaseHeader(str): ...@@ -245,7 +245,7 @@ class BaseHeader(str):
the header name and the ': ' separator. the header name and the ': ' separator.
""" """
# At some point we need to put fws here iif it was in the source. # At some point we need to put fws here if it was in the source.
header = parser.Header([ header = parser.Header([
parser.HeaderLabel([ parser.HeaderLabel([
parser.ValueTerminal(self.name, 'header-name'), parser.ValueTerminal(self.name, 'header-name'),
......
...@@ -261,7 +261,7 @@ _code_type = type(_write_atomic.__code__) ...@@ -261,7 +261,7 @@ _code_type = type(_write_atomic.__code__)
# Python 3.7a2 3391 (update GET_AITER #31709) # Python 3.7a2 3391 (update GET_AITER #31709)
# Python 3.7a4 3392 (PEP 552: Deterministic pycs #31650) # Python 3.7a4 3392 (PEP 552: Deterministic pycs #31650)
# Python 3.7b1 3393 (remove STORE_ANNOTATION opcode #32550) # Python 3.7b1 3393 (remove STORE_ANNOTATION opcode #32550)
# Python 3.7b5 3394 (restored docstring as the firts stmt in the body; # Python 3.7b5 3394 (restored docstring as the first stmt in the body;
# this might affected the first line number #32911) # this might affected the first line number #32911)
# Python 3.8a1 3400 (move frame block handling to compiler #17611) # Python 3.8a1 3400 (move frame block handling to compiler #17611)
# Python 3.8a1 3401 (add END_ASYNC_FOR #33041) # Python 3.8a1 3401 (add END_ASYNC_FOR #33041)
......
...@@ -2978,7 +2978,7 @@ def fd_count(): ...@@ -2978,7 +2978,7 @@ def fd_count():
if sys.platform.startswith(('linux', 'freebsd')): if sys.platform.startswith(('linux', 'freebsd')):
try: try:
names = os.listdir("/proc/self/fd") names = os.listdir("/proc/self/fd")
# Substract one because listdir() opens internally a file # Subtract one because listdir() internally opens a file
# descriptor to list the content of the /proc/self/fd/ directory. # descriptor to list the content of the /proc/self/fd/ directory.
return len(names) - 1 return len(names) - 1
except FileNotFoundError: except FileNotFoundError:
......
...@@ -3043,11 +3043,11 @@ class TestMakeDataclass(unittest.TestCase): ...@@ -3043,11 +3043,11 @@ class TestMakeDataclass(unittest.TestCase):
def test_non_identifier_field_names(self): def test_non_identifier_field_names(self):
for field in ['()', 'x,y', '*', '2@3', '', 'little johnny tables']: for field in ['()', 'x,y', '*', '2@3', '', 'little johnny tables']:
with self.subTest(field=field): with self.subTest(field=field):
with self.assertRaisesRegex(TypeError, 'must be valid identifers'): with self.assertRaisesRegex(TypeError, 'must be valid identifiers'):
make_dataclass('C', ['a', field]) make_dataclass('C', ['a', field])
with self.assertRaisesRegex(TypeError, 'must be valid identifers'): with self.assertRaisesRegex(TypeError, 'must be valid identifiers'):
make_dataclass('C', [field]) make_dataclass('C', [field])
with self.assertRaisesRegex(TypeError, 'must be valid identifers'): with self.assertRaisesRegex(TypeError, 'must be valid identifiers'):
make_dataclass('C', [field, 'a']) make_dataclass('C', [field, 'a'])
def test_underscore_field_names(self): def test_underscore_field_names(self):
......
...@@ -22,7 +22,7 @@ class EINTRTests(unittest.TestCase): ...@@ -22,7 +22,7 @@ class EINTRTests(unittest.TestCase):
print() print()
print("--- run eintr_tester.py ---", flush=True) print("--- run eintr_tester.py ---", flush=True)
# In verbose mode, the child process inherit stdout and stdout, # In verbose mode, the child process inherit stdout and stdout,
# to see output in realtime and reduce the risk of loosing output. # to see output in realtime and reduce the risk of losing output.
args = [sys.executable, "-E", "-X", "faulthandler", *args] args = [sys.executable, "-E", "-X", "faulthandler", *args]
proc = subprocess.run(args) proc = subprocess.run(args)
print(f"--- eintr_tester.py completed: " print(f"--- eintr_tester.py completed: "
......
...@@ -1161,7 +1161,7 @@ non-important content ...@@ -1161,7 +1161,7 @@ non-important content
# These next lines contains tabs. Backslash escapes don't # These next lines contains tabs. Backslash escapes don't
# work in f-strings. # work in f-strings.
# patchcheck doens't like these tabs. So the only way to test # patchcheck doesn't like these tabs. So the only way to test
# this will be to dynamically created and exec the f-strings. But # this will be to dynamically created and exec the f-strings. But
# that's such a hassle I'll save it for another day. For now, convert # that's such a hassle I'll save it for another day. For now, convert
# the tabs to spaces just to shut up patchcheck. # the tabs to spaces just to shut up patchcheck.
......
...@@ -32,7 +32,7 @@ class BasicTests(fixtures.DistInfoPkg, unittest.TestCase): ...@@ -32,7 +32,7 @@ class BasicTests(fixtures.DistInfoPkg, unittest.TestCase):
class ImportTests(fixtures.DistInfoPkg, unittest.TestCase): class ImportTests(fixtures.DistInfoPkg, unittest.TestCase):
def test_import_nonexistent_module(self): def test_import_nonexistent_module(self):
# Ensure that the MetadataPathFinder does not crash an import of a # Ensure that the MetadataPathFinder does not crash an import of a
# non-existant module. # nonexistent module.
with self.assertRaises(ImportError): with self.assertRaises(ImportError):
importlib.import_module('does_not_exist') importlib.import_module('does_not_exist')
......
...@@ -1875,7 +1875,7 @@ class IsCloseTests(unittest.TestCase): ...@@ -1875,7 +1875,7 @@ class IsCloseTests(unittest.TestCase):
def testPerm(self): def testPerm(self):
perm = math.perm perm = math.perm
factorial = math.factorial factorial = math.factorial
# Test if factorial defintion is satisfied # Test if factorial definition is satisfied
for n in range(100): for n in range(100):
for k in range(n + 1): for k in range(n + 1):
self.assertEqual(perm(n, k), self.assertEqual(perm(n, k),
...@@ -1939,7 +1939,7 @@ class IsCloseTests(unittest.TestCase): ...@@ -1939,7 +1939,7 @@ class IsCloseTests(unittest.TestCase):
def testComb(self): def testComb(self):
comb = math.comb comb = math.comb
factorial = math.factorial factorial = math.factorial
# Test if factorial defintion is satisfied # Test if factorial definition is satisfied
for n in range(100): for n in range(100):
for k in range(n + 1): for k in range(n + 1):
self.assertEqual(comb(n, k), factorial(n) self.assertEqual(comb(n, k), factorial(n)
......
...@@ -228,7 +228,7 @@ class TestBasicOps: ...@@ -228,7 +228,7 @@ class TestBasicOps:
choices([], cum_weights=[], k=5) choices([], cum_weights=[], k=5)
def test_choices_subnormal(self): def test_choices_subnormal(self):
# Subnormal weights would occassionally trigger an IndexError # Subnormal weights would occasionally trigger an IndexError
# in choices() when the value returned by random() was large # in choices() when the value returned by random() was large
# enough to make `random() * total` round up to the total. # enough to make `random() * total` round up to the total.
# See https://bugs.python.org/msg275594 for more detail. # See https://bugs.python.org/msg275594 for more detail.
......
...@@ -2005,7 +2005,7 @@ Adds validation of ucrtbase[d].dll version with warning for old versions. ...@@ -2005,7 +2005,7 @@ Adds validation of ucrtbase[d].dll version with warning for old versions.
.. nonce: 102DA- .. nonce: 102DA-
.. section: Build .. section: Build
Avoid error about nonexistant fileblocks.o file by using a lower-level check Avoid error about nonexistent fileblocks.o file by using a lower-level check
for st_blocks in struct stat. for st_blocks in struct stat.
.. ..
......
...@@ -3694,7 +3694,7 @@ Adds validation of ucrtbase[d].dll version with warning for old versions. ...@@ -3694,7 +3694,7 @@ Adds validation of ucrtbase[d].dll version with warning for old versions.
.. nonce: 102DA- .. nonce: 102DA-
.. section: Build .. section: Build
Avoid error about nonexistant fileblocks.o file by using a lower-level check Avoid error about nonexistent fileblocks.o file by using a lower-level check
for st_blocks in struct stat. for st_blocks in struct stat.
.. ..
......
...@@ -877,7 +877,7 @@ The affected events are '<<force-open-completions>>', '<<expand-word>>', ...@@ -877,7 +877,7 @@ The affected events are '<<force-open-completions>>', '<<expand-word>>',
'<<run-module>>', '<<check-module>>', and '<<zoom-height>>'. Any (global) '<<run-module>>', '<<check-module>>', and '<<zoom-height>>'. Any (global)
customizations made before 3.6.3 will not affect their keyset-specific customizations made before 3.6.3 will not affect their keyset-specific
customization after 3.6.3. and vice versa. customization after 3.6.3. and vice versa.
Inital patch by Charles Wohlganger. Initial patch by Charles Wohlganger.
.. ..
......
...@@ -1358,7 +1358,7 @@ Improved syntax error messages for unbalanced parentheses. ...@@ -1358,7 +1358,7 @@ Improved syntax error messages for unbalanced parentheses.
.. section: Core and Builtins .. section: Core and Builtins
The list constructor will pre-size and not over-allocate when the input The list constructor will pre-size and not over-allocate when the input
lenght is known. length is known.
.. ..
......
Many ``PyRun_XXX()`` functions like :c:func:`PyRun_String` were no longer Many ``PyRun_XXX()`` functions like :c:func:`PyRun_String` were no longer
exported in ``libpython38.dll`` by mistake. Export them again to fix the ABI exported in ``libpython38.dll`` by mistake. Export them again to fix the ABI
compatibiliy. compatibility.
...@@ -2119,7 +2119,7 @@ save_long(PicklerObject *self, PyObject *obj) ...@@ -2119,7 +2119,7 @@ save_long(PicklerObject *self, PyObject *obj)
/* How many bytes do we need? There are nbits >> 3 full /* How many bytes do we need? There are nbits >> 3 full
* bytes of data, and nbits & 7 leftover bits. If there * bytes of data, and nbits & 7 leftover bits. If there
* are any leftover bits, then we clearly need another * are any leftover bits, then we clearly need another
* byte. Wnat's not so obvious is that we *probably* * byte. What's not so obvious is that we *probably*
* need another byte even if there aren't any leftovers: * need another byte even if there aren't any leftovers:
* the most-significant bit of the most-significant byte * the most-significant bit of the most-significant byte
* acts like a sign bit, and it's usually got a sense * acts like a sign bit, and it's usually got a sense
......
...@@ -210,7 +210,7 @@ static int fuzz_sre_compile(const char* data, size_t size) { ...@@ -210,7 +210,7 @@ static int fuzz_sre_compile(const char* data, size_t size) {
/* Some random patterns used to test re.match. /* Some random patterns used to test re.match.
Be careful not to add catostraphically slow regexes here, we want to Be careful not to add catostraphically slow regexes here, we want to
excercise the matching code without causing timeouts.*/ exercise the matching code without causing timeouts.*/
static const char* regex_patterns[] = { static const char* regex_patterns[] = {
".", "^", "abc", "abc|def", "^xxx$", "\\b", "()", "[a-zA-Z0-9]", ".", "^", "abc", "abc|def", "^xxx$", "\\b", "()", "[a-zA-Z0-9]",
"abc+", "[^A-Z]", "[x]", "(?=)", "a{z}", "a+b", "a*?", "a??", "a+?", "abc+", "[^A-Z]", "[x]", "(?=)", "a{z}", "a+b", "a*?", "a??", "a+?",
......
...@@ -300,7 +300,7 @@ PyStatus ...@@ -300,7 +300,7 @@ PyStatus
PyWideStringList_Append(PyWideStringList *list, const wchar_t *item) PyWideStringList_Append(PyWideStringList *list, const wchar_t *item)
{ {
if (list->length == PY_SSIZE_T_MAX) { if (list->length == PY_SSIZE_T_MAX) {
/* lenght+1 would overflow */ /* length+1 would overflow */
return _PyStatus_NO_MEMORY(); return _PyStatus_NO_MEMORY();
} }
......
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