@Override public PType caseALetDefBindingTraceDefinition( ALetDefBindingTraceDefinition node, TypeCheckInfo question) throws AnalysisException { return typeCheckLet(node, node.getLocalDefs(), node.getBody(), question); }
/** * Returns a deep clone of this {@link ALetDefBindingTraceDefinition} node. * @return a deep clone of this {@link ALetDefBindingTraceDefinition} node */ public ALetDefBindingTraceDefinition clone() { return new ALetDefBindingTraceDefinition( _location, cloneList(_localDefs), cloneNode(_body) ); }
@Override public TraceNode caseALetDefBindingTraceDefinition( ALetDefBindingTraceDefinition term, Context ctxt) throws AnalysisException { // return ALetDefBindingTraceDefinitionAssistantInterpreter.expand(term, ctxt); Context evalContext = new Context(af, term.getLocation(), "TRACE", ctxt); for (PDefinition d : term.getLocalDefs()) { evalContext.putList(af.createPDefinitionAssistant().getNamedValues(d, evalContext)); } TraceNode node = term.getBody().apply(THIS, evalContext); node.addVariables(new TraceVariableList(evalContext, term.getLocalDefs())); return node; }
public static ALetDefBindingTraceDefinition newALetDefBindingTraceDefinition( ILexLocation location, List<AValueDefinition> localDefs, PTraceDefinition body) { return new ALetDefBindingTraceDefinition(location, localDefs, body); }
/** * Called by the {@link ALetDefBindingTraceDefinition} node from {@link ALetDefBindingTraceDefinition#apply(IPOFAnalysis)}. * @param node the calling {@link ALetDefBindingTraceDefinition} node */ public void caseALetDefBindingTraceDefinition(ALetDefBindingTraceDefinition node) throws AnalysisException { _visitedNodes.add(node); inALetDefBindingTraceDefinition(node); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getLocalDefs()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } if(node.getBody() != null && !_visitedNodes.contains(node.getBody())) { node.getBody().apply(this); } outALetDefBindingTraceDefinition(node); }
/** * Creates a deep clone of this {@link ALetDefBindingTraceDefinition} node while putting all * old node-new node relations in the map {@code oldToNewMap}. * @param oldToNewMap the map filled with the old node-new node relation * @return a deep clone of this {@link ALetDefBindingTraceDefinition} node */ public ALetDefBindingTraceDefinition clone(Map<INode,INode> oldToNewMap) { ALetDefBindingTraceDefinition node = new ALetDefBindingTraceDefinition( _location, cloneList(_localDefs, oldToNewMap), cloneNode(_body, oldToNewMap) ); oldToNewMap.put(this, node); return node; }
/** * Called by the {@link ALetDefBindingTraceDefinition} node from {@link ALetDefBindingTraceDefinition#apply(IAnalysis)}. * @param node the calling {@link ALetDefBindingTraceDefinition} node */ public void caseALetDefBindingTraceDefinition(ALetDefBindingTraceDefinition node) throws AnalysisException { _visitedNodes.add(node); inALetDefBindingTraceDefinition(node); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getLocalDefs()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } if(node.getBody() != null && !_visitedNodes.contains(node.getBody())) { node.getBody().apply(this); } outALetDefBindingTraceDefinition(node); }
/** * Called by the {@link ALetDefBindingTraceDefinition} node from {@link ALetDefBindingTraceDefinition#apply(IAnalysis)}. * @param node the calling {@link ALetDefBindingTraceDefinition} node */ public void caseALetDefBindingTraceDefinition(ALetDefBindingTraceDefinition node, Q question) throws AnalysisException { _visitedNodes.add(node); inALetDefBindingTraceDefinition(node, question); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getLocalDefs()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this, question); } } } if(node.getBody() != null && !_visitedNodes.contains(node.getBody())) { node.getBody().apply(this, question); } outALetDefBindingTraceDefinition(node, question); }
/** * Called by the {@link ALetDefBindingTraceDefinition} node from {@link ALetDefBindingTraceDefinition#apply(IAnalysis)}. * @param node the calling {@link ALetDefBindingTraceDefinition} node */ public A caseALetDefBindingTraceDefinition(ALetDefBindingTraceDefinition node) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node); mergeReturns(retVal,inALetDefBindingTraceDefinition(node)); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getLocalDefs()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this)); } } } if(node.getBody() != null && !_visitedNodes.contains(node.getBody())) { mergeReturns(retVal,node.getBody().apply(this)); } mergeReturns(retVal,outALetDefBindingTraceDefinition(node)); return retVal; }
/** * Called by the {@link ALetDefBindingTraceDefinition} node from {@link ALetDefBindingTraceDefinition#apply(IAnalysis)}. * @param node the calling {@link ALetDefBindingTraceDefinition} node */ public A caseALetDefBindingTraceDefinition(ALetDefBindingTraceDefinition node, Q question) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node, question); mergeReturns(retVal,inALetDefBindingTraceDefinition(node, question)); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getLocalDefs()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this, question)); } } } if(node.getBody() != null && !_visitedNodes.contains(node.getBody())) { mergeReturns(retVal,node.getBody().apply(this, question)); } mergeReturns(retVal,outALetDefBindingTraceDefinition(node, question)); return retVal; }
@Override public STraceDeclIR caseALetDefBindingTraceDefinition( ALetDefBindingTraceDefinition node, IRInfo question) throws AnalysisException { PTraceDefinition body = node.getBody(); ALetDefBindingTraceDeclIR letDef = new ALetDefBindingTraceDeclIR(); question.getDeclAssistant().setFinalLocalDefs(node.getLocalDefs(), letDef.getLocalDefs(), question); STraceDeclIR bodyCg = body.apply(question.getTraceDeclVisitor(), question); letDef.setBody(bodyCg); return letDef; }