@Override public PType caseACharacterPattern(ACharacterPattern pattern) throws AnalysisException { return AstFactory.newACharBasicType(pattern.getLocation()); }
/** * Returns a deep clone of this {@link ACharacterPattern} node. * @return a deep clone of this {@link ACharacterPattern} node */ public ACharacterPattern clone() { return new ACharacterPattern( _location, cloneList(_definitions), _resolved, cloneNode(_value) ); }
public static ACharacterPattern newACharacterPattern(LexCharacterToken token) { ACharacterPattern result = new ACharacterPattern(); initPattern(result, token.location); result.setValue(token); return result; }
/** * Called by the {@link ACharacterPattern} node from {@link ACharacterPattern#apply(IAnalysis)}. * @param node the calling {@link ACharacterPattern} node */ public void caseACharacterPattern(ACharacterPattern node) throws AnalysisException { _visitedNodes.add(node); inACharacterPattern(node); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getDefinitions()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } if(node.getValue() != null ) { node.getValue().apply(this); } outACharacterPattern(node); }
@Override public List<NameValuePairList> caseACharacterPattern( ACharacterPattern pattern, Newquestion question) throws AnalysisException { List<NameValuePairList> result = new Vector<NameValuePairList>(); try { if (question.expval.charValue(question.ctxt) != pattern.getValue().getValue()) { VdmRuntimeError.patternFail(4107, "Character pattern match failed", pattern.getLocation()); } } catch (ValueException e) { VdmRuntimeError.patternFail(e, pattern.getLocation()); } result.add(new NameValuePairList()); return result; }
@Override public SPatternIR caseACharacterPattern(ACharacterPattern node, IRInfo question) throws AnalysisException { char value = node.getValue().getValue(); ACharPatternIR charPatternCg = new ACharPatternIR(); charPatternCg.setValue(value); return charPatternCg; }
/** * Creates a new complete constructor {@code ACharacterPattern} 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 value_ the {@link ILexCharacterToken} node for the {@code value} child of this {@link ACharacterPattern} node */ public ACharacterPattern(ILexLocation location_, List<? extends PDefinition> definitions_, Boolean resolved_, ILexCharacterToken value_) { super(location_,definitions_,resolved_); this.setValue(value_); }
/** * Called by the {@link ACharacterPattern} node from {@link ACharacterPattern#apply(IAnalysis)}. * @param node the calling {@link ACharacterPattern} node */ public void caseACharacterPattern(ACharacterPattern node, Q question) throws AnalysisException { _visitedNodes.add(node); inACharacterPattern(node, question); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getDefinitions()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this, question); } } } if(node.getValue() != null ) { node.getValue().apply(this, question); } outACharacterPattern(node, question); }
public PExp caseACharacterPattern(ACharacterPattern node) throws AnalysisException { ACharLiteralExp ch = new ACharLiteralExp(); ch.setValue(node.getValue().clone()); addPossibleType(ch, node); return ch; }
/** * Called by the {@link ACharacterPattern} node from {@link ACharacterPattern#apply(IPOFAnalysis)}. * @param node the calling {@link ACharacterPattern} node */ public void caseACharacterPattern(ACharacterPattern node) throws AnalysisException { _visitedNodes.add(node); inACharacterPattern(node); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getDefinitions()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } if(node.getValue() != null ) { node.getValue().apply(this); } outACharacterPattern(node); }
/** * Creates a deep clone of this {@link ACharacterPattern} 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 ACharacterPattern} node */ public ACharacterPattern clone(Map<INode,INode> oldToNewMap) { ACharacterPattern node = new ACharacterPattern( _location, cloneList(_definitions, oldToNewMap), _resolved, cloneNode(_value, oldToNewMap) ); oldToNewMap.put(this, node); return node; }
/** * Called by the {@link ACharacterPattern} node from {@link ACharacterPattern#apply(IAnalysis)}. * @param node the calling {@link ACharacterPattern} node */ public A caseACharacterPattern(ACharacterPattern node) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node); mergeReturns(retVal,inACharacterPattern(node)); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getDefinitions()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this)); } } } if(node.getValue() != null ) { mergeReturns(retVal,node.getValue().apply(this)); } mergeReturns(retVal,outACharacterPattern(node)); return retVal; }
/** * Called by the {@link ACharacterPattern} node from {@link ACharacterPattern#apply(IAnalysis)}. * @param node the calling {@link ACharacterPattern} node */ public A caseACharacterPattern(ACharacterPattern node, Q question) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node, question); mergeReturns(retVal,inACharacterPattern(node, question)); { List<PDefinition> copy = new ArrayList<PDefinition>(node.getDefinitions()); for( PDefinition e : copy) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this, question)); } } } if(node.getValue() != null ) { mergeReturns(retVal,node.getValue().apply(this, question)); } mergeReturns(retVal,outACharacterPattern(node, question)); return retVal; }