瀏覽代碼

[WIP, not sure] Added generic types checking if their bounds are met

Before it they would simply return false, even if a type would match the bounds
kindlich 5 年之前
父節點
當前提交
49043637e1
沒有發現已知的金鑰在資料庫的簽署中
共有 1 個文件被更改,包括 11 次插入1 次删除
  1. 11
    1
      CodeModel/src/main/java/org/openzen/zenscript/codemodel/type/member/TypeMembers.java

+ 11
- 1
CodeModel/src/main/java/org/openzen/zenscript/codemodel/type/member/TypeMembers.java 查看文件

@@ -20,6 +20,7 @@ import org.openzen.zenscript.codemodel.expression.NullExpression;
20 20
 import org.openzen.zenscript.codemodel.expression.StorageCastExpression;
21 21
 import org.openzen.zenscript.codemodel.expression.SupertypeCastExpression;
22 22
 import org.openzen.zenscript.codemodel.expression.WrapOptionalExpression;
23
+import org.openzen.zenscript.codemodel.generic.TypeParameterBound;
23 24
 import org.openzen.zenscript.codemodel.member.EnumConstantMember;
24 25
 import org.openzen.zenscript.codemodel.member.IDefinitionMember;
25 26
 import org.openzen.zenscript.codemodel.member.InnerDefinition;
@@ -430,8 +431,17 @@ public final class TypeMembers {
430 431
    
431 432
 		if( getImplicitCaster(toType) != null || extendsOrImplements(toType.type))
432 433
 		    return true;
433
-		
434
+
435
+		if(type.type.isGeneric() && type.type instanceof GenericTypeID) {
436
+			final GenericTypeID genericTypeID = (GenericTypeID) type.type;
437
+			if(genericTypeID.parameter.matches(cache, toType.type)) {
438
+				return true;
439
+			}
440
+		}
441
+
442
+
434 443
         final StoredType accept = type.type.accept(new TagRemovingTypeVisitor(cache));
444
+
435 445
         if(!this.type.type.equals(accept.type) && cache.get(accept).canCastImplicit(toType)){
436 446
             return true;
437 447
         }

Loading…
取消
儲存