module A201801.IPLPropositions where

open import A201801.Prelude
open import A201801.Category
open import A201801.List


--------------------------------------------------------------------------------


infixr 8 _⊃_
data Form : Set
  where
    ι_  : String  Form
    _⊃_ : Form  Form  Form


record Truth : Set
  where
    constructor _true
    field
      A : Form


instance
  FormVar : IsString Form
  FormVar =
    record
      { Constraint = \ s  
      ; fromString = \ s  ι s
      }


--------------------------------------------------------------------------------


injι :  {P₁ P₂}  ι P₁  ι P₂
                  P₁  P₂
injι refl = refl


inj⊃₁ :  {A₁ A₂ B₁ B₂}  A₁  B₁  A₂  B₂
                         A₁  A₂
inj⊃₁ refl = refl


inj⊃₂ :  {A₁ A₂ B₁ B₂}  A₁  B₁  A₂  B₂
                         B₁  B₂
inj⊃₂ refl = refl


_≟ₚ_ : (A₁ A₂ : Form)  Dec (A₁  A₂)
(ι P₁)    ≟ₚ (ι P₂)    with P₁ ≟ₛ P₂
...                    | yes refl = yes refl
...                    | no P₁≢P₂ = no (P₁≢P₂  injι)
(ι P₁)    ≟ₚ (A₂  B₂) = no (\ ())
(A₁  B₁) ≟ₚ (ι P₂)    = no (\ ())
(A₁  B₁) ≟ₚ (A₂  B₂) with A₁ ≟ₚ A₂ | B₁ ≟ₚ B₂
...                    | yes refl | yes refl = yes refl
...                    | yes refl | no B₁≢B₂ = no (B₁≢B₂  inj⊃₂)
...                    | no A₁≢A₂ | _        = no (A₁≢A₂  inj⊃₁)


--------------------------------------------------------------------------------


_⊃⋯⊃_ : List Form  Form  Form
       ⊃⋯⊃ A = A
(Ξ , B) ⊃⋯⊃ A = Ξ ⊃⋯⊃ (B  A)


--------------------------------------------------------------------------------