{-# LANGUAGE AllowAmbiguousTypes #-} {-# LANGUAGE DataKinds #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE EmptyDataDeriving #-} {-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE MultiParamTypeClasses #-} {-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE TypeApplications #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE TypeOperators #-} {-# LANGUAGE UndecidableInstances #-} {-# OPTIONS_GHC -Wno-orphans #-} module Cardano.Ledger.Dijkstra.Rules.SubDeleg ( DijkstraSUBDELEG, DijkstraSubDelegPredFailure (..), ) where import Cardano.Ledger.BaseTypes ( ShelleyBase, ) import Cardano.Ledger.Binary ( DecCBOR (..), EncCBOR (..), ) import Cardano.Ledger.Conway.Core import Cardano.Ledger.Conway.Rules (ConwayDelegEnv) import Cardano.Ledger.Dijkstra.Era ( DijkstraEra, DijkstraSUBDELEG, ) import Cardano.Ledger.Dijkstra.State import Cardano.Ledger.Dijkstra.TxCert (DijkstraDelegCert) import Control.DeepSeq (NFData) import Control.State.Transition.Extended ( BaseM, Environment, Event, PredicateFailure, STS, Signal, State, TRC (TRC), TransitionRule, judgmentContext, transitionRules, ) import Data.Typeable (Typeable) import Data.Void (Void) import GHC.Generics (Generic) import NoThunks.Class (NoThunks (..)) data DijkstraSubDelegPredFailure era = DijkstraSubDelegPredFailure deriving (Int -> DijkstraSubDelegPredFailure era -> ShowS [DijkstraSubDelegPredFailure era] -> ShowS DijkstraSubDelegPredFailure era -> String (Int -> DijkstraSubDelegPredFailure era -> ShowS) -> (DijkstraSubDelegPredFailure era -> String) -> ([DijkstraSubDelegPredFailure era] -> ShowS) -> Show (DijkstraSubDelegPredFailure era) forall era. Int -> DijkstraSubDelegPredFailure era -> ShowS forall era. [DijkstraSubDelegPredFailure era] -> ShowS forall era. DijkstraSubDelegPredFailure era -> String forall a. (Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a $cshowsPrec :: forall era. Int -> DijkstraSubDelegPredFailure era -> ShowS showsPrec :: Int -> DijkstraSubDelegPredFailure era -> ShowS $cshow :: forall era. DijkstraSubDelegPredFailure era -> String show :: DijkstraSubDelegPredFailure era -> String $cshowList :: forall era. [DijkstraSubDelegPredFailure era] -> ShowS showList :: [DijkstraSubDelegPredFailure era] -> ShowS Show, DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool (DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool) -> (DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool) -> Eq (DijkstraSubDelegPredFailure era) forall era. DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a $c== :: forall era. DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool == :: DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool $c/= :: forall era. DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool /= :: DijkstraSubDelegPredFailure era -> DijkstraSubDelegPredFailure era -> Bool Eq, (forall x. DijkstraSubDelegPredFailure era -> Rep (DijkstraSubDelegPredFailure era) x) -> (forall x. Rep (DijkstraSubDelegPredFailure era) x -> DijkstraSubDelegPredFailure era) -> Generic (DijkstraSubDelegPredFailure era) forall x. Rep (DijkstraSubDelegPredFailure era) x -> DijkstraSubDelegPredFailure era forall x. DijkstraSubDelegPredFailure era -> Rep (DijkstraSubDelegPredFailure era) x forall a. (forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a forall era x. Rep (DijkstraSubDelegPredFailure era) x -> DijkstraSubDelegPredFailure era forall era x. DijkstraSubDelegPredFailure era -> Rep (DijkstraSubDelegPredFailure era) x $cfrom :: forall era x. DijkstraSubDelegPredFailure era -> Rep (DijkstraSubDelegPredFailure era) x from :: forall x. DijkstraSubDelegPredFailure era -> Rep (DijkstraSubDelegPredFailure era) x $cto :: forall era x. Rep (DijkstraSubDelegPredFailure era) x -> DijkstraSubDelegPredFailure era to :: forall x. Rep (DijkstraSubDelegPredFailure era) x -> DijkstraSubDelegPredFailure era Generic) instance NoThunks (DijkstraSubDelegPredFailure era) instance NFData (DijkstraSubDelegPredFailure era) instance Era era => EncCBOR (DijkstraSubDelegPredFailure era) where encCBOR :: DijkstraSubDelegPredFailure era -> Encoding encCBOR DijkstraSubDelegPredFailure era _ = () -> Encoding forall a. EncCBOR a => a -> Encoding encCBOR () instance Typeable era => DecCBOR (DijkstraSubDelegPredFailure era) where decCBOR :: forall s. Decoder s (DijkstraSubDelegPredFailure era) decCBOR = forall a s. DecCBOR a => Decoder s a decCBOR @() Decoder s () -> Decoder s (DijkstraSubDelegPredFailure era) -> Decoder s (DijkstraSubDelegPredFailure era) forall a b. Decoder s a -> Decoder s b -> Decoder s b forall (f :: * -> *) a b. Applicative f => f a -> f b -> f b *> DijkstraSubDelegPredFailure era -> Decoder s (DijkstraSubDelegPredFailure era) forall a. a -> Decoder s a forall (f :: * -> *) a. Applicative f => a -> f a pure DijkstraSubDelegPredFailure era forall era. DijkstraSubDelegPredFailure era DijkstraSubDelegPredFailure type instance EraRuleFailure "SUBDELEG" DijkstraEra = DijkstraSubDelegPredFailure DijkstraEra type instance EraRuleEvent "SUBDELEG" DijkstraEra = VoidEraRule "SUBDELEG" DijkstraEra instance InjectRuleFailure "SUBDELEG" DijkstraSubDelegPredFailure DijkstraEra instance ( EraGov era , EraCertState era , EraRule "SUBDELEG" era ~ DijkstraSUBDELEG era ) => STS (DijkstraSUBDELEG era) where type State (DijkstraSUBDELEG era) = CertState era type Signal (DijkstraSUBDELEG era) = DijkstraDelegCert type Environment (DijkstraSUBDELEG era) = ConwayDelegEnv era type BaseM (DijkstraSUBDELEG era) = ShelleyBase type PredicateFailure (DijkstraSUBDELEG era) = DijkstraSubDelegPredFailure era type Event (DijkstraSUBDELEG era) = Void transitionRules :: [TransitionRule (DijkstraSUBDELEG era)] transitionRules = [forall era. TransitionRule (EraRule "SUBDELEG" era) dijkstraSubDelegTransition @era] dijkstraSubDelegTransition :: TransitionRule (EraRule "SUBDELEG" era) dijkstraSubDelegTransition :: forall era. TransitionRule (EraRule "SUBDELEG" era) dijkstraSubDelegTransition = do TRC (_, st, _) <- Rule (EraRule "SUBDELEG" era) 'Transition (RuleContext 'Transition (EraRule "SUBDELEG" era)) F (Clause (EraRule "SUBDELEG" era) 'Transition) (TRC (EraRule "SUBDELEG" era)) forall sts (rtype :: RuleType). Rule sts rtype (RuleContext rtype sts) judgmentContext pure st