mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge pull request #9326 from ethereum/eventOverwriting
[BREAKING] Disallow multiple events with same name and types.
This commit is contained in:
		
						commit
						12f390a60a
					
				| @ -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