{-# LANGUAGE DataKinds #-} {-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE MultiParamTypeClasses #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE TypeApplications #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE UndecidableInstances #-} {-# OPTIONS_GHC -Wno-orphans #-} module Test.Cardano.Ledger.Conformance.ExecSpecRule.Conway.GovCert () where import Cardano.Ledger.Conway (ConwayEra) import Control.State.Transition.Extended (TRC (..)) import Data.Bifunctor (Bifunctor (..)) import qualified MAlonzo.Code.Ledger.Conway.Foreign.API as Agda import Test.Cardano.Ledger.Conformance.ExecSpecRule.Conway.Cert (ConwayCertExecContext (..)) import Test.Cardano.Ledger.Conformance.ExecSpecRule.Core ( ExecSpecRule (..), SpecTRC (..), ) import Test.Cardano.Ledger.Conformance.SpecTranslate.Base ( SpecTranslate (..), askSpecTransM, unComputationResult, withCtxSpecTransM, ) instance ExecSpecRule "GOVCERT" ConwayEra where type ExecContext "GOVCERT" ConwayEra = ConwayCertExecContext ConwayEra translateInputs :: HasCallStack => TRC (EraRule "GOVCERT" ConwayEra) -> SpecTransM ConwayEra (ExecContext "GOVCERT" ConwayEra) (SpecTRC "GOVCERT" ConwayEra) translateInputs (TRC (Environment (EraRule "GOVCERT" ConwayEra) env, State (EraRule "GOVCERT" ConwayEra) st, Signal (EraRule "GOVCERT" ConwayEra) sig)) = do ConwayCertExecContext {..} <- SpecTransM ConwayEra (ConwayCertExecContext ConwayEra) (ConwayCertExecContext ConwayEra) forall era ctx. SpecTransM era ctx ctx askSpecTransM agdaEnv <- withCtxSpecTransM (ccecVotes, ccecWithdrawals) $ toSpecRep env agdaSt <- withCtxSpecTransM () $ toSpecRep st agdaSig <- withCtxSpecTransM () $ toSpecRep sig pure $ SpecTRC agdaEnv agdaSt agdaSig runAgdaRule :: HasCallStack => SpecTRC "GOVCERT" ConwayEra -> Either Text (SpecState "GOVCERT" ConwayEra) runAgdaRule (SpecTRC SpecEnvironment "GOVCERT" ConwayEra env (Agda.MkCertState DState dState PState pState GState vState) SpecSignal "GOVCERT" ConwayEra sig) = (GState -> CertState) -> Either Text GState -> Either Text CertState forall b c a. (b -> c) -> Either a b -> Either a c forall (p :: * -> * -> *) b c a. Bifunctor p => (b -> c) -> p a b -> p a c second (DState -> PState -> GState -> CertState Agda.MkCertState DState dState PState pState) (Either Text GState -> Either Text (SpecState "GOVCERT" ConwayEra)) -> (T_HSComputationResult_110 Text GState -> Either Text GState) -> T_HSComputationResult_110 Text GState -> Either Text (SpecState "GOVCERT" ConwayEra) forall b c a. (b -> c) -> (a -> b) -> a -> c . T_HSComputationResult_110 Text GState -> Either Text GState forall a. ComputationResult Text a -> Either Text a unComputationResult (T_HSComputationResult_110 Text GState -> Either Text (SpecState "GOVCERT" ConwayEra)) -> T_HSComputationResult_110 Text GState -> Either Text (SpecState "GOVCERT" ConwayEra) forall a b. (a -> b) -> a -> b $ CertEnv -> GState -> DCert -> T_HSComputationResult_110 Text GState Agda.govCertStep CertEnv SpecEnvironment "GOVCERT" ConwayEra env GState vState DCert SpecSignal "GOVCERT" ConwayEra sig