mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Add sig member on function type
This commit is contained in:
parent
8bb96eaaf5
commit
58f7a27ee0
@ -1,6 +1,7 @@
|
|||||||
### 0.4.17 (unreleased)
|
### 0.4.17 (unreleased)
|
||||||
|
|
||||||
Features:
|
Features:
|
||||||
|
* Code Generator: Added ``.sig`` member on external function types to retrieve their signature.
|
||||||
* Optimizer: Add new optimization step to remove unused ``JUMPDEST``s.
|
* Optimizer: Add new optimization step to remove unused ``JUMPDEST``s.
|
||||||
* Type Checker: Display helpful warning for unused function arguments/return parameters.
|
* Type Checker: Display helpful warning for unused function arguments/return parameters.
|
||||||
* Type Checker: Do not show the same error multiple times for events.
|
* Type Checker: Do not show the same error multiple times for events.
|
||||||
|
@ -2436,6 +2436,11 @@ MemberList::MemberMap FunctionType::nativeMembers(ContractDefinition const*) con
|
|||||||
case Kind::BareDelegateCall:
|
case Kind::BareDelegateCall:
|
||||||
{
|
{
|
||||||
MemberList::MemberMap members;
|
MemberList::MemberMap members;
|
||||||
|
if (m_kind == Kind::External)
|
||||||
|
members.push_back(MemberList::Member(
|
||||||
|
"sig",
|
||||||
|
make_shared<FixedBytesType>(4)
|
||||||
|
));
|
||||||
if (m_kind != Kind::BareDelegateCall && m_kind != Kind::DelegateCall)
|
if (m_kind != Kind::BareDelegateCall && m_kind != Kind::DelegateCall)
|
||||||
{
|
{
|
||||||
if (isPayable())
|
if (isPayable())
|
||||||
|
@ -1068,6 +1068,13 @@ bool ExpressionCompiler::visit(MemberAccess const& _memberAccess)
|
|||||||
solAssert(false, "Invalid member access to integer");
|
solAssert(false, "Invalid member access to integer");
|
||||||
break;
|
break;
|
||||||
case Type::Category::Function:
|
case Type::Category::Function:
|
||||||
|
if (member == "sig")
|
||||||
|
{
|
||||||
|
m_context << Instruction::SWAP1 << Instruction::POP;
|
||||||
|
/// need to store store it as bytes4
|
||||||
|
utils().leftShiftNumberOnStack(224);
|
||||||
|
}
|
||||||
|
else
|
||||||
solAssert(!!_memberAccess.expression().annotation().type->memberType(member),
|
solAssert(!!_memberAccess.expression().annotation().type->memberType(member),
|
||||||
"Invalid member access to function.");
|
"Invalid member access to function.");
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user