Issue #4050: inspect.findsource/getsource now raise an IOError if the 'source'

file is a binary.  Patch by Brodie Rao, test by Daniel Diniz.
This commit is contained in:
R. David Murray 2009-05-13 17:14:11 +00:00
parent 525cffcd7e
commit 996ba02602
4 changed files with 15 additions and 1 deletions

View File

@ -523,7 +523,9 @@ def findsource(object):
or code object. The source code is returned as a list of all the lines or code object. The source code is returned as a list of all the lines
in the file and the line number indexes a line in that list. An IOError in the file and the line number indexes a line in that list. An IOError
is raised if the source code cannot be retrieved.""" is raised if the source code cannot be retrieved."""
file = getsourcefile(object) or getfile(object) file = getsourcefile(object)
if not file:
raise IOError('source code not available')
module = getmodule(object, file) module = getmodule(object, file)
if module: if module:
lines = linecache.getlines(file, module.__dict__) lines = linecache.getlines(file, module.__dict__)

View File

@ -9,6 +9,9 @@ from test.test_support import TESTFN, run_unittest
from test import inspect_fodder as mod from test import inspect_fodder as mod
from test import inspect_fodder2 as mod2 from test import inspect_fodder2 as mod2
# C module for test_findsource_binary
import time
# Functions tested in this suite: # Functions tested in this suite:
# ismodule, isclass, ismethod, isfunction, istraceback, isframe, iscode, # ismodule, isclass, ismethod, isfunction, istraceback, isframe, iscode,
# isbuiltin, isroutine, isgenerator, isgeneratorfunction, getmembers, # isbuiltin, isroutine, isgenerator, isgeneratorfunction, getmembers,
@ -329,6 +332,10 @@ class TestBuggyCases(GetSourceBase):
def test_method_in_dynamic_class(self): def test_method_in_dynamic_class(self):
self.assertSourceEqual(mod2.method_in_dynamic_class, 95, 97) self.assertSourceEqual(mod2.method_in_dynamic_class, 95, 97)
def test_findsource_binary(self):
self.assertRaises(IOError, inspect.getsource, time)
self.assertRaises(IOError, inspect.findsource, time)
# Helper for testing classify_class_attrs. # Helper for testing classify_class_attrs.
def attrs_wo_objs(cls): def attrs_wo_objs(cls):
return [t[:3] for t in inspect.classify_class_attrs(cls)] return [t[:3] for t in inspect.classify_class_attrs(cls)]

View File

@ -171,6 +171,7 @@ Raghuram Devarakonda
Toby Dickenson Toby Dickenson
Mark Dickinson Mark Dickinson
Jack Diederich Jack Diederich
Daniel Diniz
Yves Dionne Yves Dionne
Daniel Dittmar Daniel Dittmar
Jaromir Dolecek Jaromir Dolecek
@ -577,6 +578,7 @@ Eduardo P
Brian Quinlan Brian Quinlan
Anders Qvist Anders Qvist
Burton Radons Burton Radons
Brodie Rao
Antti Rasinen Antti Rasinen
Eric Raymond Eric Raymond
Edward K. Ream Edward K. Ream

View File

@ -293,6 +293,9 @@ Core and Builtins
Library Library
------- -------
- Issue #4050: inspect.findsource/getsource now raise an IOError if the 'source'
file is a binary. Patch by Brodie Rao, tests by Daniel Diniz.
- Issue #5977: distutils build_ext.get_outputs was not taking into account the - Issue #5977: distutils build_ext.get_outputs was not taking into account the
inplace option. Initial patch by kxroberto. inplace option. Initial patch by kxroberto.