2022-02-10 07:14:29 +08:00
|
|
|
module Luau.RuntimeError where
|
|
|
|
|
|
|
|
open import Agda.Builtin.Equality using (_≡_)
|
2022-02-12 09:03:26 +08:00
|
|
|
open import Luau.Heap using (Heap; _[_])
|
2022-02-10 07:14:29 +08:00
|
|
|
open import FFI.Data.Maybe using (just; nothing)
|
2022-02-12 09:03:26 +08:00
|
|
|
open import Luau.Syntax using (Block; Expr; nil; var; addr; block_is_end; _$_; local_←_; return; done; _∙_)
|
2022-02-10 07:14:29 +08:00
|
|
|
|
2022-02-12 09:03:26 +08:00
|
|
|
data RuntimeErrorᴮ {a} (H : Heap a) : Block a → Set
|
|
|
|
data RuntimeErrorᴱ {a} (H : Heap a) : Expr a → Set
|
2022-02-10 07:14:29 +08:00
|
|
|
|
|
|
|
data RuntimeErrorᴱ H where
|
|
|
|
NilIsNotAFunction : ∀ {M} → RuntimeErrorᴱ H (nil $ M)
|
|
|
|
UnboundVariable : ∀ x → RuntimeErrorᴱ H (var x)
|
2022-02-12 09:03:26 +08:00
|
|
|
SEGV : ∀ a → (H [ a ] ≡ nothing) → RuntimeErrorᴱ H (addr a)
|
2022-02-10 07:14:29 +08:00
|
|
|
app : ∀ {M N} → RuntimeErrorᴱ H M → RuntimeErrorᴱ H (M $ N)
|
|
|
|
block : ∀ b {B} → RuntimeErrorᴮ H B → RuntimeErrorᴱ H (block b is B end)
|
|
|
|
|
|
|
|
data RuntimeErrorᴮ H where
|
|
|
|
local : ∀ x {M B} → RuntimeErrorᴱ H M → RuntimeErrorᴮ H (local x ← M ∙ B)
|
|
|
|
return : ∀ {M B} → RuntimeErrorᴱ H M → RuntimeErrorᴮ H (return M ∙ B)
|
|
|
|
|