import Syntax.Simple.Signature as S

module Syntax.BiTyped.Pre.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 = Mode  {n : }  X n  Set 

Fam₀ : R.Fam₀  Set₁
Fam₀ = Fam 0ℓ

⟦_⟧ᵃ : (Δ : TExps Ξ) (X : R.Fam ) (Y : Fam ℓ′ X)  Fam ℓ′ (R.⟦ Δ ⟧ᵃ X)
 Δ ⟧ᵃ X Y d x = Y d x

⟦_⟧ᵃˢ : (D : ArgsD Ξ) (X : R.Fam ) (Y : Fam ℓ′ X)
       {n : }  R.⟦ eraseᵃˢ D ⟧ᵃˢ X n  Set ℓ′
 []                ⟧ᵃˢ _ _ _        = 
 (Δ ⊢[ d ] _)  Ds ⟧ᵃˢ X Y (x , xs) =  Δ ⟧ᵃ X Y d x ×  Ds ⟧ᵃˢ X Y xs

⟦_⟧ᶜ : (D : OpD) (X : R.Fam ) (Y : Fam ℓ′ X)  Fam ℓ′ (R.⟦ eraseᶜ D ⟧ᶜ X)
 ι d  _ D ⟧ᶜ X Y d' xs = d  d' ×  D ⟧ᵃˢ X Y xs

⟦_⟧ : (D : SigD) (X : R.Fam ) (Y : Fam ℓ′ X)  Fam ℓ′ (R.⟦ erase D  X)
 D  X Y d (i , xs) =  D .ar i ⟧ᶜ X Y d xs