Commit be3e46f6 authored by Marius Wachtler's avatar Marius Wachtler

Clear the exc_info when resuming a generator

parent d55d8e07
...@@ -372,6 +372,7 @@ private: ...@@ -372,6 +372,7 @@ private:
return UNKNOWN; return UNKNOWN;
case AST_LangPrimitive::NONE: case AST_LangPrimitive::NONE:
case AST_LangPrimitive::SET_EXC_INFO: case AST_LangPrimitive::SET_EXC_INFO:
case AST_LangPrimitive::UNCACHE_EXC_INFO:
return NONE; return NONE;
case AST_LangPrimitive::NONZERO: case AST_LangPrimitive::NONZERO:
return BOOL; return BOOL;
......
...@@ -562,6 +562,10 @@ Value ASTInterpreter::visit_langPrimitive(AST_LangPrimitive* node) { ...@@ -562,6 +562,10 @@ Value ASTInterpreter::visit_langPrimitive(AST_LangPrimitive* node) {
getFrameInfo()->exc = ExcInfo(type.o, value.o, traceback.o); getFrameInfo()->exc = ExcInfo(type.o, value.o, traceback.o);
v = None; v = None;
} else if (node->opcode == AST_LangPrimitive::UNCACHE_EXC_INFO) {
assert(node->args.empty());
getFrameInfo()->exc = ExcInfo(NULL, NULL, NULL);
v = None;
} else } else
RELEASE_ASSERT(0, "not implemented"); RELEASE_ASSERT(0, "not implemented");
return v; return v;
......
...@@ -638,6 +638,22 @@ private: ...@@ -638,6 +638,22 @@ private:
return getNone(); return getNone();
} }
case AST_LangPrimitive::UNCACHE_EXC_INFO: {
assert(node->args.empty());
auto* builder = emitter.getBuilder();
llvm::Value* frame_info = irstate->getFrameInfoVar();
llvm::Value* exc_info = builder->CreateConstInBoundsGEP2_32(frame_info, 0, 0);
assert(exc_info->getType() == g.llvm_excinfo_type->getPointerTo());
llvm::Constant* v = embedConstantPtr(0, g.llvm_value_type_ptr);
builder->CreateStore(v, builder->CreateConstInBoundsGEP2_32(exc_info, 0, 0));
builder->CreateStore(v, builder->CreateConstInBoundsGEP2_32(exc_info, 0, 1));
builder->CreateStore(v, builder->CreateConstInBoundsGEP2_32(exc_info, 0, 2));
return getNone();
}
default: default:
RELEASE_ASSERT(0, "%d", node->opcode); RELEASE_ASSERT(0, "%d", node->opcode);
} }
......
...@@ -1454,6 +1454,9 @@ bool PrintVisitor::visit_langprimitive(AST_LangPrimitive* node) { ...@@ -1454,6 +1454,9 @@ bool PrintVisitor::visit_langprimitive(AST_LangPrimitive* node) {
case AST_LangPrimitive::SET_EXC_INFO: case AST_LangPrimitive::SET_EXC_INFO:
printf("SET_EXC_INFO"); printf("SET_EXC_INFO");
break; break;
case AST_LangPrimitive::UNCACHE_EXC_INFO:
printf("UNCACHE_EXC_INFO");
break;
default: default:
RELEASE_ASSERT(0, "%d", node->opcode); RELEASE_ASSERT(0, "%d", node->opcode);
} }
......
...@@ -997,6 +997,7 @@ public: ...@@ -997,6 +997,7 @@ public:
NONE, NONE,
NONZERO, NONZERO,
SET_EXC_INFO, SET_EXC_INFO,
UNCACHE_EXC_INFO,
} opcode; } opcode;
std::vector<AST_expr*> args; std::vector<AST_expr*> args;
......
...@@ -1006,7 +1006,13 @@ private: ...@@ -1006,7 +1006,13 @@ private:
rtn->lineno = node->lineno; rtn->lineno = node->lineno;
rtn->col_offset = node->col_offset; rtn->col_offset = node->col_offset;
rtn->value = remapExpr(node->value); rtn->value = remapExpr(node->value);
return rtn;
InternedString node_name(nodeName(rtn));
pushAssign(node_name, rtn);
push_back(makeExpr(new AST_LangPrimitive(AST_LangPrimitive::UNCACHE_EXC_INFO)));
return makeName(node_name, AST_TYPE::Load, node->lineno);
} }
AST_expr* remapExpr(AST_expr* node, bool wrap_with_assign = true) { AST_expr* remapExpr(AST_expr* node, bool wrap_with_assign = true) {
......
# expected: fail
# - wip
# Generators participate in the notional Python stack just like normal function calls do, # Generators participate in the notional Python stack just like normal function calls do,
# even if we implement them using separate C stacks. # even if we implement them using separate C stacks.
# #
...@@ -8,6 +5,7 @@ ...@@ -8,6 +5,7 @@
# get inherited when we go into a generator # get inherited when we go into a generator
# exc_info gets passed into generators (at both begin and send()) and cleared like normal on the way out: # exc_info gets passed into generators (at both begin and send()) and cleared like normal on the way out:
import sys
def f12(): def f12():
print print
print "f12" print "f12"
...@@ -25,6 +23,7 @@ def f12(): ...@@ -25,6 +23,7 @@ def f12():
print "after KeyError:", sys.exc_info()[0] print "after KeyError:", sys.exc_info()[0]
yield 2 yield 2
print list(g())
try: try:
raise AttributeError() raise AttributeError()
except: except:
...@@ -32,6 +31,7 @@ def f12(): ...@@ -32,6 +31,7 @@ def f12():
i = g() i = g()
i.next() i.next()
print list(g())
try: try:
1/0 1/0
except: except:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment