Safe Haskell | None |
---|---|
Language | Haskell2010 |
Instances requires for consensus/ledger integration
Synopsis
- data ByronTransition = ByronTransitionInfo !( Map ProtocolVersion BlockNo )
- byronEraParams :: Config -> EraParams
- byronEraParamsNeverHardForks :: Config -> EraParams
- initByronLedgerState :: Config -> Maybe UTxO -> LedgerState ByronBlock
- decodeByronAnnTip :: Decoder s ( AnnTip ByronBlock )
- decodeByronLedgerState :: Decoder s ( LedgerState ByronBlock )
- decodeByronQuery :: Decoder s ( SomeSecond BlockQuery ByronBlock )
- decodeByronResult :: BlockQuery ByronBlock result -> forall s. Decoder s result
- encodeByronAnnTip :: AnnTip ByronBlock -> Encoding
- encodeByronExtLedgerState :: ExtLedgerState ByronBlock -> Encoding
- encodeByronHeaderState :: HeaderState ByronBlock -> Encoding
- encodeByronLedgerState :: LedgerState ByronBlock -> Encoding
- encodeByronQuery :: BlockQuery ByronBlock result -> Encoding
- encodeByronResult :: BlockQuery ByronBlock result -> result -> Encoding
- data family BlockQuery blk :: Type -> Type
- data family LedgerState blk
- data family Ticked st
- validationErrorImpossible :: forall err a. Except err a -> a
Documentation
data ByronTransition Source #
Information required to determine the transition from Byron to Shelley
ByronTransitionInfo !( Map ProtocolVersion BlockNo ) |
Per candidate proposal, the
The HFC needs to know when a candidate proposal becomes stable. We cannot
reliably do this using
Invariant: the domain of this map should equal the set of candidate proposals. |
Instances
Ledger integration
byronEraParams :: Config -> EraParams Source #
To be used for a Byron-to-X (where X is typically Shelley) chain.
byronEraParamsNeverHardForks :: Config -> EraParams Source #
Separate variant of
byronEraParams
to be used for a Byron-only chain.
:: Config | |
-> Maybe UTxO |
Optionally override UTxO |
-> LedgerState ByronBlock |
Serialisation
decodeByronAnnTip :: Decoder s ( AnnTip ByronBlock ) Source #
decodeByronQuery :: Decoder s ( SomeSecond BlockQuery ByronBlock ) Source #
decodeByronResult :: BlockQuery ByronBlock result -> forall s. Decoder s result Source #
encodeByronQuery :: BlockQuery ByronBlock result -> Encoding Source #
encodeByronResult :: BlockQuery ByronBlock result -> result -> Encoding Source #
Type family instances
data family BlockQuery blk :: Type -> Type Source #
Different queries supported by the ledger, indexed by the result type.
Instances
data family LedgerState blk Source #
Ledger state associated with a block
Instances
data family Ticked st Source #
" Ticked " piece of state (
LedgerState
,
LedgerView
,
ChainIndepState
)
Ticking refers to the passage of time (the ticking of the clock). When a piece of state is marked as ticked, it means that time-related changes have been applied to the state (or forecast).
Some examples of time related changes:
- Scheduled delegations might have been applied in Byron
- New leader schedule computed for Shelley
- Transition from Byron to Shelley activated in the hard fork combinator.
- Nonces switched out at the start of a new epoch.
Instances
Auxiliary
validationErrorImpossible :: forall err a. Except err a -> a Source #
Mark computation as validation error free
Given a
BlockValidationMode
of
NoBlockValidation
, a call to
applyByronBlock
shouldn't fail since the ledger layer won't be performing
any block validation checks. However, because
applyByronBlock
can fail in
the event it is given a
BlockValidationMode
of
BlockValidation
, it still
looks
like it can fail (since its type doesn't change based on the
ValidationMode
) and we must still treat it as such.