{-# OPTIONS --safe #-}
open import Ledger.Dijkstra.Specification.Transaction using (TransactionStructure)
open import Ledger.Dijkstra.Specification.Abstract using (AbstractFunctions)
module Ledger.Dijkstra.Specification.BlockBody.Properties.Computational
  (txs : TransactionStructure) (open TransactionStructure txs)
  (abs : AbstractFunctions txs) (open AbstractFunctions abs)
  where

open import Data.String.Base using () renaming (_++_ to _+ˢ_)
open import Ledger.Prelude
open import Ledger.Dijkstra.Specification.BlockBody txs abs
open import Ledger.Dijkstra.Specification.Enact govStructure
open import Ledger.Core.Specification.Epoch
open import Ledger.Dijkstra.Specification.Ledger.Properties.Computational txs abs
open import Ledger.Dijkstra.Specification.Utxo txs abs
open Computational ⦃...⦄
open Block


BBODY-computeProof : (Γ : BBodyEnv) (s : BBodyState) (block : Block)
   ComputationResult String (∃[ s' ] Γ  s ⇀⦇ block ,BBODY⦈ s')


BBODY-computeProof Γ (ls , _) block
  using maxBlockExUnitsPParams.maxBlockExUnits (PParamsOf (proj₁ Γ))
  using sumTotExUnits(∑ˡ[ tx  block .ts ] totExUnits tx)
  with ¿ maxBlockExUnits ≥ᵉ sumTotExUnits ¿
... | yes p = do
  _ , lsStep  computeProof _ ls (block .ts)
  success (_ , BBODY-Block-Body (block .≡-bBodySize , block .≡-bBodyHash , p , lsStep))
... | no _ = failure $
  "Block ExUnits constraint failed: total tx ExUnits "
   show sumTotExUnits
   " exceeds maxBlockExUnits "
   show maxBlockExUnits


BBODY-completeness : (Γ : BBodyEnv) (s : BBodyState) (block : Block) (s' : BBodyState)
   Γ  s ⇀⦇ block ,BBODY⦈ s'
   map proj₁ (BBODY-computeProof Γ s block)  success s'


BBODY-completeness Γ s block _ (BBODY-Block-Body (_ , _ , p , lsStep))
  using maxBlockExUnitsPParams.maxBlockExUnits (PParamsOf (proj₁ Γ))
  using sumTotExUnits(∑ˡ[ tx  block .ts ] totExUnits tx)
  with ¿ maxBlockExUnits ≥ᵉ sumTotExUnits ¿
... | no ¬p = ⊥-elim $ ¬p p
... | yes _
    with recomputeProof lsStep | completeness _ _ _ _ lsStep
...    | success _ | refl = refl

instance


  Computational-BBODY : Computational _⊢_⇀⦇_,BBODY⦈_ String
  Computational-BBODY .computeProof = BBODY-computeProof
  Computational-BBODY .completeness = BBODY-completeness