module Lorentz.Address
( TAddress (..)
, FutureContract (..)
, asAddressOf
, asAddressOf_
, callingAddress
, callingDefAddress
, callingTAddress
, callingDefTAddress
, ToAddress (..)
, ToTAddress (..)
, ToTAddress_
, toTAddress_
, ToContractRef (..)
, FromContractRef (..)
, convertContractRef
, Address
, EpAddress (..)
, ContractRef (..)
, M.coerceContractRef
) where
import Data.Type.Bool (Not, type (&&))
import Fmt (Buildable)
import Lorentz.Annotation
import Lorentz.Base
import Lorentz.Constraints
import qualified Lorentz.Entrypoints.Core as Ep
import Morley.Michelson.Typed (ContractRef(..), IsoValue(..))
import qualified Morley.Michelson.Typed as M
import Morley.Michelson.Typed.Entrypoints (EpAddress(..))
import Morley.Tezos.Address (Address)
import Morley.Util.Type
import Morley.Util.TypeLits
newtype TAddress (p :: Type) (vd :: Type) = TAddress { TAddress p vd -> Address
unTAddress :: Address }
deriving stock ((forall x. TAddress p vd -> Rep (TAddress p vd) x)
-> (forall x. Rep (TAddress p vd) x -> TAddress p vd)
-> Generic (TAddress p vd)
forall x. Rep (TAddress p vd) x -> TAddress p vd
forall x. TAddress p vd -> Rep (TAddress p vd) x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
forall p vd x. Rep (TAddress p vd) x -> TAddress p vd
forall p vd x. TAddress p vd -> Rep (TAddress p vd) x
$cto :: forall p vd x. Rep (TAddress p vd) x -> TAddress p vd
$cfrom :: forall p vd x. TAddress p vd -> Rep (TAddress p vd) x
Generic, Int -> TAddress p vd -> ShowS
[TAddress p vd] -> ShowS
TAddress p vd -> String
(Int -> TAddress p vd -> ShowS)
-> (TAddress p vd -> String)
-> ([TAddress p vd] -> ShowS)
-> Show (TAddress p vd)
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
forall p vd. Int -> TAddress p vd -> ShowS
forall p vd. [TAddress p vd] -> ShowS
forall p vd. TAddress p vd -> String
showList :: [TAddress p vd] -> ShowS
$cshowList :: forall p vd. [TAddress p vd] -> ShowS
show :: TAddress p vd -> String
$cshow :: forall p vd. TAddress p vd -> String
showsPrec :: Int -> TAddress p vd -> ShowS
$cshowsPrec :: forall p vd. Int -> TAddress p vd -> ShowS
Show)
deriving newtype (TAddress p vd -> TAddress p vd -> Bool
(TAddress p vd -> TAddress p vd -> Bool)
-> (TAddress p vd -> TAddress p vd -> Bool) -> Eq (TAddress p vd)
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
forall p vd. TAddress p vd -> TAddress p vd -> Bool
/= :: TAddress p vd -> TAddress p vd -> Bool
$c/= :: forall p vd. TAddress p vd -> TAddress p vd -> Bool
== :: TAddress p vd -> TAddress p vd -> Bool
$c== :: forall p vd. TAddress p vd -> TAddress p vd -> Bool
Eq, Eq (TAddress p vd)
Eq (TAddress p vd)
-> (TAddress p vd -> TAddress p vd -> Ordering)
-> (TAddress p vd -> TAddress p vd -> Bool)
-> (TAddress p vd -> TAddress p vd -> Bool)
-> (TAddress p vd -> TAddress p vd -> Bool)
-> (TAddress p vd -> TAddress p vd -> Bool)
-> (TAddress p vd -> TAddress p vd -> TAddress p vd)
-> (TAddress p vd -> TAddress p vd -> TAddress p vd)
-> Ord (TAddress p vd)
TAddress p vd -> TAddress p vd -> Bool
TAddress p vd -> TAddress p vd -> Ordering
TAddress p vd -> TAddress p vd -> TAddress p vd
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
forall p vd. Eq (TAddress p vd)
forall p vd. TAddress p vd -> TAddress p vd -> Bool
forall p vd. TAddress p vd -> TAddress p vd -> Ordering
forall p vd. TAddress p vd -> TAddress p vd -> TAddress p vd
min :: TAddress p vd -> TAddress p vd -> TAddress p vd
$cmin :: forall p vd. TAddress p vd -> TAddress p vd -> TAddress p vd
max :: TAddress p vd -> TAddress p vd -> TAddress p vd
$cmax :: forall p vd. TAddress p vd -> TAddress p vd -> TAddress p vd
>= :: TAddress p vd -> TAddress p vd -> Bool
$c>= :: forall p vd. TAddress p vd -> TAddress p vd -> Bool
> :: TAddress p vd -> TAddress p vd -> Bool
$c> :: forall p vd. TAddress p vd -> TAddress p vd -> Bool
<= :: TAddress p vd -> TAddress p vd -> Bool
$c<= :: forall p vd. TAddress p vd -> TAddress p vd -> Bool
< :: TAddress p vd -> TAddress p vd -> Bool
$c< :: forall p vd. TAddress p vd -> TAddress p vd -> Bool
compare :: TAddress p vd -> TAddress p vd -> Ordering
$ccompare :: forall p vd. TAddress p vd -> TAddress p vd -> Ordering
$cp1Ord :: forall p vd. Eq (TAddress p vd)
Ord, TAddress p vd -> Builder
(TAddress p vd -> Builder) -> Buildable (TAddress p vd)
forall p. (p -> Builder) -> Buildable p
forall p vd. TAddress p vd -> Builder
build :: TAddress p vd -> Builder
$cbuild :: forall p vd. TAddress p vd -> Builder
Buildable)
deriving anyclass (WellTypedToT (TAddress p vd)
WellTypedToT (TAddress p vd)
-> (TAddress p vd -> Value (ToT (TAddress p vd)))
-> (Value (ToT (TAddress p vd)) -> TAddress p vd)
-> IsoValue (TAddress p vd)
Value (ToT (TAddress p vd)) -> TAddress p vd
TAddress p vd -> Value (ToT (TAddress p vd))
forall a.
WellTypedToT a
-> (a -> Value (ToT a)) -> (Value (ToT a) -> a) -> IsoValue a
forall p vd. WellTypedToT (TAddress p vd)
forall p vd. Value (ToT (TAddress p vd)) -> TAddress p vd
forall p vd. TAddress p vd -> Value (ToT (TAddress p vd))
fromVal :: Value (ToT (TAddress p vd)) -> TAddress p vd
$cfromVal :: forall p vd. Value (ToT (TAddress p vd)) -> TAddress p vd
toVal :: TAddress p vd -> Value (ToT (TAddress p vd))
$ctoVal :: forall p vd. TAddress p vd -> Value (ToT (TAddress p vd))
$cp1IsoValue :: forall p vd. WellTypedToT (TAddress p vd)
IsoValue, AnnOptions
FollowEntrypointFlag -> Notes (ToT (TAddress p vd))
(FollowEntrypointFlag -> Notes (ToT (TAddress p vd)))
-> AnnOptions -> HasAnnotation (TAddress p vd)
forall a.
(FollowEntrypointFlag -> Notes (ToT a))
-> AnnOptions -> HasAnnotation a
forall p vd. AnnOptions
forall p vd. FollowEntrypointFlag -> Notes (ToT (TAddress p vd))
annOptions :: AnnOptions
$cannOptions :: forall p vd. AnnOptions
getAnnotation :: FollowEntrypointFlag -> Notes (ToT (TAddress p vd))
$cgetAnnotation :: forall p vd. FollowEntrypointFlag -> Notes (ToT (TAddress p vd))
HasAnnotation)
asAddressOf :: contract cp st vd -> Address -> TAddress cp vd
asAddressOf :: contract cp st vd -> Address -> TAddress cp vd
asAddressOf contract cp st vd
_ = Address -> TAddress cp vd
forall p vd. Address -> TAddress p vd
TAddress
asAddressOf_ :: contract cp st vd -> Address : s :-> TAddress cp vd : s
asAddressOf_ :: contract cp st vd -> (Address : s) :-> (TAddress cp vd : s)
asAddressOf_ contract cp st vd
_ = Instr (ToTs (Address : s)) (ToTs (TAddress cp vd : s))
-> (Address : s) :-> (TAddress cp vd : s)
forall (inp :: [*]) (out :: [*]).
Instr (ToTs inp) (ToTs out) -> inp :-> out
I Instr (ToTs (Address : s)) (ToTs (TAddress cp vd : s))
forall (inp :: [T]). Instr inp inp
M.Nop
callingTAddress
:: forall cp vd mname.
(NiceParameterFull cp)
=> TAddress cp vd
-> Ep.EntrypointRef mname
-> ContractRef (Ep.GetEntrypointArgCustom cp mname)
callingTAddress :: TAddress cp vd
-> EntrypointRef mname
-> ContractRef (GetEntrypointArgCustom cp mname)
callingTAddress = forall addr (mname :: Maybe Symbol).
(ToTAddress cp vd addr, NiceParameterFull cp) =>
addr
-> EntrypointRef mname
-> ContractRef (GetEntrypointArgCustom cp mname)
forall cp vd addr (mname :: Maybe Symbol).
(ToTAddress cp vd addr, NiceParameterFull cp) =>
addr
-> EntrypointRef mname
-> ContractRef (GetEntrypointArgCustom cp mname)
callingAddress @cp @vd
{-# DEPRECATED callingTAddress "Use `callingAddress`" #-}
callingDefTAddress
:: forall cp vd.
(NiceParameterFull cp)
=> TAddress cp vd
-> ContractRef (Ep.GetDefaultEntrypointArg cp)
callingDefTAddress :: TAddress cp vd -> ContractRef (GetDefaultEntrypointArg cp)
callingDefTAddress TAddress cp vd
taddr = TAddress cp vd
-> EntrypointRef 'Nothing
-> ContractRef (GetEntrypointArgCustom cp 'Nothing)
forall cp vd (mname :: Maybe Symbol).
NiceParameterFull cp =>
TAddress cp vd
-> EntrypointRef mname
-> ContractRef (GetEntrypointArgCustom cp mname)
callingTAddress TAddress cp vd
taddr EntrypointRef 'Nothing
Ep.CallDefault
{-# DEPRECATED callingDefTAddress "Use `callingDefAddress`" #-}
callingAddress
:: forall cp vd addr mname.
(ToTAddress cp vd addr, NiceParameterFull cp)
=> addr
-> Ep.EntrypointRef mname
-> ContractRef (Ep.GetEntrypointArgCustom cp mname)
callingAddress :: addr
-> EntrypointRef mname
-> ContractRef (GetEntrypointArgCustom cp mname)
callingAddress (forall a. ToTAddress cp vd a => a -> TAddress cp vd
forall cp vd a. ToTAddress cp vd a => a -> TAddress cp vd
toTAddress @cp @vd -> TAddress Address
addr) EntrypointRef mname
epRef =
(((SingI (ToT cp), FailOnOperationFound (ContainsOp (ToT cp)),
FailOnNestedBigMapsFound (ContainsNestedBigMaps (ToT cp))),
KnownValue cp)
:- ParameterScope (ToT cp))
-> (ParameterScope (ToT cp) =>
ContractRef (GetEntrypointArgCustom cp mname))
-> ContractRef (GetEntrypointArgCustom cp mname)
forall (c :: Constraint) e r. HasDict c e => e -> (c => r) -> r
withDict (((SingI (ToT cp), FailOnOperationFound (ContainsOp (ToT cp)),
FailOnNestedBigMapsFound (ContainsNestedBigMaps (ToT cp))),
KnownValue cp)
:- ParameterScope (ToT cp)
forall a. NiceParameter a :- ParameterScope (ToT a)
niceParameterEvi @cp) ((ParameterScope (ToT cp) =>
ContractRef (GetEntrypointArgCustom cp mname))
-> ContractRef (GetEntrypointArgCustom cp mname))
-> (ParameterScope (ToT cp) =>
ContractRef (GetEntrypointArgCustom cp mname))
-> ContractRef (GetEntrypointArgCustom cp mname)
forall a b. (a -> b) -> a -> b
$
case EntrypointRef mname
-> EntrypointCall cp (GetEntrypointArgCustom cp mname)
forall cp (mname :: Maybe Symbol).
ParameterDeclaresEntrypoints cp =>
EntrypointRef mname
-> EntrypointCall cp (GetEntrypointArgCustom cp mname)
Ep.parameterEntrypointCallCustom @cp EntrypointRef mname
epRef of
epc :: EntrypointCall cp (GetEntrypointArgCustom cp mname)
epc@M.EntrypointCall{} -> Address
-> SomeEntrypointCall (GetEntrypointArgCustom cp mname)
-> ContractRef (GetEntrypointArgCustom cp mname)
forall arg. Address -> SomeEntrypointCall arg -> ContractRef arg
ContractRef Address
addr (EntrypointCall cp (GetEntrypointArgCustom cp mname)
-> SomeEntrypointCall (GetEntrypointArgCustom cp mname)
forall (arg :: T) (param :: T).
ParameterScope param =>
EntrypointCallT param arg -> SomeEntrypointCallT arg
M.SomeEpc EntrypointCall cp (GetEntrypointArgCustom cp mname)
epc)
callingDefAddress
:: forall cp vd addr.
(ToTAddress cp vd addr, NiceParameterFull cp)
=> addr
-> ContractRef (Ep.GetDefaultEntrypointArg cp)
callingDefAddress :: addr -> ContractRef (GetDefaultEntrypointArg cp)
callingDefAddress addr
addr = addr
-> EntrypointRef 'Nothing
-> ContractRef (GetEntrypointArgCustom cp 'Nothing)
forall cp vd addr (mname :: Maybe Symbol).
(ToTAddress cp vd addr, NiceParameterFull cp) =>
addr
-> EntrypointRef mname
-> ContractRef (GetEntrypointArgCustom cp mname)
callingAddress @cp @vd addr
addr EntrypointRef 'Nothing
Ep.CallDefault
type ToTAddress_ cp vd addr = (ToTAddress cp vd addr, ToT addr ~ ToT Address)
toTAddress_
:: forall cp addr vd s.
(ToTAddress_ cp vd addr)
=> addr : s :-> TAddress cp vd : s
toTAddress_ :: (addr : s) :-> (TAddress cp vd : s)
toTAddress_ = Instr (ToTs (addr : s)) (ToTs (TAddress cp vd : s))
-> (addr : s) :-> (TAddress cp vd : s)
forall (inp :: [*]) (out :: [*]).
Instr (ToTs inp) (ToTs out) -> inp :-> out
I Instr (ToTs (addr : s)) (ToTs (TAddress cp vd : s))
forall (inp :: [T]). Instr inp inp
M.Nop
newtype FutureContract arg = FutureContract { FutureContract arg -> ContractRef arg
unFutureContract :: ContractRef arg }
instance IsoValue (FutureContract arg) where
type ToT (FutureContract arg) = ToT EpAddress
toVal :: FutureContract arg -> Value (ToT (FutureContract arg))
toVal (FutureContract ContractRef arg
contract) = EpAddress -> Value (ToT EpAddress)
forall a. IsoValue a => a -> Value (ToT a)
toVal (EpAddress -> Value (ToT EpAddress))
-> EpAddress -> Value (ToT EpAddress)
forall a b. (a -> b) -> a -> b
$ ContractRef arg -> EpAddress
forall cp. ContractRef cp -> EpAddress
M.contractRefToAddr ContractRef arg
contract
fromVal :: Value (ToT (FutureContract arg)) -> FutureContract arg
fromVal = Text -> Value 'TAddress -> FutureContract arg
forall a. HasCallStack => Text -> a
error Text
"Fetching 'FutureContract' back from Michelson is impossible"
instance HasAnnotation (FutureContract a) where
getAnnotation :: FollowEntrypointFlag -> Notes (ToT (FutureContract a))
getAnnotation FollowEntrypointFlag
_ = Notes (ToT (FutureContract a))
forall (t :: T). SingI t => Notes t
M.starNotes
class ToAddress a where
toAddress :: a -> Address
instance ToAddress Address where
toAddress :: Address -> Address
toAddress = Address -> Address
forall a. a -> a
id
instance ToAddress EpAddress where
toAddress :: EpAddress -> Address
toAddress = EpAddress -> Address
eaAddress
instance ToAddress (TAddress cp vd) where
toAddress :: TAddress cp vd -> Address
toAddress = TAddress cp vd -> Address
forall cp vd. TAddress cp vd -> Address
unTAddress
instance ToAddress (FutureContract cp) where
toAddress :: FutureContract cp -> Address
toAddress = ContractRef cp -> Address
forall a. ToAddress a => a -> Address
toAddress (ContractRef cp -> Address)
-> (FutureContract cp -> ContractRef cp)
-> FutureContract cp
-> Address
forall b c a. (b -> c) -> (a -> b) -> a -> c
. FutureContract cp -> ContractRef cp
forall arg. FutureContract arg -> ContractRef arg
unFutureContract
instance ToAddress (ContractRef cp) where
toAddress :: ContractRef cp -> Address
toAddress = ContractRef cp -> Address
forall cp. ContractRef cp -> Address
crAddress
class ToTAddress (cp :: Type) (vd :: Type) (a :: Type) where
toTAddress :: a -> TAddress cp vd
instance ToTAddress cp vd Address where
toTAddress :: Address -> TAddress cp vd
toTAddress = Address -> TAddress cp vd
forall p vd. Address -> TAddress p vd
TAddress
instance (cp ~ cp', vd ~ vd') => ToTAddress cp vd (TAddress cp' vd') where
toTAddress :: TAddress cp' vd' -> TAddress cp vd
toTAddress = TAddress cp' vd' -> TAddress cp vd
forall a. a -> a
id
class ToContractRef (cp :: Type) (contract :: Type) where
toContractRef :: HasCallStack => contract -> ContractRef cp
instance (cp ~ cp') => ToContractRef cp (ContractRef cp') where
toContractRef :: ContractRef cp' -> ContractRef cp
toContractRef = ContractRef cp' -> ContractRef cp
forall a. a -> a
id
instance (NiceParameter cp, cp ~ cp') => ToContractRef cp (FutureContract cp') where
toContractRef :: FutureContract cp' -> ContractRef cp
toContractRef = FutureContract cp' -> ContractRef cp
forall arg. FutureContract arg -> ContractRef arg
unFutureContract
instance ( FailWhen cond msg
, cond ~
( Ep.CanHaveEntrypoints cp &&
Not (Ep.ParameterEntrypointsDerivation cp == Ep.EpdNone)
)
, msg ~
( 'Text "Cannot apply `ToContractRef` to `TAddress`" ':$$:
'Text "Consider using call(Def)TAddress first`" ':$$:
'Text "(or if you know your parameter type is primitive," ':$$:
'Text " make sure typechecker also knows about that)" ':$$:
'Text "For parameter `" ':<>: 'ShowType cp ':<>: 'Text "`"
)
, cp ~ arg, NiceParameter arg
, NiceParameterFull cp, Ep.GetDefaultEntrypointArg cp ~ cp
) =>
ToContractRef arg (TAddress cp vd) where
toContractRef :: TAddress cp vd -> ContractRef arg
toContractRef = TAddress cp vd -> ContractRef arg
forall cp vd.
NiceParameterFull cp =>
TAddress cp vd -> ContractRef (GetDefaultEntrypointArg cp)
callingDefTAddress
class FromContractRef (cp :: Type) (contract :: Type) where
fromContractRef :: ContractRef cp -> contract
instance (cp ~ cp') => FromContractRef cp (ContractRef cp') where
fromContractRef :: ContractRef cp -> ContractRef cp'
fromContractRef = ContractRef cp -> ContractRef cp'
forall a. a -> a
id
instance (cp ~ cp') => FromContractRef cp (FutureContract cp') where
fromContractRef :: ContractRef cp -> FutureContract cp'
fromContractRef = ContractRef cp' -> FutureContract cp'
forall arg. ContractRef arg -> FutureContract arg
FutureContract (ContractRef cp' -> FutureContract cp')
-> (ContractRef cp -> ContractRef cp')
-> ContractRef cp
-> FutureContract cp'
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ContractRef cp -> ContractRef cp'
forall cp contract.
FromContractRef cp contract =>
ContractRef cp -> contract
fromContractRef
instance FromContractRef cp EpAddress where
fromContractRef :: ContractRef cp -> EpAddress
fromContractRef = ContractRef cp -> EpAddress
forall cp. ContractRef cp -> EpAddress
M.contractRefToAddr
instance FromContractRef cp Address where
fromContractRef :: ContractRef cp -> Address
fromContractRef = ContractRef cp -> Address
forall cp. ContractRef cp -> Address
crAddress
convertContractRef
:: forall cp contract2 contract1.
(ToContractRef cp contract1, FromContractRef cp contract2)
=> contract1 -> contract2
convertContractRef :: contract1 -> contract2
convertContractRef = forall contract.
FromContractRef cp contract =>
ContractRef cp -> contract
forall cp contract.
FromContractRef cp contract =>
ContractRef cp -> contract
fromContractRef @cp (ContractRef cp -> contract2)
-> (contract1 -> ContractRef cp) -> contract1 -> contract2
forall b c a. (b -> c) -> (a -> b) -> a -> c
. contract1 -> ContractRef cp
forall cp contract.
(ToContractRef cp contract, HasCallStack) =>
contract -> ContractRef cp
toContractRef