{-# OPTIONS_GHC -fno-omit-interface-pragmas #-}
{-# OPTIONS_GHC -fno-ignore-interface-pragmas #-}
module PlutusTx.Builtins (
BuiltinByteString
, appendByteString
, consByteString
, sliceByteString
, lengthOfByteString
, indexByteString
, emptyByteString
, equalsByteString
, lessThanByteString
, lessThanEqualsByteString
, greaterThanByteString
, greaterThanEqualsByteString
, sha2_256
, sha3_256
, blake2b_256
, verifyEd25519Signature
, verifyEcdsaSecp256k1Signature
, verifySchnorrSecp256k1Signature
, decodeUtf8
, Integer
, addInteger
, subtractInteger
, multiplyInteger
, divideInteger
, modInteger
, quotientInteger
, remainderInteger
, greaterThanInteger
, greaterThanEqualsInteger
, lessThanInteger
, lessThanEqualsInteger
, equalsInteger
, error
, BuiltinData
, chooseData
, matchData
, matchData'
, equalsData
, serialiseData
, mkConstr
, mkMap
, mkList
, mkI
, mkB
, unsafeDataAsConstr
, unsafeDataAsMap
, unsafeDataAsList
, unsafeDataAsI
, unsafeDataAsB
, BI.builtinDataToData
, BI.dataToBuiltinData
, BuiltinString
, appendString
, emptyString
, equalsString
, encodeUtf8
, matchList
, trace
, fromBuiltin
, toBuiltin
) where
import PlutusTx.Base (const, uncurry)
import PlutusTx.Bool (Bool (..))
import PlutusTx.Builtins.Class
import PlutusTx.Builtins.Internal (BuiltinByteString (..), BuiltinData, BuiltinString)
import PlutusTx.Builtins.Internal qualified as BI
import PlutusTx.Integer (Integer)
{-# INLINABLE appendByteString #-}
appendByteString :: BuiltinByteString -> BuiltinByteString -> BuiltinByteString
appendByteString :: BuiltinByteString -> BuiltinByteString -> BuiltinByteString
appendByteString = BuiltinByteString -> BuiltinByteString -> BuiltinByteString
BI.appendByteString
{-# INLINABLE consByteString #-}
consByteString :: Integer -> BuiltinByteString -> BuiltinByteString
consByteString :: BuiltinInteger -> BuiltinByteString -> BuiltinByteString
consByteString BuiltinInteger
n BuiltinByteString
bs = BuiltinInteger -> BuiltinByteString -> BuiltinByteString
BI.consByteString (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
n) BuiltinByteString
bs
{-# INLINABLE sliceByteString #-}
sliceByteString :: Integer -> Integer -> BuiltinByteString -> BuiltinByteString
sliceByteString :: BuiltinInteger
-> BuiltinInteger -> BuiltinByteString -> BuiltinByteString
sliceByteString BuiltinInteger
start BuiltinInteger
n BuiltinByteString
bs = BuiltinInteger
-> BuiltinInteger -> BuiltinByteString -> BuiltinByteString
BI.sliceByteString (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
start) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
n) BuiltinByteString
bs
{-# INLINABLE lengthOfByteString #-}
lengthOfByteString :: BuiltinByteString -> Integer
lengthOfByteString :: BuiltinByteString -> BuiltinInteger
lengthOfByteString = BuiltinByteString -> BuiltinInteger
BI.lengthOfByteString
{-# INLINABLE indexByteString #-}
indexByteString :: BuiltinByteString -> Integer -> Integer
indexByteString :: BuiltinByteString -> BuiltinInteger -> BuiltinInteger
indexByteString BuiltinByteString
b BuiltinInteger
n = BuiltinByteString -> BuiltinInteger -> BuiltinInteger
BI.indexByteString BuiltinByteString
b (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
n)
{-# INLINABLE emptyByteString #-}
emptyByteString :: BuiltinByteString
emptyByteString :: BuiltinByteString
emptyByteString = BuiltinByteString
BI.emptyByteString
{-# INLINABLE sha2_256 #-}
sha2_256 :: BuiltinByteString -> BuiltinByteString
sha2_256 :: BuiltinByteString -> BuiltinByteString
sha2_256 = BuiltinByteString -> BuiltinByteString
BI.sha2_256
{-# INLINABLE sha3_256 #-}
sha3_256 :: BuiltinByteString -> BuiltinByteString
sha3_256 :: BuiltinByteString -> BuiltinByteString
sha3_256 = BuiltinByteString -> BuiltinByteString
BI.sha3_256
{-# INLINABLE blake2b_256 #-}
blake2b_256 :: BuiltinByteString -> BuiltinByteString
blake2b_256 :: BuiltinByteString -> BuiltinByteString
blake2b_256 = BuiltinByteString -> BuiltinByteString
BI.blake2b_256
{-# INLINABLE verifyEd25519Signature #-}
verifyEd25519Signature
:: BuiltinByteString
-> BuiltinByteString
-> BuiltinByteString
-> Bool
verifyEd25519Signature :: BuiltinByteString -> BuiltinByteString -> BuiltinByteString -> Bool
verifyEd25519Signature BuiltinByteString
pubKey BuiltinByteString
message BuiltinByteString
signature = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinByteString
-> BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.verifyEd25519Signature BuiltinByteString
pubKey BuiltinByteString
message BuiltinByteString
signature)
{-# INLINABLE equalsByteString #-}
equalsByteString :: BuiltinByteString -> BuiltinByteString -> Bool
equalsByteString :: BuiltinByteString -> BuiltinByteString -> Bool
equalsByteString BuiltinByteString
x BuiltinByteString
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.equalsByteString BuiltinByteString
x BuiltinByteString
y)
{-# INLINABLE lessThanByteString #-}
lessThanByteString :: BuiltinByteString -> BuiltinByteString -> Bool
lessThanByteString :: BuiltinByteString -> BuiltinByteString -> Bool
lessThanByteString BuiltinByteString
x BuiltinByteString
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.lessThanByteString BuiltinByteString
x BuiltinByteString
y)
{-# INLINABLE lessThanEqualsByteString #-}
lessThanEqualsByteString :: BuiltinByteString -> BuiltinByteString -> Bool
lessThanEqualsByteString :: BuiltinByteString -> BuiltinByteString -> Bool
lessThanEqualsByteString BuiltinByteString
x BuiltinByteString
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.lessThanEqualsByteString BuiltinByteString
x BuiltinByteString
y)
{-# INLINABLE greaterThanByteString #-}
greaterThanByteString :: BuiltinByteString -> BuiltinByteString -> Bool
greaterThanByteString :: BuiltinByteString -> BuiltinByteString -> Bool
greaterThanByteString BuiltinByteString
x BuiltinByteString
y = forall a. BuiltinBool -> a -> a -> a
BI.ifThenElse (BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.lessThanEqualsByteString BuiltinByteString
x BuiltinByteString
y) Bool
False Bool
True
{-# INLINABLE greaterThanEqualsByteString #-}
greaterThanEqualsByteString :: BuiltinByteString -> BuiltinByteString -> Bool
greaterThanEqualsByteString :: BuiltinByteString -> BuiltinByteString -> Bool
greaterThanEqualsByteString BuiltinByteString
x BuiltinByteString
y = forall a. BuiltinBool -> a -> a -> a
BI.ifThenElse (BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.lessThanByteString BuiltinByteString
x BuiltinByteString
y) Bool
False Bool
True
{-# INLINABLE decodeUtf8 #-}
decodeUtf8 :: BuiltinByteString -> BuiltinString
decodeUtf8 :: BuiltinByteString -> BuiltinString
decodeUtf8 = BuiltinByteString -> BuiltinString
BI.decodeUtf8
{-# INLINEABLE verifyEcdsaSecp256k1Signature #-}
verifyEcdsaSecp256k1Signature
:: BuiltinByteString
-> BuiltinByteString
-> BuiltinByteString
-> Bool
verifyEcdsaSecp256k1Signature :: BuiltinByteString -> BuiltinByteString -> BuiltinByteString -> Bool
verifyEcdsaSecp256k1Signature BuiltinByteString
vk BuiltinByteString
msg BuiltinByteString
sig =
forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinByteString
-> BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.verifyEcdsaSecp256k1Signature BuiltinByteString
vk BuiltinByteString
msg BuiltinByteString
sig)
{-# INLINEABLE verifySchnorrSecp256k1Signature #-}
verifySchnorrSecp256k1Signature
:: BuiltinByteString
-> BuiltinByteString
-> BuiltinByteString
-> Bool
verifySchnorrSecp256k1Signature :: BuiltinByteString -> BuiltinByteString -> BuiltinByteString -> Bool
verifySchnorrSecp256k1Signature BuiltinByteString
vk BuiltinByteString
msg BuiltinByteString
sig =
forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinByteString
-> BuiltinByteString -> BuiltinByteString -> BuiltinBool
BI.verifySchnorrSecp256k1Signature BuiltinByteString
vk BuiltinByteString
msg BuiltinByteString
sig)
{-# INLINABLE addInteger #-}
addInteger :: Integer -> Integer -> Integer
addInteger :: BuiltinInteger -> BuiltinInteger -> BuiltinInteger
addInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinInteger
BI.addInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE subtractInteger #-}
subtractInteger :: Integer -> Integer -> Integer
subtractInteger :: BuiltinInteger -> BuiltinInteger -> BuiltinInteger
subtractInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinInteger
BI.subtractInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE multiplyInteger #-}
multiplyInteger :: Integer -> Integer -> Integer
multiplyInteger :: BuiltinInteger -> BuiltinInteger -> BuiltinInteger
multiplyInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinInteger
BI.multiplyInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE divideInteger #-}
divideInteger :: Integer -> Integer -> Integer
divideInteger :: BuiltinInteger -> BuiltinInteger -> BuiltinInteger
divideInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinInteger
BI.divideInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE modInteger #-}
modInteger :: Integer -> Integer -> Integer
modInteger :: BuiltinInteger -> BuiltinInteger -> BuiltinInteger
modInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinInteger
BI.modInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE quotientInteger #-}
quotientInteger :: Integer -> Integer -> Integer
quotientInteger :: BuiltinInteger -> BuiltinInteger -> BuiltinInteger
quotientInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinInteger
BI.quotientInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE remainderInteger #-}
remainderInteger :: Integer -> Integer -> Integer
remainderInteger :: BuiltinInteger -> BuiltinInteger -> BuiltinInteger
remainderInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinInteger
BI.remainderInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE greaterThanInteger #-}
greaterThanInteger :: Integer -> Integer -> Bool
greaterThanInteger :: BuiltinInteger -> BuiltinInteger -> Bool
greaterThanInteger BuiltinInteger
x BuiltinInteger
y = forall a. BuiltinBool -> a -> a -> a
BI.ifThenElse (BuiltinInteger -> BuiltinInteger -> BuiltinBool
BI.lessThanEqualsInteger BuiltinInteger
x BuiltinInteger
y ) Bool
False Bool
True
{-# INLINABLE greaterThanEqualsInteger #-}
greaterThanEqualsInteger :: Integer -> Integer -> Bool
greaterThanEqualsInteger :: BuiltinInteger -> BuiltinInteger -> Bool
greaterThanEqualsInteger BuiltinInteger
x BuiltinInteger
y = forall a. BuiltinBool -> a -> a -> a
BI.ifThenElse (BuiltinInteger -> BuiltinInteger -> BuiltinBool
BI.lessThanInteger BuiltinInteger
x BuiltinInteger
y) Bool
False Bool
True
{-# INLINABLE lessThanInteger #-}
lessThanInteger :: Integer -> Integer -> Bool
lessThanInteger :: BuiltinInteger -> BuiltinInteger -> Bool
lessThanInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinBool
BI.lessThanInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE lessThanEqualsInteger #-}
lessThanEqualsInteger :: Integer -> Integer -> Bool
lessThanEqualsInteger :: BuiltinInteger -> BuiltinInteger -> Bool
lessThanEqualsInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinBool
BI.lessThanEqualsInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE equalsInteger #-}
equalsInteger :: Integer -> Integer -> Bool
equalsInteger :: BuiltinInteger -> BuiltinInteger -> Bool
equalsInteger BuiltinInteger
x BuiltinInteger
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinInteger -> BuiltinInteger -> BuiltinBool
BI.equalsInteger (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
x) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
y))
{-# INLINABLE error #-}
error :: () -> a
error :: forall a. () -> a
error ()
x = forall a. BuiltinUnit -> a
BI.error (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin ()
x)
{-# INLINABLE appendString #-}
appendString :: BuiltinString -> BuiltinString -> BuiltinString
appendString :: BuiltinString -> BuiltinString -> BuiltinString
appendString = BuiltinString -> BuiltinString -> BuiltinString
BI.appendString
{-# INLINABLE emptyString #-}
emptyString :: BuiltinString
emptyString :: BuiltinString
emptyString = BuiltinString
BI.emptyString
{-# INLINABLE equalsString #-}
equalsString :: BuiltinString -> BuiltinString -> Bool
equalsString :: BuiltinString -> BuiltinString -> Bool
equalsString BuiltinString
x BuiltinString
y = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinString -> BuiltinString -> BuiltinBool
BI.equalsString BuiltinString
x BuiltinString
y)
{-# INLINABLE trace #-}
trace :: BuiltinString -> a -> a
trace :: forall a. BuiltinString -> a -> a
trace = forall a. BuiltinString -> a -> a
BI.trace
{-# INLINABLE encodeUtf8 #-}
encodeUtf8 :: BuiltinString -> BuiltinByteString
encodeUtf8 :: BuiltinString -> BuiltinByteString
encodeUtf8 = BuiltinString -> BuiltinByteString
BI.encodeUtf8
matchList :: forall a r . BI.BuiltinList a -> r -> (a -> BI.BuiltinList a -> r) -> r
matchList :: forall a r. BuiltinList a -> r -> (a -> BuiltinList a -> r) -> r
matchList BuiltinList a
l r
nilCase a -> BuiltinList a -> r
consCase = forall a b. BuiltinList a -> b -> b -> b
BI.chooseList BuiltinList a
l (forall a b. a -> b -> a
const r
nilCase) (\()
_ -> a -> BuiltinList a -> r
consCase (forall a. BuiltinList a -> a
BI.head BuiltinList a
l) (forall a. BuiltinList a -> BuiltinList a
BI.tail BuiltinList a
l)) ()
{-# INLINABLE chooseData #-}
chooseData :: forall a . BuiltinData -> a -> a -> a -> a -> a -> a
chooseData :: forall a. BuiltinData -> a -> a -> a -> a -> a -> a
chooseData = forall a. BuiltinData -> a -> a -> a -> a -> a -> a
BI.chooseData
{-# INLINABLE serialiseData #-}
serialiseData :: BuiltinData -> BuiltinByteString
serialiseData :: BuiltinData -> BuiltinByteString
serialiseData = BuiltinData -> BuiltinByteString
BI.serialiseData
{-# INLINABLE mkConstr #-}
mkConstr :: Integer -> [BuiltinData] -> BuiltinData
mkConstr :: BuiltinInteger -> [BuiltinData] -> BuiltinData
mkConstr BuiltinInteger
i [BuiltinData]
args = BuiltinInteger -> BuiltinList BuiltinData -> BuiltinData
BI.mkConstr (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin BuiltinInteger
i) (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin [BuiltinData]
args)
{-# INLINABLE mkMap #-}
mkMap :: [(BuiltinData, BuiltinData)] -> BuiltinData
mkMap :: [(BuiltinData, BuiltinData)] -> BuiltinData
mkMap [(BuiltinData, BuiltinData)]
es = BuiltinList (BuiltinPair BuiltinData BuiltinData) -> BuiltinData
BI.mkMap (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin [(BuiltinData, BuiltinData)]
es)
{-# INLINABLE mkList #-}
mkList :: [BuiltinData] -> BuiltinData
mkList :: [BuiltinData] -> BuiltinData
mkList [BuiltinData]
l = BuiltinList BuiltinData -> BuiltinData
BI.mkList (forall a arep. ToBuiltin a arep => a -> arep
toBuiltin [BuiltinData]
l)
{-# INLINABLE mkI #-}
mkI :: Integer -> BuiltinData
mkI :: BuiltinInteger -> BuiltinData
mkI = BuiltinInteger -> BuiltinData
BI.mkI
{-# INLINABLE mkB #-}
mkB :: BuiltinByteString -> BuiltinData
mkB :: BuiltinByteString -> BuiltinData
mkB = BuiltinByteString -> BuiltinData
BI.mkB
{-# INLINABLE unsafeDataAsConstr #-}
unsafeDataAsConstr :: BuiltinData -> (Integer, [BuiltinData])
unsafeDataAsConstr :: BuiltinData -> (BuiltinInteger, [BuiltinData])
unsafeDataAsConstr BuiltinData
d = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinData -> BuiltinPair BuiltinInteger (BuiltinList BuiltinData)
BI.unsafeDataAsConstr BuiltinData
d)
{-# INLINABLE unsafeDataAsMap #-}
unsafeDataAsMap :: BuiltinData -> [(BuiltinData, BuiltinData)]
unsafeDataAsMap :: BuiltinData -> [(BuiltinData, BuiltinData)]
unsafeDataAsMap BuiltinData
d = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinData -> BuiltinList (BuiltinPair BuiltinData BuiltinData)
BI.unsafeDataAsMap BuiltinData
d)
{-# INLINABLE unsafeDataAsList #-}
unsafeDataAsList :: BuiltinData -> [BuiltinData]
unsafeDataAsList :: BuiltinData -> [BuiltinData]
unsafeDataAsList BuiltinData
d = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinData -> BuiltinList BuiltinData
BI.unsafeDataAsList BuiltinData
d)
{-# INLINABLE unsafeDataAsI #-}
unsafeDataAsI :: BuiltinData -> Integer
unsafeDataAsI :: BuiltinData -> BuiltinInteger
unsafeDataAsI BuiltinData
d = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinData -> BuiltinInteger
BI.unsafeDataAsI BuiltinData
d)
{-# INLINABLE unsafeDataAsB #-}
unsafeDataAsB :: BuiltinData -> BuiltinByteString
unsafeDataAsB :: BuiltinData -> BuiltinByteString
unsafeDataAsB = BuiltinData -> BuiltinByteString
BI.unsafeDataAsB
{-# INLINABLE equalsData #-}
equalsData :: BuiltinData -> BuiltinData -> Bool
equalsData :: BuiltinData -> BuiltinData -> Bool
equalsData BuiltinData
d1 BuiltinData
d2 = forall arep a. FromBuiltin arep a => arep -> a
fromBuiltin (BuiltinData -> BuiltinData -> BuiltinBool
BI.equalsData BuiltinData
d1 BuiltinData
d2)
{-# INLINABLE matchData #-}
matchData
:: BuiltinData
-> (Integer -> [BuiltinData] -> r)
-> ([(BuiltinData, BuiltinData)] -> r)
-> ([BuiltinData] -> r)
-> (Integer -> r)
-> (BuiltinByteString -> r)
-> r
matchData :: forall r.
BuiltinData
-> (BuiltinInteger -> [BuiltinData] -> r)
-> ([(BuiltinData, BuiltinData)] -> r)
-> ([BuiltinData] -> r)
-> (BuiltinInteger -> r)
-> (BuiltinByteString -> r)
-> r
matchData BuiltinData
d BuiltinInteger -> [BuiltinData] -> r
constrCase [(BuiltinData, BuiltinData)] -> r
mapCase [BuiltinData] -> r
listCase BuiltinInteger -> r
iCase BuiltinByteString -> r
bCase =
forall a. BuiltinData -> a -> a -> a -> a -> a -> a
chooseData
BuiltinData
d
(\()
_ -> forall a b c. (a -> b -> c) -> (a, b) -> c
uncurry BuiltinInteger -> [BuiltinData] -> r
constrCase (BuiltinData -> (BuiltinInteger, [BuiltinData])
unsafeDataAsConstr BuiltinData
d))
(\()
_ -> [(BuiltinData, BuiltinData)] -> r
mapCase (BuiltinData -> [(BuiltinData, BuiltinData)]
unsafeDataAsMap BuiltinData
d))
(\()
_ -> [BuiltinData] -> r
listCase (BuiltinData -> [BuiltinData]
unsafeDataAsList BuiltinData
d))
(\()
_ -> BuiltinInteger -> r
iCase (BuiltinData -> BuiltinInteger
unsafeDataAsI BuiltinData
d))
(\()
_ -> BuiltinByteString -> r
bCase (BuiltinData -> BuiltinByteString
unsafeDataAsB BuiltinData
d))
()
{-# INLINABLE matchData' #-}
matchData'
:: BuiltinData
-> (Integer -> BI.BuiltinList BuiltinData -> r)
-> (BI.BuiltinList (BI.BuiltinPair BuiltinData BuiltinData) -> r)
-> (BI.BuiltinList BuiltinData -> r)
-> (Integer -> r)
-> (BuiltinByteString -> r)
-> r
matchData' :: forall r.
BuiltinData
-> (BuiltinInteger -> BuiltinList BuiltinData -> r)
-> (BuiltinList (BuiltinPair BuiltinData BuiltinData) -> r)
-> (BuiltinList BuiltinData -> r)
-> (BuiltinInteger -> r)
-> (BuiltinByteString -> r)
-> r
matchData' BuiltinData
d BuiltinInteger -> BuiltinList BuiltinData -> r
constrCase BuiltinList (BuiltinPair BuiltinData BuiltinData) -> r
mapCase BuiltinList BuiltinData -> r
listCase BuiltinInteger -> r
iCase BuiltinByteString -> r
bCase =
forall a. BuiltinData -> a -> a -> a -> a -> a -> a
chooseData
BuiltinData
d
(\()
_ -> let tup :: BuiltinPair BuiltinInteger (BuiltinList BuiltinData)
tup = BuiltinData -> BuiltinPair BuiltinInteger (BuiltinList BuiltinData)
BI.unsafeDataAsConstr BuiltinData
d in BuiltinInteger -> BuiltinList BuiltinData -> r
constrCase (forall a b. BuiltinPair a b -> a
BI.fst BuiltinPair BuiltinInteger (BuiltinList BuiltinData)
tup) (forall a b. BuiltinPair a b -> b
BI.snd BuiltinPair BuiltinInteger (BuiltinList BuiltinData)
tup))
(\()
_ -> BuiltinList (BuiltinPair BuiltinData BuiltinData) -> r
mapCase (BuiltinData -> BuiltinList (BuiltinPair BuiltinData BuiltinData)
BI.unsafeDataAsMap BuiltinData
d))
(\()
_ -> BuiltinList BuiltinData -> r
listCase (BuiltinData -> BuiltinList BuiltinData
BI.unsafeDataAsList BuiltinData
d))
(\()
_ -> BuiltinInteger -> r
iCase (BuiltinData -> BuiltinInteger
unsafeDataAsI BuiltinData
d))
(\()
_ -> BuiltinByteString -> r
bCase (BuiltinData -> BuiltinByteString
unsafeDataAsB BuiltinData
d))
()