amaru-uplc 0.1.0

A UPLC Evaluator as a CEK machine
Documentation
use crate::{arena::Arena, builtin::DefaultFunction};

use super::decode::FlatDecodeError;

pub fn try_from_tag(arena: &Arena, v: u8) -> Result<&DefaultFunction, FlatDecodeError> {
    match v {
        v if v == DefaultFunction::AddInteger as u8 => Ok(arena.alloc(DefaultFunction::AddInteger)),
        v if v == DefaultFunction::SubtractInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::SubtractInteger))
        }
        v if v == DefaultFunction::MultiplyInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::MultiplyInteger))
        }
        v if v == DefaultFunction::DivideInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::DivideInteger))
        }
        v if v == DefaultFunction::QuotientInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::QuotientInteger))
        }
        v if v == DefaultFunction::RemainderInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::RemainderInteger))
        }
        v if v == DefaultFunction::ModInteger as u8 => Ok(arena.alloc(DefaultFunction::ModInteger)),
        v if v == DefaultFunction::EqualsInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::EqualsInteger))
        }
        v if v == DefaultFunction::LessThanInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::LessThanInteger))
        }
        v if v == DefaultFunction::LessThanEqualsInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::LessThanEqualsInteger))
        }
        // ByteString functions
        v if v == DefaultFunction::AppendByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::AppendByteString))
        }
        v if v == DefaultFunction::ConsByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::ConsByteString))
        }
        v if v == DefaultFunction::SliceByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::SliceByteString))
        }
        v if v == DefaultFunction::LengthOfByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::LengthOfByteString))
        }
        v if v == DefaultFunction::IndexByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::IndexByteString))
        }
        v if v == DefaultFunction::EqualsByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::EqualsByteString))
        }
        v if v == DefaultFunction::LessThanByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::LessThanByteString))
        }
        v if v == DefaultFunction::LessThanEqualsByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::LessThanEqualsByteString))
        }
        // Cryptography and hash functions
        v if v == DefaultFunction::Sha2_256 as u8 => Ok(arena.alloc(DefaultFunction::Sha2_256)),
        v if v == DefaultFunction::Sha3_256 as u8 => Ok(arena.alloc(DefaultFunction::Sha3_256)),
        v if v == DefaultFunction::Blake2b_256 as u8 => {
            Ok(arena.alloc(DefaultFunction::Blake2b_256))
        }
        v if v == DefaultFunction::Blake2b_224 as u8 => {
            Ok(arena.alloc(DefaultFunction::Blake2b_224))
        }
        v if v == DefaultFunction::Keccak_256 as u8 => Ok(arena.alloc(DefaultFunction::Keccak_256)),
        v if v == DefaultFunction::VerifyEd25519Signature as u8 => {
            Ok(arena.alloc(DefaultFunction::VerifyEd25519Signature))
        }
        v if v == DefaultFunction::VerifyEcdsaSecp256k1Signature as u8 => {
            Ok(arena.alloc(DefaultFunction::VerifyEcdsaSecp256k1Signature))
        }
        v if v == DefaultFunction::VerifySchnorrSecp256k1Signature as u8 => {
            Ok(arena.alloc(DefaultFunction::VerifySchnorrSecp256k1Signature))
        }
        // String functions
        v if v == DefaultFunction::AppendString as u8 => {
            Ok(arena.alloc(DefaultFunction::AppendString))
        }
        v if v == DefaultFunction::EqualsString as u8 => {
            Ok(arena.alloc(DefaultFunction::EqualsString))
        }
        v if v == DefaultFunction::EncodeUtf8 as u8 => Ok(arena.alloc(DefaultFunction::EncodeUtf8)),
        v if v == DefaultFunction::DecodeUtf8 as u8 => Ok(arena.alloc(DefaultFunction::DecodeUtf8)),
        // Bool function
        v if v == DefaultFunction::IfThenElse as u8 => Ok(arena.alloc(DefaultFunction::IfThenElse)),
        // Unit function
        v if v == DefaultFunction::ChooseUnit as u8 => Ok(arena.alloc(DefaultFunction::ChooseUnit)),
        // Tracing function
        v if v == DefaultFunction::Trace as u8 => Ok(arena.alloc(DefaultFunction::Trace)),
        // Pairs functions
        v if v == DefaultFunction::FstPair as u8 => Ok(arena.alloc(DefaultFunction::FstPair)),
        v if v == DefaultFunction::SndPair as u8 => Ok(arena.alloc(DefaultFunction::SndPair)),
        // List functions
        v if v == DefaultFunction::ChooseList as u8 => Ok(arena.alloc(DefaultFunction::ChooseList)),
        v if v == DefaultFunction::MkCons as u8 => Ok(arena.alloc(DefaultFunction::MkCons)),
        v if v == DefaultFunction::HeadList as u8 => Ok(arena.alloc(DefaultFunction::HeadList)),
        v if v == DefaultFunction::TailList as u8 => Ok(arena.alloc(DefaultFunction::TailList)),
        v if v == DefaultFunction::NullList as u8 => Ok(arena.alloc(DefaultFunction::NullList)),
        // Data functions
        // It is convenient to have a "choosing" function for a data type that has more than two
        // constructors to get pattern matching over it and we may end up having multiple such data
        // types, hence we include the name of the data type as a suffix.
        v if v == DefaultFunction::ChooseData as u8 => Ok(arena.alloc(DefaultFunction::ChooseData)),
        v if v == DefaultFunction::ConstrData as u8 => Ok(arena.alloc(DefaultFunction::ConstrData)),
        v if v == DefaultFunction::MapData as u8 => Ok(arena.alloc(DefaultFunction::MapData)),
        v if v == DefaultFunction::ListData as u8 => Ok(arena.alloc(DefaultFunction::ListData)),
        v if v == DefaultFunction::IData as u8 => Ok(arena.alloc(DefaultFunction::IData)),
        v if v == DefaultFunction::BData as u8 => Ok(arena.alloc(DefaultFunction::BData)),
        v if v == DefaultFunction::UnConstrData as u8 => {
            Ok(arena.alloc(DefaultFunction::UnConstrData))
        }
        v if v == DefaultFunction::UnMapData as u8 => Ok(arena.alloc(DefaultFunction::UnMapData)),
        v if v == DefaultFunction::UnListData as u8 => Ok(arena.alloc(DefaultFunction::UnListData)),
        v if v == DefaultFunction::UnIData as u8 => Ok(arena.alloc(DefaultFunction::UnIData)),
        v if v == DefaultFunction::UnBData as u8 => Ok(arena.alloc(DefaultFunction::UnBData)),
        v if v == DefaultFunction::EqualsData as u8 => Ok(arena.alloc(DefaultFunction::EqualsData)),
        v if v == DefaultFunction::SerialiseData as u8 => {
            Ok(arena.alloc(DefaultFunction::SerialiseData))
        }
        // Misc constructors
        // Constructors that we need for constructing e.g. Data. Polymorphic builtin
        // constructors are often problematic (See note [Representable built-in
        // functions over polymorphic built-in types])
        v if v == DefaultFunction::MkPairData as u8 => Ok(arena.alloc(DefaultFunction::MkPairData)),
        v if v == DefaultFunction::MkNilData as u8 => Ok(arena.alloc(DefaultFunction::MkNilData)),
        v if v == DefaultFunction::MkNilPairData as u8 => {
            Ok(arena.alloc(DefaultFunction::MkNilPairData))
        }
        v if v == DefaultFunction::Bls12_381_G1_Add as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G1_Add))
        }
        v if v == DefaultFunction::Bls12_381_G1_Neg as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G1_Neg))
        }
        v if v == DefaultFunction::Bls12_381_G1_ScalarMul as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G1_ScalarMul))
        }
        v if v == DefaultFunction::Bls12_381_G1_Equal as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G1_Equal))
        }
        v if v == DefaultFunction::Bls12_381_G1_Compress as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G1_Compress))
        }
        v if v == DefaultFunction::Bls12_381_G1_Uncompress as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G1_Uncompress))
        }
        v if v == DefaultFunction::Bls12_381_G1_HashToGroup as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G1_HashToGroup))
        }
        v if v == DefaultFunction::Bls12_381_G2_Add as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G2_Add))
        }
        v if v == DefaultFunction::Bls12_381_G2_Neg as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G2_Neg))
        }
        v if v == DefaultFunction::Bls12_381_G2_ScalarMul as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G2_ScalarMul))
        }
        v if v == DefaultFunction::Bls12_381_G2_Equal as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G2_Equal))
        }
        v if v == DefaultFunction::Bls12_381_G2_Compress as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G2_Compress))
        }
        v if v == DefaultFunction::Bls12_381_G2_Uncompress as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G2_Uncompress))
        }
        v if v == DefaultFunction::Bls12_381_G2_HashToGroup as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_G2_HashToGroup))
        }
        v if v == DefaultFunction::Bls12_381_MillerLoop as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_MillerLoop))
        }
        v if v == DefaultFunction::Bls12_381_MulMlResult as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_MulMlResult))
        }
        v if v == DefaultFunction::Bls12_381_FinalVerify as u8 => {
            Ok(arena.alloc(DefaultFunction::Bls12_381_FinalVerify))
        }

        // Bitwise
        v if v == DefaultFunction::IntegerToByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::IntegerToByteString))
        }
        v if v == DefaultFunction::ByteStringToInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::ByteStringToInteger))
        }

        v if v == DefaultFunction::AndByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::AndByteString))
        }
        v if v == DefaultFunction::OrByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::OrByteString))
        }
        v if v == DefaultFunction::XorByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::XorByteString))
        }
        v if v == DefaultFunction::ComplementByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::ComplementByteString))
        }
        v if v == DefaultFunction::ReadBit as u8 => Ok(arena.alloc(DefaultFunction::ReadBit)),
        v if v == DefaultFunction::WriteBits as u8 => Ok(arena.alloc(DefaultFunction::WriteBits)),
        v if v == DefaultFunction::ReplicateByte as u8 => {
            Ok(arena.alloc(DefaultFunction::ReplicateByte))
        }
        v if v == DefaultFunction::ShiftByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::ShiftByteString))
        }
        v if v == DefaultFunction::RotateByteString as u8 => {
            Ok(arena.alloc(DefaultFunction::RotateByteString))
        }
        v if v == DefaultFunction::CountSetBits as u8 => {
            Ok(arena.alloc(DefaultFunction::CountSetBits))
        }
        v if v == DefaultFunction::FindFirstSetBit as u8 => {
            Ok(arena.alloc(DefaultFunction::FindFirstSetBit))
        }
        v if v == DefaultFunction::Ripemd_160 as u8 => Ok(arena.alloc(DefaultFunction::Ripemd_160)),

        v if v == DefaultFunction::ExpModInteger as u8 => {
            Ok(arena.alloc(DefaultFunction::ExpModInteger))
        }
        v if v == DefaultFunction::DropList as u8 => Ok(arena.alloc(DefaultFunction::DropList)),
        v if v == DefaultFunction::LengthOfArray as u8 => {
            Ok(arena.alloc(DefaultFunction::LengthOfArray))
        }
        v if v == DefaultFunction::ListToArray as u8 => {
            Ok(arena.alloc(DefaultFunction::ListToArray))
        }
        v if v == DefaultFunction::IndexArray as u8 => Ok(arena.alloc(DefaultFunction::IndexArray)),

        _ => Err(FlatDecodeError::DefaultFunctionNotFound(v)),
    }
}