Module walkthrough:let
Builds on walkthrough:host
tm ::= ...
| let(string, tm, tm)
typeOf Ctx T1 Ty
----------------------------------------------------- [Proj-Let]
Ctx |{tm}- let(X, T1, T2) ~~> app(abs(X, Ty, T2), T1)
eval T1 T11
----------------------------------- [E-Let-Step]
eval let(X, T1, T2) let(X, T11, T2)
value T1
subst X T1 T2 V
--------------------- [E-Let-Subst]
eval let(X, T1, T2) V
X != Y
subst X R T1 S1
subst X R T2 S2
--------------------------------------- [S-Let-NEq]
subst X R let(Y, T1, T2) let(Y, S1, S2)
subst X R T1 S1
--------------------------------------- [S-Let-Eq]
subst X R let(X, T1, T2) let(X, S1, T2)
typeOf Ctx T1 Ty1
typeOf (X, Ty1)::Ctx T2 Ty2
----------------------------- [T-Let]
typeOf Ctx let(X, T1, T2) Ty2
Click on a command or tactic to see a detailed view of its use.
Module walkthrough:let. Prove walkthrough:host:typeOf_unique. [Show Proof] Prove walkthrough:host:ty_lookup. [Show Proof] Prove walkthrough:host:subst_type_preservation. [Show Proof] Prove walkthrough:host:type_preservation. [Show Proof] Prove_Constraint walkthrough:host:proj_type_same. [Show Proof] Add_Ext_Size walkthrough:host:eval. Add_Proj_Rel walkthrough:host:eval. Prove_Ext_Ind walkthrough:host:eval. [Show Proof]