abi v0.1.17 ABI.FunctionSelector
Module to help parse the ABI function signatures, e.g.
my_function(uint64, string[])
.
Link to this section Summary
Functions
Decodes a function selector to a struct.
Decodes the given type-string as a simple array of types.
Decodes the given type-string as a single type.
Encodes a function call signature.
Link to this section Types
Link to this type
type()
type()
type() ::
{:uint, integer()}
| :bool
| :bytes
| :string
| :address
| {:array, type()}
| {:array, type(), non_neg_integer()}
| {:tuple, [type()]}
type() :: {:uint, integer()} | :bool | :bytes | :string | :address | {:array, type()} | {:array, type(), non_neg_integer()} | {:tuple, [type()]}
Link to this section Functions
Link to this function
decode(signature)
Decodes a function selector to a struct.
Examples
iex> ABI.FunctionSelector.decode("bark(uint256,bool)")
%ABI.FunctionSelector{
function: "bark",
types: [
{:uint, 256},
:bool
]
}
iex> ABI.FunctionSelector.decode("(uint256,bool)")
%ABI.FunctionSelector{
function: nil,
types: [
{:uint, 256},
:bool
]
}
iex> ABI.FunctionSelector.decode("growl(uint,address,string[])")
%ABI.FunctionSelector{
function: "growl",
types: [
{:uint, 256},
:address,
{:array, :string}
]
}
iex> ABI.FunctionSelector.decode("rollover()")
%ABI.FunctionSelector{
function: "rollover",
types: []
}
iex> ABI.FunctionSelector.decode("do_playDead3()")
%ABI.FunctionSelector{
function: "do_playDead3",
types: []
}
iex> ABI.FunctionSelector.decode("pet(address[])")
%ABI.FunctionSelector{
function: "pet",
types: [
{:array, :address}
]
}
iex> ABI.FunctionSelector.decode("paw(string[2])")
%ABI.FunctionSelector{
function: "paw",
types: [
{:array, :string, 2}
]
}
iex> ABI.FunctionSelector.decode("scram(uint256[])")
%ABI.FunctionSelector{
function: "scram",
types: [
{:array, {:uint, 256}}
]
}
iex> ABI.FunctionSelector.decode("shake((string))")
%ABI.FunctionSelector{
function: "shake",
types: [
{:tuple, [:string]}
]
}
Link to this function
decode_raw(type_string)
Decodes the given type-string as a simple array of types.
Examples
iex> ABI.FunctionSelector.decode_raw("string,uint256")
[:string, {:uint, 256}]
iex> ABI.FunctionSelector.decode_raw("")
[]
Link to this function
decode_type(single_type)
Decodes the given type-string as a single type.
Examples
iex> ABI.FunctionSelector.decode_type("uint256")
{:uint, 256}
iex> ABI.FunctionSelector.decode_type("(bool,address)")
{:tuple, [:bool, :address]}
iex> ABI.FunctionSelector.decode_type("address[][3]")
{:array, {:array, :address}, 3}
Link to this function
encode(function_selector)
Encodes a function call signature.
Examples
iex> ABI.FunctionSelector.encode(%ABI.FunctionSelector{
...> function: "bark",
...> types: [
...> {:uint, 256},
...> :bool,
...> {:array, :string},
...> {:array, :string, 3},
...> {:tuple, [{:uint, 256}, :bool]}
...> ]
...> })
"bark(uint256,bool,string[],string[3],(uint256,bool))"