{-# OPTIONS --cubical --safe #-}
module Cubical.Foundations.Structure where

open import Cubical.Core.Everything

private
  variable
     ℓ' ℓ'' : Level
    S : Type   Type ℓ'

-- A structure is a type-family S : Type ℓ → Type ℓ', i.e. for X : Type ℓ and s : S X,
-- the pair (X , s) : TypeWithStr ℓ S means that X is equipped with a S-structure, witnessed by s.

TypeWithStr : ( : Level) (S : Type   Type ℓ')  Type (ℓ-max (ℓ-suc ) ℓ')
TypeWithStr  S = Σ[ X  Type  ] S X

typ : TypeWithStr  S  Type 
typ = fst

str : (A : TypeWithStr  S)  S (typ A)
str = snd

-- An S-structure should have a notion of S-homomorphism, or rather S-isomorphism.
-- This will be implemented by a function ι : StrIso S ℓ'
-- that gives us for any two types with S-structure (X , s) and (Y , t) a family:
--    ι (X , s) (Y , t) : (X ≃ Y) → Type ℓ''
StrIso : (S : Type   Type ℓ'') (ℓ' : Level)  Type (ℓ-max (ℓ-suc (ℓ-max  ℓ')) ℓ'')
StrIso {} S ℓ' = (A B : TypeWithStr  S)  typ A  typ B  Type ℓ'