mirror of
https://github.com/python/cpython.git
synced 2024-11-27 11:55:13 +08:00
Merge 3.5 (Issue #24669)
This commit is contained in:
commit
8d603f1796
@ -798,7 +798,7 @@ def findsource(object):
|
||||
if not hasattr(object, 'co_firstlineno'):
|
||||
raise OSError('could not find function definition')
|
||||
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:
|
||||
if pat.match(lines[lnum]): break
|
||||
lnum = lnum - 1
|
||||
|
@ -66,3 +66,6 @@ class FesteringGob(MalodorousPervert, ParrotDroppings):
|
||||
pass
|
||||
def contradiction(self):
|
||||
pass
|
||||
|
||||
async def lobbest(grenade):
|
||||
pass
|
||||
|
@ -336,6 +336,7 @@ class TestRetrievingSourceCode(GetSourceBase):
|
||||
def test_getfunctions(self):
|
||||
functions = inspect.getmembers(mod, inspect.isfunction)
|
||||
self.assertEqual(functions, [('eggs', mod.eggs),
|
||||
('lobbest', mod.lobbest),
|
||||
('spam', mod.spam)])
|
||||
|
||||
@unittest.skipIf(sys.flags.optimize >= 2,
|
||||
@ -393,6 +394,7 @@ class TestRetrievingSourceCode(GetSourceBase):
|
||||
def test_getsource(self):
|
||||
self.assertSourceEqual(git.abuse, 29, 39)
|
||||
self.assertSourceEqual(mod.StupidGit, 21, 50)
|
||||
self.assertSourceEqual(mod.lobbest, 70, 71)
|
||||
|
||||
def test_getsourcefile(self):
|
||||
self.assertEqual(normcase(inspect.getsourcefile(mod.spam)), modfile)
|
||||
|
@ -64,6 +64,8 @@ Library
|
||||
- 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.
|
||||
|
||||
- Issue #24669: Fix inspect.getsource() for 'async def' functions.
|
||||
Patch by Kai Groner.
|
||||
|
||||
What's New in Python 3.5.0 beta 3?
|
||||
==================================
|
||||
|
Loading…
Reference in New Issue
Block a user