mirror of
https://github.com/python/cpython.git
synced 2025-11-01 14:11:41 +00:00
Allow multiple context managers in one with statement, as proposed
in http://codereview.appspot.com/53094 and accepted by Guido. The construct is transformed into multiple With AST nodes so that there should be no problems with the semantics.
This commit is contained in:
parent
04516611e7
commit
944f684ce6
11 changed files with 216 additions and 71 deletions
|
|
@ -965,18 +965,22 @@ def com_try_except_finally(self, nodelist):
|
|||
return try_except
|
||||
|
||||
def com_with(self, nodelist):
|
||||
# with_stmt: 'with' expr [with_var] ':' suite
|
||||
expr = self.com_node(nodelist[1])
|
||||
# with_stmt: 'with' with_item (',' with_item)* ':' suite
|
||||
body = self.com_node(nodelist[-1])
|
||||
if nodelist[2][0] == token.COLON:
|
||||
var = None
|
||||
else:
|
||||
var = self.com_assign(nodelist[2][2], OP_ASSIGN)
|
||||
return With(expr, var, body, lineno=nodelist[0][2])
|
||||
for i in range(len(nodelist) - 3, 0, -2):
|
||||
ret = self.com_with_item(nodelist[i], body, nodelist[0][2])
|
||||
if i == 1:
|
||||
return ret
|
||||
body = ret
|
||||
|
||||
def com_with_var(self, nodelist):
|
||||
# with_var: 'as' expr
|
||||
return self.com_node(nodelist[1])
|
||||
def com_with_item(self, nodelist, body, lineno):
|
||||
# with_item: test ['as' expr]
|
||||
if len(nodelist) == 4:
|
||||
var = self.com_assign(nodelist[3], OP_ASSIGN)
|
||||
else:
|
||||
var = None
|
||||
expr = self.com_node(nodelist[1])
|
||||
return With(expr, var, body, lineno=lineno)
|
||||
|
||||
def com_augassign_op(self, node):
|
||||
assert node[0] == symbol.augassign
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue