From 2f3b510246be986837718220324e6bdc25b18afb Mon Sep 17 00:00:00 2001 From: NeilKleistGao Date: Tue, 21 Jun 2022 10:00:18 +0800 Subject: [PATCH] Fix the res running variable is not consistent with DiffTests --- shared/src/test/diff/mlscript/Issues65.mls | 52 +++++++++++++++++++ .../src/test/scala/mlscript/DiffTests.scala | 8 ++- 2 files changed, 59 insertions(+), 1 deletion(-) create mode 100644 shared/src/test/diff/mlscript/Issues65.mls diff --git a/shared/src/test/diff/mlscript/Issues65.mls b/shared/src/test/diff/mlscript/Issues65.mls new file mode 100644 index 0000000000..29db2daa1f --- /dev/null +++ b/shared/src/test/diff/mlscript/Issues65.mls @@ -0,0 +1,52 @@ +:js +42 +//│ // Prelude +//│ let res; +//│ // Query 1 +//│ res = 42; +//│ // End of generated code +//│ res: 42 +//│ = 42 + +:js +def foo = "oops" +//│ // Query 1 +//│ globalThis.foo = "oops"; +//│ res = foo; +//│ // End of generated code +//│ foo: "oops" +//│ = 'oops' + +:js +res +//│ // Query 1 +//│ res = res; +//│ // End of generated code +//│ res: "oops" +//│ = 'oops' + +:js +res = 5 +//│ // Query 1 +//│ globalThis.res1 = 5; +//│ res = res1; +//│ // End of generated code +//│ res: 5 +//│ = 5 + +:js +foo +//│ // Query 1 +//│ res = foo; +//│ // End of generated code +//│ res: "oops" +//│ = 'oops' + +:js +res +//│ // Query 1 +//│ res = res1; +//│ // End of generated code +//│ res: 5 +//│ = 5 + diff --git a/shared/src/test/scala/mlscript/DiffTests.scala b/shared/src/test/scala/mlscript/DiffTests.scala index 5921f6c0fa..1dab74d4bd 100644 --- a/shared/src/test/scala/mlscript/DiffTests.scala +++ b/shared/src/test/scala/mlscript/DiffTests.scala @@ -52,6 +52,7 @@ class DiffTests extends org.scalatest.funsuite.AnyFunSuite with org.scalatest.Pa override def emitDbg(str: String): Unit = output(str) } var ctx: typer.Ctx = typer.Ctx.init + var selfDefineRes: Bool = false var declared: Map[Str, typer.PolymorphicType] = Map.empty val failures = mutable.Buffer.empty[Int] val unmergedChanges = mutable.Buffer.empty[Int] @@ -510,6 +511,8 @@ class DiffTests extends org.scalatest.funsuite.AnyFunSuite with org.scalatest.Pa typer.typeType(rhs)(ctx.nextLevel, raise, vars = tps.map(tp => tp.name -> typer.freshVar(typer.noProv/*FIXME*/)(1)).toMap)) ctx += nme.name -> ty_sch + if (nme.name.contentEquals("res")) selfDefineRes = true + if (!selfDefineRes) ctx += "res" -> ty_sch declared += nme.name -> ty_sch val exp = getType(ty_sch) output(s"$nme: ${exp.show}") @@ -521,6 +524,7 @@ class DiffTests extends org.scalatest.funsuite.AnyFunSuite with org.scalatest.Pa typer.dbg = mode.dbg val ty_sch = typer.typeLetRhs(isrec, nme.name, rhs)(ctx, raise) val exp = getType(ty_sch) + if (nme.name.contentEquals("res")) selfDefineRes = true // statement does not have a declared type for the body // the inferred type must be used and stored for lookup declared.get(nme.name) match { @@ -528,6 +532,7 @@ class DiffTests extends org.scalatest.funsuite.AnyFunSuite with org.scalatest.Pa // infer it's type and store it for lookup and type gen case N => ctx += nme.name -> ty_sch + if (!selfDefineRes) ctx += "res" -> ty_sch output(s"$nme: ${exp.show}") if (mode.generateTsDeclarations) tsTypegenCodeBuilder.addTypeGenTermDefinition(exp, Some(nme.name)) @@ -536,6 +541,7 @@ class DiffTests extends org.scalatest.funsuite.AnyFunSuite with org.scalatest.Pa // the inferred type is used to for ts type gen case S(sign) => ctx += nme.name -> sign + if (!selfDefineRes) ctx += "res" -> sign val sign_exp = getType(sign) output(exp.show) output(s" <: $nme:") @@ -565,7 +571,7 @@ class DiffTests extends org.scalatest.funsuite.AnyFunSuite with org.scalatest.Pa case L(pty) => val exp = getType(pty) if (exp =/= TypeName("unit")) { - ctx += "res" -> pty + if (!selfDefineRes) ctx += "res" -> pty output(s"res: ${exp.show}") if (mode.generateTsDeclarations) tsTypegenCodeBuilder.addTypeGenTermDefinition(exp, None) prefixLength = 3