{-# LANGUAGE TypeFamilies #-} {-# OPTIONS_GHC -Wno-orphans #-} module Cardano.Ledger.Babbage.State.Stake () where import Cardano.Ledger.Babbage.Core () import Cardano.Ledger.Babbage.Era (BabbageEra) import Cardano.Ledger.Shelley.State ( EraStake (..), ShelleyInstantStake, addShelleyInstantStake, deleteShelleyInstantStake, resolveShelleyInstantStake, shelleyInstantStakeCredentialsL, ) instance EraStake BabbageEra where type InstantStake BabbageEra = ShelleyInstantStake BabbageEra instantStakeCredentialsL :: Lens' (InstantStake BabbageEra) (Map (Credential 'Staking) (CompactForm Coin)) instantStakeCredentialsL = forall era. Lens' (ShelleyInstantStake era) (Map (Credential 'Staking) (CompactForm Coin)) shelleyInstantStakeCredentialsL addInstantStake :: UTxO BabbageEra -> InstantStake BabbageEra -> InstantStake BabbageEra addInstantStake = forall era. EraTxOut era => UTxO era -> ShelleyInstantStake era -> ShelleyInstantStake era addShelleyInstantStake deleteInstantStake :: UTxO BabbageEra -> InstantStake BabbageEra -> InstantStake BabbageEra deleteInstantStake = forall era. EraTxOut era => UTxO era -> ShelleyInstantStake era -> ShelleyInstantStake era deleteShelleyInstantStake resolveInstantStake :: InstantStake BabbageEra -> UMap -> Stake resolveInstantStake = forall era. (EraStake era, InstantStake era ~ ShelleyInstantStake era) => ShelleyInstantStake era -> UMap -> Stake resolveShelleyInstantStake