Merge 3.5 (Issue #24669)

This commit is contained in:
Yury Selivanov 2015-07-21 19:04:22 +03:00
commit 8d603f1796
4 changed files with 8 additions and 1 deletions

View File

@ -798,7 +798,7 @@ def findsource(object):
if not hasattr(object, 'co_firstlineno'): if not hasattr(object, 'co_firstlineno'):
raise OSError('could not find function definition') raise OSError('could not find function definition')
lnum = object.co_firstlineno - 1 lnum = object.co_firstlineno - 1
pat = re.compile(r'^(\s*def\s)|(.*(?<!\w)lambda(:|\s))|^(\s*@)') pat = re.compile(r'^(\s*def\s)|(\s*async\s+def\s)|(.*(?<!\w)lambda(:|\s))|^(\s*@)')
while lnum > 0: while lnum > 0:
if pat.match(lines[lnum]): break if pat.match(lines[lnum]): break
lnum = lnum - 1 lnum = lnum - 1

View File

@ -66,3 +66,6 @@ class FesteringGob(MalodorousPervert, ParrotDroppings):
pass pass
def contradiction(self): def contradiction(self):
pass pass
async def lobbest(grenade):
pass

View File

@ -336,6 +336,7 @@ class TestRetrievingSourceCode(GetSourceBase):
def test_getfunctions(self): def test_getfunctions(self):
functions = inspect.getmembers(mod, inspect.isfunction) functions = inspect.getmembers(mod, inspect.isfunction)
self.assertEqual(functions, [('eggs', mod.eggs), self.assertEqual(functions, [('eggs', mod.eggs),
('lobbest', mod.lobbest),
('spam', mod.spam)]) ('spam', mod.spam)])
@unittest.skipIf(sys.flags.optimize >= 2, @unittest.skipIf(sys.flags.optimize >= 2,
@ -393,6 +394,7 @@ class TestRetrievingSourceCode(GetSourceBase):
def test_getsource(self): def test_getsource(self):
self.assertSourceEqual(git.abuse, 29, 39) self.assertSourceEqual(git.abuse, 29, 39)
self.assertSourceEqual(mod.StupidGit, 21, 50) self.assertSourceEqual(mod.StupidGit, 21, 50)
self.assertSourceEqual(mod.lobbest, 70, 71)
def test_getsourcefile(self): def test_getsourcefile(self):
self.assertEqual(normcase(inspect.getsourcefile(mod.spam)), modfile) self.assertEqual(normcase(inspect.getsourcefile(mod.spam)), modfile)

View File

@ -64,6 +64,8 @@ Library
- Issue #6549: Remove hyphen from ttk.Style().element options. Only return result - Issue #6549: Remove hyphen from ttk.Style().element options. Only return result
from ttk.Style().configure if a result was generated or a query submitted. from ttk.Style().configure if a result was generated or a query submitted.
- Issue #24669: Fix inspect.getsource() for 'async def' functions.
Patch by Kai Groner.
What's New in Python 3.5.0 beta 3? What's New in Python 3.5.0 beta 3?
================================== ==================================