2
0
Эх сурвалжийг харах

do not unify abstract _new function while inlining

Simon Krajewski 12 жил өмнө
parent
commit
81f60a9201
1 өөрчлөгдсөн 5 нэмэгдсэн , 3 устгасан
  1. 5 3
      optimizer.ml

+ 5 - 3
optimizer.ml

@@ -395,9 +395,11 @@ let rec type_inline ctx cf f ethis params tret config p force =
 			(match follow ethis.etype with
 			(match follow ethis.etype with
 			| TAnon a -> (match !(a.a_status) with
 			| TAnon a -> (match !(a.a_status) with
 				| Statics {cl_kind = KAbstractImpl a } when Meta.has Meta.Impl cf.cf_meta ->
 				| Statics {cl_kind = KAbstractImpl a } when Meta.has Meta.Impl cf.cf_meta ->
-					(* the first argument must unify with a_this for abstract implementation functions *)
-					let tb = (TFun(("",false,map_type a.a_this) :: List.map (fun e -> "",false,e.etype) (List.tl params),tret)) in
-					unify_raise ctx mt tb p
+					if cf.cf_name <> "_new" then begin
+						(* the first argument must unify with a_this for abstract implementation functions *)
+						let tb = (TFun(("",false,map_type a.a_this) :: List.map (fun e -> "",false,e.etype) (List.tl params),tret)) in
+						unify_raise ctx mt tb p
+					end
 				| _ -> unify_func())
 				| _ -> unify_func())
 			| _ -> unify_func());
 			| _ -> unify_func());
 			(*
 			(*