Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 1432771

Browse files
committed
Merged revisions 74457 via svnmerge from
svn+ssh://[email protected]/python/trunk ........ r74457 | benjamin.peterson | 2009-08-15 08:16:38 -0500 (Sat, 15 Aug 2009) | 1 line #6707 fix a crash with dir() on an uninitialized module ........
1 parent 1fff008 commit 1432771

3 files changed

Lines changed: 8 additions & 3 deletions

File tree

Lib/test/test_module.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,7 @@ def test_uninitialized(self):
1111
# and __doc__ is None
1212
foo = ModuleType.__new__(ModuleType)
1313
self.assertTrue(foo.__dict__ is None)
14+
self.assertRaises(SystemError, dir, foo)
1415
try:
1516
s = foo.__name__
1617
self.fail("__name__ = %s" % repr(s))

Misc/NEWS

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,8 @@ What's New in Python 3.2 Alpha 1?
1212
Core and Builtins
1313
-----------------
1414

15+
- Issue #6707: dir() on an uninitialized module caused a crash.
16+
1517
- Issue #6540: Fixed crash for bytearray.translate() with invalid parameters.
1618

1719
- Issue #6573: set.union() stopped processing inputs if an instance of self

Objects/object.c

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1265,9 +1265,11 @@ _specialized_dir_module(PyObject *obj)
12651265
if (PyDict_Check(dict))
12661266
result = PyDict_Keys(dict);
12671267
else {
1268-
PyErr_Format(PyExc_TypeError,
1269-
"%.200s.__dict__ is not a dictionary",
1270-
PyModule_GetName(obj));
1268+
const char *name = PyModule_GetName(obj);
1269+
if (name)
1270+
PyErr_Format(PyExc_TypeError,
1271+
"%.200s.__dict__ is not a dictionary",
1272+
name);
12711273
}
12721274
}
12731275

0 commit comments

Comments
 (0)