/** * Returns a deep clone of this {@link ABracketedExpressionTraceCoreDefinition} node. * @return a deep clone of this {@link ABracketedExpressionTraceCoreDefinition} node */ public ABracketedExpressionTraceCoreDefinition clone() { return new ABracketedExpressionTraceCoreDefinition( _location, cloneList(_terms) ); }
/** * Creates a new complete constructor {@code ABracketedExpressionTraceCoreDefinition} node with the given nodes as children. * @deprecated This method should not be used, use AstFactory instead. * The basic child nodes are removed from their previous parents. * @param terms_ the {@link NodeList} node for the {@code terms} child of this {@link ABracketedExpressionTraceCoreDefinition} node */ public ABracketedExpressionTraceCoreDefinition(ILexLocation location_, List<? extends ATraceDefinitionTerm> terms_) { super(location_); this.setTerms(terms_); }
/** * Essentially this.toString().equals(o.toString()). **/ @Override public boolean equals(Object o) { if (o != null && o instanceof ABracketedExpressionTraceCoreDefinition) { return toString().equals(o.toString()); } return false; }
@Override public TraceNode caseABracketedExpressionTraceCoreDefinition( ABracketedExpressionTraceCoreDefinition core, Context ctxt) throws AnalysisException { // return ABracketedExpressionTraceCoreDefinitionAssitantInterpreter.expand(core, ctxt); SequenceTraceNode node = new SequenceTraceNode(); for (ATraceDefinitionTerm term : core.getTerms()) { // node.nodes.add(ATraceDefinitionTermAssistantInterpreter.expand(term, ctxt)); node.nodes.add(term.apply(THIS, ctxt)); } return node; }
public static ABracketedExpressionTraceCoreDefinition newABracketedExpressionTraceCoreDefinition( ILexLocation location, List<ATraceDefinitionTerm> list) { return new ABracketedExpressionTraceCoreDefinition(location, list); }
@Override public PType caseABracketedExpressionTraceCoreDefinition( ABracketedExpressionTraceCoreDefinition node, TypeCheckInfo question) throws AnalysisException { for (ATraceDefinitionTerm term : node.getTerms()) { for (PTraceDefinition def : term.getList()) { def.apply(THIS, question); } } return null; }
/** * Called by the {@link ABracketedExpressionTraceCoreDefinition} node from {@link ABracketedExpressionTraceCoreDefinition#apply(IAnalysis)}. * @param node the calling {@link ABracketedExpressionTraceCoreDefinition} node */ public void caseABracketedExpressionTraceCoreDefinition(ABracketedExpressionTraceCoreDefinition node) throws AnalysisException { _visitedNodes.add(node); inABracketedExpressionTraceCoreDefinition(node); { List<ATraceDefinitionTerm> copy = new ArrayList<ATraceDefinitionTerm>(node.getTerms()); for( ATraceDefinitionTerm e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } outABracketedExpressionTraceCoreDefinition(node); }
/** * Creates a deep clone of this {@link ABracketedExpressionTraceCoreDefinition} 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 ABracketedExpressionTraceCoreDefinition} node */ public ABracketedExpressionTraceCoreDefinition clone(Map<INode,INode> oldToNewMap) { ABracketedExpressionTraceCoreDefinition node = new ABracketedExpressionTraceCoreDefinition( _location, cloneList(_terms, oldToNewMap) ); oldToNewMap.put(this, node); return node; }
/** * Called by the {@link ABracketedExpressionTraceCoreDefinition} node from {@link ABracketedExpressionTraceCoreDefinition#apply(IPOFAnalysis)}. * @param node the calling {@link ABracketedExpressionTraceCoreDefinition} node */ public void caseABracketedExpressionTraceCoreDefinition(ABracketedExpressionTraceCoreDefinition node) throws AnalysisException { _visitedNodes.add(node); inABracketedExpressionTraceCoreDefinition(node); { List<ATraceDefinitionTerm> copy = new ArrayList<ATraceDefinitionTerm>(node.getTerms()); for( ATraceDefinitionTerm e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } outABracketedExpressionTraceCoreDefinition(node); }
/** * Called by the {@link ABracketedExpressionTraceCoreDefinition} node from {@link ABracketedExpressionTraceCoreDefinition#apply(IAnalysis)}. * @param node the calling {@link ABracketedExpressionTraceCoreDefinition} node */ public void caseABracketedExpressionTraceCoreDefinition(ABracketedExpressionTraceCoreDefinition node, Q question) throws AnalysisException { _visitedNodes.add(node); inABracketedExpressionTraceCoreDefinition(node, question); { List<ATraceDefinitionTerm> copy = new ArrayList<ATraceDefinitionTerm>(node.getTerms()); for( ATraceDefinitionTerm e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this, question); } } } outABracketedExpressionTraceCoreDefinition(node, question); }
@Override public STraceCoreDeclIR caseABracketedExpressionTraceCoreDefinition( ABracketedExpressionTraceCoreDefinition node, IRInfo question) throws AnalysisException { ABracketedExpTraceCoreDeclIR bracketTraceCoreDecl = new ABracketedExpTraceCoreDeclIR(); for (ATraceDefinitionTerm term : node.getTerms()) { STermIR termCg = term.apply(question.getTermVisitor(), question); if (termCg instanceof ATraceDeclTermIR) { bracketTraceCoreDecl.getTerms().add((ATraceDeclTermIR) termCg); } else { log.error("Expected term to be of type ATraceDeclTermIR. Got: " + termCg); } } return bracketTraceCoreDecl; }
/** * Called by the {@link ABracketedExpressionTraceCoreDefinition} node from {@link ABracketedExpressionTraceCoreDefinition#apply(IAnalysis)}. * @param node the calling {@link ABracketedExpressionTraceCoreDefinition} node */ public A caseABracketedExpressionTraceCoreDefinition(ABracketedExpressionTraceCoreDefinition node, Q question) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node, question); mergeReturns(retVal,inABracketedExpressionTraceCoreDefinition(node, question)); { List<ATraceDefinitionTerm> copy = new ArrayList<ATraceDefinitionTerm>(node.getTerms()); for( ATraceDefinitionTerm e : copy) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this, question)); } } } mergeReturns(retVal,outABracketedExpressionTraceCoreDefinition(node, question)); return retVal; }
/** * Called by the {@link ABracketedExpressionTraceCoreDefinition} node from {@link ABracketedExpressionTraceCoreDefinition#apply(IAnalysis)}. * @param node the calling {@link ABracketedExpressionTraceCoreDefinition} node */ public A caseABracketedExpressionTraceCoreDefinition(ABracketedExpressionTraceCoreDefinition node) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node); mergeReturns(retVal,inABracketedExpressionTraceCoreDefinition(node)); { List<ATraceDefinitionTerm> copy = new ArrayList<ATraceDefinitionTerm>(node.getTerms()); for( ATraceDefinitionTerm e : copy) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this)); } } } mergeReturns(retVal,outABracketedExpressionTraceCoreDefinition(node)); return retVal; }