mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Disallow multiple events with same name and types.
This commit is contained in:
parent
7a4cab38fc
commit
ab2f64f442
@ -11,6 +11,7 @@ Breaking changes:
|
|||||||
* Type Checker: Exponentiation and shifts of literals by non-literals will always use ``uint256`` or ``int256`` as a type.
|
* Type Checker: Exponentiation and shifts of literals by non-literals will always use ``uint256`` or ``int256`` as a type.
|
||||||
* Type Checker: Disallow structs and arrays in memory or calldata if they contain nested mappings.
|
* Type Checker: Disallow structs and arrays in memory or calldata if they contain nested mappings.
|
||||||
* Type Checker: Disallow assignments to state variables that contain nested mappings.
|
* Type Checker: Disallow assignments to state variables that contain nested mappings.
|
||||||
|
* Type checker: Disallow events with same name and parameter types in inheritance hierarchy.
|
||||||
* ``using A for B`` only affects the contract it is mentioned in and not all derived contracts
|
* ``using A for B`` only affects the contract it is mentioned in and not all derived contracts
|
||||||
* Inline Assembly: Disallow `.` in user-defined function and variable names.
|
* Inline Assembly: Disallow `.` in user-defined function and variable names.
|
||||||
|
|
||||||
|
@ -120,7 +120,8 @@ void ContractLevelChecker::checkDuplicateEvents(ContractDefinition const& _contr
|
|||||||
/// Checks that two events with the same name defined in this contract have different
|
/// Checks that two events with the same name defined in this contract have different
|
||||||
/// argument types
|
/// argument types
|
||||||
map<string, vector<EventDefinition const*>> events;
|
map<string, vector<EventDefinition const*>> events;
|
||||||
for (EventDefinition const* event: _contract.events())
|
for (auto const* contract: _contract.annotation().linearizedBaseContracts)
|
||||||
|
for (EventDefinition const* event: contract->events())
|
||||||
events[event->name()].push_back(event);
|
events[event->name()].push_back(event);
|
||||||
|
|
||||||
findDuplicateDefinitions(events);
|
findDuplicateDefinitions(events);
|
||||||
|
@ -0,0 +1,8 @@
|
|||||||
|
contract A {
|
||||||
|
event X();
|
||||||
|
}
|
||||||
|
contract B is A {
|
||||||
|
event X() anonymous;
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// DeclarationError 5883: (52-72): Event with same name and parameter types defined twice.
|
@ -0,0 +1,8 @@
|
|||||||
|
contract A {
|
||||||
|
event X(uint);
|
||||||
|
}
|
||||||
|
contract B is A {
|
||||||
|
event X(uint indexed);
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// DeclarationError 5883: (56-78): Event with same name and parameter types defined twice.
|
@ -0,0 +1,6 @@
|
|||||||
|
contract A {
|
||||||
|
event X();
|
||||||
|
}
|
||||||
|
contract B is A {
|
||||||
|
event X(uint);
|
||||||
|
}
|
@ -0,0 +1,8 @@
|
|||||||
|
contract A {
|
||||||
|
event X(uint);
|
||||||
|
}
|
||||||
|
contract B is A {
|
||||||
|
event X(uint);
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// DeclarationError 5883: (56-70): Event with same name and parameter types defined twice.
|
@ -0,0 +1,10 @@
|
|||||||
|
contract A {
|
||||||
|
event X(uint, uint indexed);
|
||||||
|
}
|
||||||
|
contract B {
|
||||||
|
event X(uint, uint);
|
||||||
|
}
|
||||||
|
contract C is A, B {
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// DeclarationError 5883: (65-85): Event with same name and parameter types defined twice.
|
@ -0,0 +1,8 @@
|
|||||||
|
contract A {
|
||||||
|
event X(uint, uint indexed);
|
||||||
|
}
|
||||||
|
contract B is A {
|
||||||
|
event X(uint, uint);
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// DeclarationError 5883: (70-90): Event with same name and parameter types defined twice.
|
@ -0,0 +1,4 @@
|
|||||||
|
contract A { event X(uint); }
|
||||||
|
contract B is A {}
|
||||||
|
contract C is A {}
|
||||||
|
contract D is B, C {}
|
@ -0,0 +1,5 @@
|
|||||||
|
contract A {
|
||||||
|
event X();
|
||||||
|
event X(uint);
|
||||||
|
}
|
||||||
|
// ----
|
Loading…
Reference in New Issue
Block a user