lean4-htt/tests/elabissues/leaky_tmp_metavars2.lean

66 lines
2 KiB
Text
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/-
Here is an example where temporary metavariables from typeclass resolution
could spill into nested typeclass resolution, for which the outer TC succeeds
iff:
1. the inner TC is still called, even with the leaked tmp mvars
2. the inner TC is allowed to assign the leaked tmp mvars
This example will *NOT* work in Lean4.
Although it would be easy to allow inner TC to set the outer TC tmp mvars,
the issue is that the solution to the inner TC problem may not be unique,
and it would be extremely difficult to allow backtracking from the outer TC
through to the inner TC.
In Lean4, inner TC can be called with leaked temporary mvars from the outer TC,
but they are treated as opaque, just as regular mvars are treated in the outer TC.
So, this example will fail.
-/
class Foo (α : Type) : Type := (x : Unit)
class Zoo (α : Type) : Type := (x : Unit)
class Bar (α : Type) : Type := (x : Unit)
class HasParam (α : Type) [Bar α] : Type := (x : Unit)
instance FooToBar (α : Type) [f : Foo α] : Bar α :=
match f.x with
| () => {x:=()}
instance ZooToBar (α : Type) [z : Zoo α] : Bar α :=
match z.x with
| () => {x:=()}
instance HasParamInst (α : Type) [h : Foo α] : HasParam α := {x:=()}
class Top : Type := (x : Unit)
instance FooInt : Foo Int := {x:=()}
instance AllZoo (α : Type) : Zoo α := {x:=()}
instance Bad (α : Type) [HasParam α] : Top := Top.mk ()
set_option pp.all true
set_option trace.class_instances true
set_option trace.type_context.complete_instance true
def foo [Top] : Unit := ()
#check @foo _
/-
[class_instances] class-instance resolution trace
[class_instances] (0) ?x_0 : Top := @Bad ?x_1 ?x_2
[class_instances] (1) ?x_2 : @HasParam ?x_1 (@ZooToBar ?x_1 (AllZoo ?x_1)) := @HasParamInst ?x_3 ?x_4
[type_context.complete_instance] would have synthed: Foo ?x_3
[type_context.complete_instance] would have synthed: Foo ?x_3
failed is_def_eq
-/
def couldWork : Top :=
@Bad Int (@HasParamInst Int FooInt)
#print couldWork
/-
def couldWork : Top :=
@Bad Int (@HasParamInst Int FooInt)
-/