X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.scl.compiler%2Fsrc%2Forg%2Fsimantics%2Fscl%2Fcompiler%2Fcompilation%2FDeclarationClassification.java;h=ed21f04b2951c9f8bbd8e16ae75c3c7c114c3669;hb=HEAD;hp=6f82720c4675b805f997e1976695571be3ad6951;hpb=cb5fc8d606d8b322563e9345c441eecfa7f01753;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/compilation/DeclarationClassification.java b/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/compilation/DeclarationClassification.java index 6f82720c4..ed21f04b2 100644 --- a/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/compilation/DeclarationClassification.java +++ b/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/compilation/DeclarationClassification.java @@ -25,6 +25,7 @@ import org.simantics.scl.compiler.internal.parsing.declarations.DInstanceAst; import org.simantics.scl.compiler.internal.parsing.declarations.DMappingRelationAst; import org.simantics.scl.compiler.internal.parsing.declarations.DRelationAst; import org.simantics.scl.compiler.internal.parsing.declarations.DRuleAst; +import org.simantics.scl.compiler.internal.parsing.declarations.DRulesetAst; import org.simantics.scl.compiler.internal.parsing.declarations.DTypeAst; import org.simantics.scl.compiler.internal.parsing.declarations.DValueAst; import org.simantics.scl.compiler.internal.parsing.declarations.DValueTypeAst; @@ -38,36 +39,37 @@ import org.simantics.scl.compiler.module.ImportDeclaration; import gnu.trove.map.hash.THashMap; public class DeclarationClassification { - ArrayList importsAst = new ArrayList(); - ArrayList dataTypesAst = new ArrayList(); - ArrayList typeAliasesAst = new ArrayList(); - ValueRepository valueDefinitionsAst = new ValueRepository(); - RelationRepository relationDefinitionsAst = new RelationRepository(); - ArrayList typeAnnotationsAst = new ArrayList(); - ArrayList fixityAst = new ArrayList(); - ArrayList typeClassesAst = new ArrayList(); - ArrayList instancesAst = new ArrayList(); - ArrayList derivingInstancesAst = new ArrayList(); - ArrayList effectsAst = new ArrayList(); - ArrayList rulesAst = new ArrayList(); - ArrayList mappingRelationsAst = new ArrayList(); + public ArrayList importsAst = new ArrayList(); + public ArrayList dataTypesAst = new ArrayList(); + public ArrayList typeAliasesAst = new ArrayList(); + public ValueRepository valueDefinitionsAst = new ValueRepository(); + public RelationRepository relationDefinitionsAst = new RelationRepository(); + public ArrayList typeAnnotationsAst = new ArrayList(); + public ArrayList fixityAst = new ArrayList(); + public ArrayList typeClassesAst = new ArrayList(); + public ArrayList instancesAst = new ArrayList(); + public ArrayList derivingInstancesAst = new ArrayList(); + public ArrayList effectsAst = new ArrayList(); + public ArrayList rulesAst = new ArrayList(); + public ArrayList mappingRelationsAst = new ArrayList(); + public ArrayList rulesetsAst = new ArrayList(); - THashMap valueDocumentation = new THashMap(); - THashMap relationDocumentation = new THashMap(); - THashMap typeDocumentation = new THashMap(); - THashMap classDocumentation = new THashMap(); + public THashMap valueDocumentation = new THashMap(); + public THashMap relationDocumentation = new THashMap(); + public THashMap typeDocumentation = new THashMap(); + public THashMap classDocumentation = new THashMap(); - ArrayList javaMethodDeclarations = new ArrayList(); + public ArrayList javaMethodDeclarations = new ArrayList(); - StringBuilder moduleDocumentation = new StringBuilder(); + public StringBuilder moduleDocumentation = new StringBuilder(); - ArrayList currentAnnotations = new ArrayList(2); - DDocumentationAst documentation; - String inJavaClass; + public ArrayList currentAnnotations = new ArrayList(2); + public DDocumentationAst documentation; + public String inJavaClass; - ArrayList defaultAnnotations = new ArrayList(); + public ArrayList defaultAnnotations = new ArrayList(); - ErrorLog errorLog; + public ErrorLog errorLog; public DeclarationClassification(CompilationContext compilationContext) { this.errorLog = compilationContext.errorLog; @@ -106,6 +108,8 @@ public class DeclarationClassification { handle((DMappingRelationAst)declaration); else if(declaration instanceof DRelationAst) handle((DRelationAst)declaration); + else if(declaration instanceof DRulesetAst) + handle((DRulesetAst)declaration); else throw new InternalCompilerError("Unknown declaration " + declaration.getClass().getSimpleName()); } @@ -186,7 +190,7 @@ public class DeclarationClassification { importsAst.add(declaration); } - public void handle(DImportJavaAst declaration) { + public void handle(DImportJavaAst declaration) { if(!currentAnnotations.isEmpty()) { for(DAnnotationAst annotation : currentAnnotations) { String name = annotation.id.text; @@ -236,6 +240,10 @@ public class DeclarationClassification { errorLog.log(declaration.location, "Annotations not supported."); currentAnnotations = new ArrayList(2); } + if(declaration.name.name.equals("Eq") || declaration.name.name.equals("Hashable")) { + errorLog.logWarning(declaration.location, "Skipped instance definition for " + declaration.name + " for " + declaration.types[0]); + return; + } instancesAst.add(new ProcessedDInstanceAst( declaration, valueDefs)); @@ -246,6 +254,10 @@ public class DeclarationClassification { errorLog.log(declaration.location, "Annotations not supported."); currentAnnotations = new ArrayList(2); } + if(declaration.name.name.equals("Eq") || declaration.name.name.equals("Hashable")) { + errorLog.logWarning(declaration.location, "Skipped instance definition for " + declaration.name + " for " + declaration.types[0]); + return; + } derivingInstancesAst.add(declaration); } @@ -334,11 +346,19 @@ public class DeclarationClassification { } } + public void handle(DRulesetAst declaration) { + if(documentation != null) { + declaration.documentation = documentation; + documentation = null; + } + rulesetsAst.add(declaration); + } + public void handle(DDocumentationAst declaration) { if(documentation != null) { errorLog.log(documentation.location, "Invalid documentation string. It precedes another documentation string."); } - documentation = declaration; + documentation = declaration; } public void handle(DAnnotationAst declaration) {