X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.scl.compiler%2Fsrc%2Forg%2Fsimantics%2Fscl%2Fcompiler%2Finternal%2Fderiving%2FShowDeriver.java;h=afd2a4f8943dfe3d5aa711a611ac3a6827f7eae1;hp=e06a117e9cb20b4ecfc6ee03ed93a6f0a06eda09;hb=a8758de5bc19e5adb3f618d3038743a164f09912;hpb=12d9af17384d960b75d58c3935d2b7b46d93e87b diff --git a/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/deriving/ShowDeriver.java b/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/deriving/ShowDeriver.java index e06a117e9..afd2a4f89 100644 --- a/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/deriving/ShowDeriver.java +++ b/bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/internal/deriving/ShowDeriver.java @@ -10,7 +10,9 @@ import org.simantics.scl.compiler.elaboration.expressions.EApply; import org.simantics.scl.compiler.elaboration.expressions.ELiteral; import org.simantics.scl.compiler.elaboration.expressions.EVar; import org.simantics.scl.compiler.elaboration.expressions.Expression; +import org.simantics.scl.compiler.elaboration.modules.TypeAlias; import org.simantics.scl.compiler.elaboration.modules.TypeConstructor; +import org.simantics.scl.compiler.elaboration.modules.TypeDescriptor; import org.simantics.scl.compiler.environment.AmbiguousNameException; import org.simantics.scl.compiler.environment.Environment; import org.simantics.scl.compiler.environment.Environments; @@ -46,7 +48,7 @@ class ShowDeriver implements InstanceDeriver { } TCon con; try { - con = Environments.getTypeConstructorName(environment, headType.name); + con = Environments.getTypeDescriptorName(environment, headType.name); } catch (AmbiguousNameException e1) { errorLog.log(headType.location, e1.getMessage()); return; @@ -55,11 +57,16 @@ class ShowDeriver implements InstanceDeriver { errorLog.log(headType.location, "Couldn't resolve " + headType.name); return; } - TypeConstructor tcon = environment.getTypeConstructor(con); - if(tcon == null) { + TypeDescriptor tdesc = environment.getTypeDescriptor(con); + if(tdesc == null) { errorLog.log(headType.location, "Didn't find type constructor for " + headType.name); return; } + if(tdesc instanceof TypeAlias) { + errorLog.log(headType.location, "Cannot derive instance for a type alias."); + return; + } + TypeConstructor tcon = (TypeConstructor)tdesc; if(tcon.isOpen) { errorLog.log(headType.location, "Cannot derive instance for open data types."); return;