import Syntax.Simple.Signature as S
module Syntax.BiTyped.Pre.Generalised.Functor (SD : S.SigD) where
open import Prelude
open import Syntax.Simple SD
import Syntax.Typed.Raw.Functor SD as R
open import Syntax.BiTyped.Signature SD
open import Theory.Erasure
private variable
Ξ : ℕ
X : R.Fam ℓ
Fam : (ℓ : Level) → R.Fam ℓ′ → Set (lsuc ℓ ⊔ ℓ′)
Fam ℓ X = (valid exact : Bool) → Mode → {n : ℕ} → X n → Set ℓ
Fam₀ : R.Fam₀ → Set₁
Fam₀ = Fam 0ℓ
⟦_⟧ᵃ : (Δ : TExps Ξ) (X : R.Fam ℓ) (Y : Fam ℓ′ X)
→ (valid : Bool) → Mode → {n : ℕ} → R.⟦ Δ ⟧ᵃ X n → Set ℓ′
⟦ Δ ⟧ᵃ X Y v d x = ∃[ e ] Y v e d x
⟦_⟧ᵃˢ : (Ds : ArgsD Ξ) (X : R.Fam ℓ) (Y : Fam ℓ′ X)
→ (vs : Vec Bool (length Ds)) → {n : ℕ} → R.⟦ eraseᵃˢ Ds ⟧ᵃˢ X n → Set ℓ′
⟦ [] ⟧ᵃˢ _ _ _ _ = ⊤
⟦ (Δ ⊢[ d ] _) ∷ Ds ⟧ᵃˢ X Y (v ∷ vs) (x , xs) = ⟦ Δ ⟧ᵃ X Y v d x × ⟦ Ds ⟧ᵃˢ X Y vs xs
⟦_⟧ᶜ : (D : OpD) (X : R.Fam ℓ) (Y : Fam ℓ′ X)
→ (valid : Bool) → Mode → {n : ℕ} → R.⟦ eraseᶜ D ⟧ᶜ X n → Set ℓ′
⟦ ι d _ Ds ⟧ᶜ X Y v d' ts = ∃[ vs ] And (toList vs) v × d ≡ d' × ⟦ Ds ⟧ᵃˢ X Y vs ts
⟦_⟧ : (D : SigD) (X : R.Fam ℓ) (Y : Fam ℓ′ X) → Fam ℓ′ (R.⟦ erase D ⟧ X)
⟦ D ⟧ X Y v e d (i , xs) = e ≡ true × ⟦ D .ar i ⟧ᶜ X Y v d xs