{-# OPTIONS --safe #-} import Data.Maybe as M open import Ledger.Prelude open import Ledger.Crypto open import Ledger.Abstract open import Ledger.Transaction module Ledger.Conway.Conformance.Utxow.Properties (txs : _) (open TransactionStructure txs) (abs : AbstractFunctions txs) (open AbstractFunctions abs) where open import Ledger.Conway.Conformance.Utxow txs abs open import Ledger.Conway.Conformance.Utxo txs abs open import Ledger.Conway.Conformance.Utxo.Properties txs abs open import Tactic.GenError using (genErrors) instance Computational-UTXOW : Computational _⊢_⇀⦇_,UTXOW⦈_ String Computational-UTXOW = record {Go} where module Go Γ s tx (let H , ⁇ H? = UTXOW-inductive-premises {tx}{s}) where open Computational Computational-UTXO renaming (computeProof to computeProof'; completeness to completeness') computeProof : ComputationResult String (∃ (Γ ⊢ s ⇀⦇ tx ,UTXOW⦈_)) computeProof = case H? of λ where (yes (p₁ , p₂ , p₃ , p₄ , p₅ , p₆ , p₇ , p₈)) → map (map₂′ (UTXOW-inductive⋯ p₁ p₂ p₃ p₄ p₅ p₆ p₇ p₈)) (computeProof' Γ s tx) (no ¬p) → failure $ genErrors ¬p completeness : ∀ s' → Γ ⊢ s ⇀⦇ tx ,UTXOW⦈ s' → map proj₁ computeProof ≡ success s' completeness s' (UTXOW-inductive⋯ p₁ p₂ p₃ p₄ p₅ p₆ p₇ p₈ h) with H? ... | no ¬p = ⊥-elim $ ¬p ((p₁ , p₂ , p₃ , p₄ , p₅ , p₆ , p₇ , p₈)) ... | yes _ with computeProof' Γ s tx | completeness' _ _ _ _ h ... | success _ | refl = refl