Skip to content

Commit

Permalink
Open union encoding of Eon
Browse files Browse the repository at this point in the history
  • Loading branch information
newhoggy committed Sep 29, 2023
1 parent 63be533 commit a335ff5
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 0 deletions.
2 changes: 2 additions & 0 deletions cardano-api/cardano-api.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ library internal
Cardano.Api.Eon.ByronToAlonzoEra
Cardano.Api.Eon.ByronToMaryEra
Cardano.Api.Eon.ConwayEraOnwards
Cardano.Api.Eon.Core
Cardano.Api.Eon.MaryEraOnwards
Cardano.Api.Eon.ShelleyBasedEra
Cardano.Api.Eon.ShelleyEraOnly
Expand Down Expand Up @@ -201,6 +202,7 @@ library internal
, typed-protocols ^>= 0.1
, unordered-containers >= 0.2.11
, vector
, world-peace
, yaml

library
Expand Down
54 changes: 54 additions & 0 deletions cardano-api/internal/Cardano/Api/Eon/Core.hs
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}

module Cardano.Api.Eon.Core where

import Data.Kind
import Data.WorldPeace

data Eon (eras :: [Type]) era where
Eon :: Contains '[era] eras => OpenUnion eras -> Eon eras era

data Byron = Byron deriving (Eq, Show)
data Shelley = Shelley deriving (Eq, Show)
data Allegra = Allegra deriving (Eq, Show)
data Mary = Mary deriving (Eq, Show)
data Alonzo = Alonzo deriving (Eq, Show)
data Babbage = Babbage deriving (Eq, Show)
data Conway = Conway deriving (Eq, Show)

type ByronEraOnly = '[Byron ]
type ShelleyEraOnly = '[ Shelley ]
type AllegraEraOnly = '[ Allegra ]
type MaryEraOnly = '[ Mary ]
type AlonzoEraOnly = '[ Alonzo ]
type BabbageEraOnly = '[ Babbage ]
type ConwayEraOnly = '[ Conway]

type ByronEraOnwards = '[Byron, Shelley, Allegra, Mary, Alonzo, Babbage, Conway]
type ShelleyEraOnwards = '[ Shelley, Allegra, Mary, Alonzo, Babbage, Conway]
type AllegraEraOnwards = '[ Allegra, Mary, Alonzo, Babbage, Conway]
type MaryEraOnwards = '[ Mary, Alonzo, Babbage, Conway]
type AlonzoEraOnwards = '[ Alonzo, Babbage, Conway]
type BabbageEraOnwards = '[ Babbage, Conway]
type ConwayEraOnwards = '[ Conway]

relaxEon :: ()
=> Contains as bs
=> IsMember a bs
=> Eon as a
-> Eon bs a
relaxEon (Eon a) = Eon (relaxOpenUnion a)

example1 :: IsMember era ByronEraOnwards => Eon ByronEraOnwards era -> Eon ByronEraOnwards era
example1 = relaxEon

example2 :: IsMember era ByronEraOnwards => Eon ShelleyEraOnwards era -> Eon ByronEraOnwards era
example2 = relaxEon

0 comments on commit a335ff5

Please sign in to comment.