module Ledger.Dijkstra.Foreign.Enact where
open import Class.Convertible
open import Class.Convertible.Foreign
open import Tactic.Derive.Convertible
open import Class.HasHsType
open import Class.HasHsType.Foreign
open import Tactic.Derive.HsType
open import Ledger.Prelude
open import Ledger.Prelude.Foreign.HSTypes
open import Ledger.Core.Foreign.Address
open import Ledger.Dijkstra.Foreign.HSStructures
open import Ledger.Dijkstra.Foreign.PParams
open import Ledger.Dijkstra.Foreign.Gov.Actions
open import Ledger.Dijkstra.Specification.Enact DummyGovStructure
open import Ledger.Dijkstra.Specification.Enact.Properties.Computational DummyGovStructure
open Computational
instance
HsTy-EnactEnv = autoHsType EnactEnv ⊣ withConstructor "MkEnactEnv"
• fieldPrefix "ee"
Conv-EnactEnv = autoConvert EnactEnv
HsTy-EnactState = autoHsType EnactState ⊣ withConstructor "MkEnactState"
• fieldPrefix "es"
Conv-EnactState = autoConvert EnactState
enact-step : HsType (EnactEnv → EnactState → GovAction → ComputationResult String EnactState)
enact-step = to (compute Computational-ENACT)
{-# COMPILE GHC enact-step as enactStep #-}