@Override public PType defaultPImport(PImport node, TypeCheckInfo question) throws AnalysisException { return node.apply(tcImports, question); }
public List<PDefinition> getDefinitions(PImport imp, AModuleModules from) { try { return imp.apply(af.getImportDefinitionFinder(), from); } catch (AnalysisException e) { return null; } }
public void typeCheck(AFromModuleImports ifm, ModuleEnvironment env) throws AnalysisException { TypeCheckVisitor tc = new TypeCheckVisitor(); TypeCheckInfo question = new TypeCheckInfo(af, env, null, null); for (List<PImport> ofType : ifm.getSignatures()) { for (PImport imp : ofType) { imp.apply(tc, question); } } }
/** * Called by the {@link AFromModuleImports} node from {@link AFromModuleImports#apply(IAnalysis)}. * @param node the calling {@link AFromModuleImports} node */ public void caseAFromModuleImports(AFromModuleImports node) throws AnalysisException { _visitedNodes.add(node); inAFromModuleImports(node); if(node.getName() != null ) { node.getName().apply(this); } { List<List<PImport>> copy = new ArrayList<List<PImport>>(node.getSignatures()); for( List<PImport> list : copy) { for( PImport e : list) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } } outAFromModuleImports(node); }
/** * Called by the {@link AFromModuleImports} node from {@link AFromModuleImports#apply(IAnalysis)}. * @param node the calling {@link AFromModuleImports} node */ public void caseAFromModuleImports(AFromModuleImports node, Q question) throws AnalysisException { _visitedNodes.add(node); inAFromModuleImports(node, question); if(node.getName() != null ) { node.getName().apply(this, question); } { List<List<PImport>> copy = new ArrayList<List<PImport>>(node.getSignatures()); for( List<PImport> list : copy) { for( PImport e : list) { if(!_visitedNodes.contains(e)) { e.apply(this, question); } } } } outAFromModuleImports(node, question); }
/** * Called by the {@link AFromModuleImports} node from {@link AFromModuleImports#apply(IPOFAnalysis)}. * @param node the calling {@link AFromModuleImports} node */ public void caseAFromModuleImports(AFromModuleImports node) throws AnalysisException { _visitedNodes.add(node); inAFromModuleImports(node); if(node.getName() != null ) { node.getName().apply(this); } { List<List<PImport>> copy = new ArrayList<List<PImport>>(node.getSignatures()); for( List<PImport> list : copy) { for( PImport e : list) { if(!_visitedNodes.contains(e)) { e.apply(this); } } } } outAFromModuleImports(node); }
SImportIR impCg = imp.apply(question.getImportVisitor(), question);
/** * Called by the {@link AFromModuleImports} node from {@link AFromModuleImports#apply(IAnalysis)}. * @param node the calling {@link AFromModuleImports} node */ public A caseAFromModuleImports(AFromModuleImports node, Q question) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node, question); mergeReturns(retVal,inAFromModuleImports(node, question)); if(node.getName() != null ) { mergeReturns(retVal,node.getName().apply(this, question)); } { List<List<PImport>> copy = new ArrayList<List<PImport>>(node.getSignatures()); for( List<PImport> list : copy) { for( PImport e : list) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this, question)); } } } } mergeReturns(retVal,outAFromModuleImports(node, question)); return retVal; }
/** * Called by the {@link AFromModuleImports} node from {@link AFromModuleImports#apply(IAnalysis)}. * @param node the calling {@link AFromModuleImports} node */ public A caseAFromModuleImports(AFromModuleImports node) throws AnalysisException { _visitedNodes.add(node); A retVal = createNewReturnValue(node); mergeReturns(retVal,inAFromModuleImports(node)); if(node.getName() != null ) { mergeReturns(retVal,node.getName().apply(this)); } { List<List<PImport>> copy = new ArrayList<List<PImport>>(node.getSignatures()); for( List<PImport> list : copy) { for( PImport e : list) { if(!_visitedNodes.contains(e)) { mergeReturns(retVal,e.apply(this)); } } } } mergeReturns(retVal,outAFromModuleImports(node)); return retVal; }