{-# LANGUAGE DeriveAnyClass #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE TypeFamilies #-}
module Ouroboros.Consensus.Storage.VolatileDB.Impl.FileInfo (
FileInfo
, addBlock
, empty
, fromParsedBlockInfos
, canGC
, hashes
, isFull
, maxSlotNo
, maxSlotNoInFiles
) where
import Data.Set (Set)
import qualified Data.Set as Set
import GHC.Generics (Generic)
import NoThunks.Class (NoThunks)
import Ouroboros.Consensus.Block
import Ouroboros.Consensus.Storage.VolatileDB.API (BlockInfo (..))
import Ouroboros.Consensus.Storage.VolatileDB.Impl.Parser
import Ouroboros.Consensus.Storage.VolatileDB.Impl.Types
import Ouroboros.Network.Block (MaxSlotNo (..))
data FileInfo blk = FileInfo {
forall blk. FileInfo blk -> MaxSlotNo
maxSlotNo :: !MaxSlotNo
, forall blk. FileInfo blk -> Set (HeaderHash blk)
hashes :: !(Set (HeaderHash blk))
}
deriving ((forall x. FileInfo blk -> Rep (FileInfo blk) x)
-> (forall x. Rep (FileInfo blk) x -> FileInfo blk)
-> Generic (FileInfo blk)
forall x. Rep (FileInfo blk) x -> FileInfo blk
forall x. FileInfo blk -> Rep (FileInfo blk) x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
forall blk x. Rep (FileInfo blk) x -> FileInfo blk
forall blk x. FileInfo blk -> Rep (FileInfo blk) x
$cfrom :: forall blk x. FileInfo blk -> Rep (FileInfo blk) x
from :: forall x. FileInfo blk -> Rep (FileInfo blk) x
$cto :: forall blk x. Rep (FileInfo blk) x -> FileInfo blk
to :: forall x. Rep (FileInfo blk) x -> FileInfo blk
Generic)
deriving instance StandardHash blk => Show (FileInfo blk)
deriving instance StandardHash blk => NoThunks (FileInfo blk)
empty :: FileInfo blk
empty :: forall blk. FileInfo blk
empty = FileInfo {
maxSlotNo :: MaxSlotNo
maxSlotNo = MaxSlotNo
NoMaxSlotNo
, hashes :: Set (HeaderHash blk)
hashes = Set (HeaderHash blk)
forall a. Set a
Set.empty
}
addBlock :: StandardHash blk => SlotNo -> HeaderHash blk -> FileInfo blk -> FileInfo blk
addBlock :: forall blk.
StandardHash blk =>
SlotNo -> HeaderHash blk -> FileInfo blk -> FileInfo blk
addBlock SlotNo
slotNo HeaderHash blk
hash FileInfo { MaxSlotNo
maxSlotNo :: forall blk. FileInfo blk -> MaxSlotNo
maxSlotNo :: MaxSlotNo
maxSlotNo, Set (HeaderHash blk)
hashes :: forall blk. FileInfo blk -> Set (HeaderHash blk)
hashes :: Set (HeaderHash blk)
hashes } =
FileInfo {
maxSlotNo :: MaxSlotNo
maxSlotNo = MaxSlotNo
maxSlotNo MaxSlotNo -> MaxSlotNo -> MaxSlotNo
forall a. Ord a => a -> a -> a
`max` SlotNo -> MaxSlotNo
MaxSlotNo SlotNo
slotNo
, hashes :: Set (HeaderHash blk)
hashes = HeaderHash blk -> Set (HeaderHash blk) -> Set (HeaderHash blk)
forall a. Ord a => a -> Set a -> Set a
Set.insert HeaderHash blk
hash Set (HeaderHash blk)
hashes
}
fromParsedBlockInfos ::
forall blk. StandardHash blk
=> [ParsedBlockInfo blk] -> FileInfo blk
fromParsedBlockInfos :: forall blk.
StandardHash blk =>
[ParsedBlockInfo blk] -> FileInfo blk
fromParsedBlockInfos [ParsedBlockInfo blk]
parsedBlockInfos = FileInfo {
maxSlotNo :: MaxSlotNo
maxSlotNo = (ParsedBlockInfo blk -> MaxSlotNo)
-> [ParsedBlockInfo blk] -> MaxSlotNo
forall m a. Monoid m => (a -> m) -> [a] -> m
forall (t :: * -> *) m a.
(Foldable t, Monoid m) =>
(a -> m) -> t a -> m
foldMap ParsedBlockInfo blk -> MaxSlotNo
parsedBlockInfoToMaxSlotNo [ParsedBlockInfo blk]
parsedBlockInfos
, hashes :: Set (HeaderHash blk)
hashes = [HeaderHash blk] -> Set (HeaderHash blk)
forall a. Ord a => [a] -> Set a
Set.fromList ([HeaderHash blk] -> Set (HeaderHash blk))
-> [HeaderHash blk] -> Set (HeaderHash blk)
forall a b. (a -> b) -> a -> b
$ (ParsedBlockInfo blk -> HeaderHash blk)
-> [ParsedBlockInfo blk] -> [HeaderHash blk]
forall a b. (a -> b) -> [a] -> [b]
map (BlockInfo blk -> HeaderHash blk
forall blk. BlockInfo blk -> HeaderHash blk
biHash (BlockInfo blk -> HeaderHash blk)
-> (ParsedBlockInfo blk -> BlockInfo blk)
-> ParsedBlockInfo blk
-> HeaderHash blk
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ParsedBlockInfo blk -> BlockInfo blk
forall blk. ParsedBlockInfo blk -> BlockInfo blk
pbiBlockInfo) [ParsedBlockInfo blk]
parsedBlockInfos
}
where
parsedBlockInfoToMaxSlotNo :: ParsedBlockInfo blk -> MaxSlotNo
parsedBlockInfoToMaxSlotNo :: ParsedBlockInfo blk -> MaxSlotNo
parsedBlockInfoToMaxSlotNo = SlotNo -> MaxSlotNo
MaxSlotNo (SlotNo -> MaxSlotNo)
-> (ParsedBlockInfo blk -> SlotNo)
-> ParsedBlockInfo blk
-> MaxSlotNo
forall b c a. (b -> c) -> (a -> b) -> a -> c
. BlockInfo blk -> SlotNo
forall blk. BlockInfo blk -> SlotNo
biSlotNo (BlockInfo blk -> SlotNo)
-> (ParsedBlockInfo blk -> BlockInfo blk)
-> ParsedBlockInfo blk
-> SlotNo
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ParsedBlockInfo blk -> BlockInfo blk
forall blk. ParsedBlockInfo blk -> BlockInfo blk
pbiBlockInfo
canGC ::
FileInfo blk
-> SlotNo
-> Bool
canGC :: forall blk. FileInfo blk -> SlotNo -> Bool
canGC FileInfo { MaxSlotNo
maxSlotNo :: forall blk. FileInfo blk -> MaxSlotNo
maxSlotNo :: MaxSlotNo
maxSlotNo } SlotNo
slot =
case MaxSlotNo
maxSlotNo of
MaxSlotNo
NoMaxSlotNo -> Bool
True
MaxSlotNo SlotNo
latest -> SlotNo
latest SlotNo -> SlotNo -> Bool
forall a. Ord a => a -> a -> Bool
< SlotNo
slot
isFull :: BlocksPerFile -> FileInfo blk -> Bool
isFull :: forall blk. BlocksPerFile -> FileInfo blk -> Bool
isFull BlocksPerFile
maxBlocksPerFile FileInfo { Set (HeaderHash blk)
hashes :: forall blk. FileInfo blk -> Set (HeaderHash blk)
hashes :: Set (HeaderHash blk)
hashes } =
Int -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (Set (HeaderHash blk) -> Int
forall a. Set a -> Int
Set.size Set (HeaderHash blk)
hashes) Word32 -> Word32 -> Bool
forall a. Ord a => a -> a -> Bool
>= BlocksPerFile -> Word32
unBlocksPerFile BlocksPerFile
maxBlocksPerFile
maxSlotNoInFiles :: [FileInfo blk] -> MaxSlotNo
maxSlotNoInFiles :: forall blk. [FileInfo blk] -> MaxSlotNo
maxSlotNoInFiles = (FileInfo blk -> MaxSlotNo) -> [FileInfo blk] -> MaxSlotNo
forall m a. Monoid m => (a -> m) -> [a] -> m
forall (t :: * -> *) m a.
(Foldable t, Monoid m) =>
(a -> m) -> t a -> m
foldMap FileInfo blk -> MaxSlotNo
forall blk. FileInfo blk -> MaxSlotNo
maxSlotNo