-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathNormalStoreProgress.agda
140 lines (118 loc) · 7.54 KB
/
NormalStoreProgress.agda
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
module MonoRef.Dynamics.Efficient.EvStore.NormalStoreProgress where
open import Data.Empty using (⊥-elim)
open import MonoRef.Dynamics.Efficient.Coercions
open import MonoRef.Dynamics.Efficient.Error
open import MonoRef.Dynamics.Efficient.EvStore.ActiveCastProgProgress
open import MonoRef.Dynamics.Efficient.EvStore.CastProgress
open import MonoRef.Dynamics.Efficient.EvStore.ProgProgressDef
open import MonoRef.Dynamics.Efficient.EvStore.Reduction
open import MonoRef.Dynamics.Efficient.EvStore.Store
open import MonoRef.Dynamics.Efficient.Frames
open import MonoRef.Dynamics.Efficient.Substitution
open import MonoRef.Dynamics.Efficient.TargetWithoutBlame
open import MonoRef.Static.Context
open import MonoRef.Static.Types
progress-normal-store : ∀ {Σ A}
→ (e : Σ ∣ ∅ ⊢ A) → (μ : Store Σ) → NormalStore μ → ProgProgress e μ
progress-normal-store (` ()) _ _
progress-normal-store (ƛ e) _ _ = done (S-Val (V-ƛ e))
progress-normal-store (e₁ · e₂) ν μ-evd with progress-normal-store e₁ ν μ-evd
... | step-d μ-evd' e₁⟶e₁' = step-d μ-evd' (ξ (ξ-appₗ e₂) (switch e₁⟶e₁'))
... | step-a μ-evd' e₁⟶e₁' = step-d μ-evd' (ξ (ξ-appₗ e₂) e₁⟶e₁')
... | done v with progress-normal-store e₂ ν μ-evd
... | step-d μ-evd' e₂⟶e₂' = step-d μ-evd' (ξ (ξ-appᵣ e₁) (switch e₂⟶e₂'))
... | step-a μ-evd' e₂⟶e₂' = step-d μ-evd' (ξ (ξ-appᵣ e₁) e₂⟶e₂')
progress-normal-store (_ · _) _ μ-evd | done (S-Val (V-ƛ _)) | done v' =
step-d μ-evd (β-pure (β-ƛ v'))
progress-normal-store (_ · _) _ μ-evd | done (V-cast v (I-final (I-middle I-fun))) | done v' =
step-d μ-evd (β-pure (β-ƛₚ v v')
)
... | error E-error = step-d μ-evd (ξ-error (ξ-appᵣ e₁))
progress-normal-store (.error · e₂) ν μ-evd | error E-error =
step-d μ-evd (ξ-error (ξ-appₗ e₂))
progress-normal-store `zero _ _ = done (S-Val V-zero)
progress-normal-store (`suc e) ν μ-evd with progress-normal-store e ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ ξ-suc (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ ξ-suc e⟶e')
... | done x = done (S-Val (V-suc x))
... | error E-error = step-d μ-evd (ξ-error ξ-suc)
progress-normal-store (case p z s) ν μ-evd with progress-normal-store p ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-caseₚ z s) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-caseₚ z s) e⟶e')
... | error E-error = step-d μ-evd (ξ-error (ξ-caseₚ z s))
... | done (S-Val V-zero) = step-d μ-evd (β-pure β-zero)
... | done (S-Val (V-suc v)) = step-d μ-evd (β-pure (β-suc v))
... | done (V-cast _ (I-final (I-middle ())))
progress-normal-store (ref A e) ν μ-evd with progress-normal-store e ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-ref A) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-ref A) e⟶e')
progress-normal-store {Σ = Σ} {A = Ref A} (ref A e) ν μ-evd | done v =
step-d μ-evd (β-mono (β-ref v))
... | error E-error = step-d μ-evd (ξ-error (ξ-ref A))
progress-normal-store (e₁ `× e₂) ν μ-evd with progress-normal-store e₁ ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-×ₗ e₂) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-×ₗ e₂) e⟶e')
... | error E-error = step-d μ-evd (ξ-error (ξ-×ₗ e₂))
... | done v₁ with progress-normal-store e₂ ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-×ᵣ e₁) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-×ᵣ e₁) e⟶e')
... | done v₂ = done (S-Val (V-pair v₁ v₂))
... | error E-error = step-d μ-evd (ξ-error (ξ-×ᵣ e₁))
progress-normal-store (π₁ e) ν μ-evd with progress-normal-store e ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ ξ-πₗ (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ ξ-πₗ e⟶e')
... | done (S-Val (V-pair v₁ v₂)) = step-d μ-evd (β-pure (β-π₁ v₁ v₂))
... | done (V-cast _ (I-final (I-middle ())))
... | error E-error = step-d μ-evd (ξ-error ξ-πₗ)
progress-normal-store (π₂ e) ν μ-evd with progress-normal-store e ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ ξ-πᵣ (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ ξ-πᵣ e⟶e')
... | done (S-Val (V-pair v₁ v₂)) = step-d μ-evd (β-pure (β-π₂ v₁ v₂))
... | done (V-cast _ (I-final (I-middle ())))
... | error E-error = step-d μ-evd (ξ-error ξ-πᵣ)
progress-normal-store (addr mem Σ'⊑Σ) _ _ = done (S-Val (V-addr mem Σ'⊑Σ))
progress-normal-store ((!ₛ e) A-static) ν μ-evd with progress-normal-store e ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-!ₛ A-static) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-!ₛ A-static) e⟶e')
... | done (S-Val v) = step-d μ-evd (β-mono (β-!ₛ v))
... | done (V-cast _ (I-final (I-middle ())))
... | error E-error = step-d μ-evd (ξ-error (ξ-!ₛ A-static))
progress-normal-store ((e₁ :=ₛ e₂) A-static) ν μ-evd with progress-normal-store e₁ ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ₛₗ A-static e₂) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ₛₗ A-static e₂) e⟶e')
... | error E-error = step-d μ-evd (ξ-error (ξ-:=ₛₗ A-static e₂))
... | done (V-cast _ (I-final (I-middle ())))
... | done (S-Val v₁) with progress-normal-store e₂ ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ₛᵣ A-static e₁) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ₛᵣ A-static e₁) e⟶e')
... | done v₂ = step-d μ-evd (β-mono (β-:=ₛ v₁ v₂))
... | error E-error = step-d μ-evd (ξ-error (ξ-:=ₛᵣ A-static e₁))
progress-normal-store (! A x e) ν μ-evd with progress-normal-store e ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-! A x) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-! A x) e⟶e')
... | done (V-cast _ (I-final (I-middle ())))
... | done (S-Val v) = step-d μ-evd (β-mono (β-! x v))
... | error E-error = step-d μ-evd (ξ-error (ξ-! A x))
progress-normal-store (:= A x e₁ e₂) ν μ-evd with progress-normal-store e₁ ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ₗ A x e₂) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ₗ A x e₂) e⟶e')
... | error E-error = step-d μ-evd (ξ-error (ξ-:=ₗ A x e₂))
... | done (V-cast _ (I-final (I-middle ())))
... | done (S-Val v₁) with progress-normal-store e₂ ν μ-evd
... | step-d μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ᵣ A x e₁) (switch e⟶e'))
... | step-a μ-evd' e⟶e' = step-d μ-evd' (ξ (ξ-:=ᵣ A x e₁) e⟶e')
... | done v₂ = step-d μ-evd (β-mono (β-:= x v₁ v₂))
... | error E-error = step-d μ-evd (ξ-error (ξ-:=ᵣ A x e₁))
progress-normal-store unit _ _ = done (S-Val V-unit)
progress-normal-store error _ _ = error E-error
progress-normal-store (e < c >) ν μ-evd with progress-normal-store e ν μ-evd
... | step-d μ-evd' e⟶e' = step-a μ-evd' (ξ-cast e⟶e')
... | step-a μ-evd' (switch e⟶e') = step-a μ-evd' (ξ-cast e⟶e')
... | step-a μ-evd' (ξ-cast _) = step-d μ-evd' (cast-pure compose-casts)
... | step-a μ-evd' ξ-cast-error = step-d μ-evd' (cast-pure compose-casts)
... | error E-error = step-a μ-evd (ξ-cast-error)
... | done v
with ⟶ᵤᵣprogress v c ν
... | step-pure R = step-d μ-evd (cast-pure R)
... | step-mono R = step-d μ-evd (cast-mono R)
... | done x = done x