+ BlockAssignmentMap::iterator j = parent_assignments.find(i->first);
+ if(j==parent_assignments.end())
+ parent_assignments.insert(*i);
+ else if(i->second.self_referencing || i->second.conditional)
+ {
+ j->second.nodes.insert(j->second.nodes.end(), i->second.nodes.begin(), i->second.nodes.end());
+ j->second.conditional |= i->second.conditional;
+ j->second.self_referencing |= i->second.self_referencing;
+ }
+ else
+ j->second = i->second;
+ }
+ assignments.pop_back();
+}
+
+void ProgramCompiler::UnusedVariableLocator::visit(Conditional &cond)
+{
+ cond.condition->visit(*this);
+ assignments.push_back(BlockAssignmentMap());
+ cond.body.visit(*this);
+
+ BlockAssignmentMap if_assignments;
+ swap(assignments.back(), if_assignments);
+ cond.else_body.visit(*this);