{-# 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