mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Disallow indexed reference types in events when using ABIEncoderV2
This commit is contained in:
		
							parent
							
								
									ba5625063c
								
							
						
					
					
						commit
						768ea5b0be
					
				| @ -1,6 +1,7 @@ | ||||
| ### 0.4.25 (unreleased) | ||||
| 
 | ||||
| Bugfixes: | ||||
|  * Type Checker: Report error when using indexed structs in events with experimental ABIEncoderV2. This used to log wrong values. | ||||
|  * Type Checker: Report error when using structs in events without experimental ABIEncoderV2. This used to crash or log the wrong values. | ||||
| 
 | ||||
| ### 0.4.24 (2018-05-16) | ||||
|  | ||||
| @ -869,7 +869,17 @@ bool TypeChecker::visit(EventDefinition const& _eventDef) | ||||
| 	for (ASTPointer<VariableDeclaration> const& var: _eventDef.parameters()) | ||||
| 	{ | ||||
| 		if (var->isIndexed()) | ||||
| 		{ | ||||
| 			numIndexed++; | ||||
| 			if ( | ||||
| 				_eventDef.sourceUnit().annotation().experimentalFeatures.count(ExperimentalFeature::ABIEncoderV2) | ||||
| 				&& dynamic_cast<ReferenceType const*>(type(*var).get()) | ||||
| 			) | ||||
| 				m_errorReporter.typeError( | ||||
| 					var->location(), | ||||
| 					"Reference types cannot be indexed." | ||||
| 				); | ||||
| 		} | ||||
| 		if (!type(*var)->canLiveOutsideStorage()) | ||||
| 			m_errorReporter.typeError(var->location(), "Type is required to live outside storage."); | ||||
| 		if (!type(*var)->interfaceType(false)) | ||||
|  | ||||
| @ -0,0 +1,7 @@ | ||||
| pragma experimental ABIEncoderV2; | ||||
| contract c { | ||||
|     event E(uint[] indexed); | ||||
| } | ||||
| // ---- | ||||
| // Warning: (0-33): Experimental features are turned on. Do not use experimental features on live deployments. | ||||
| // TypeError: (59-65): Reference types cannot be indexed. | ||||
							
								
								
									
										6
									
								
								test/libsolidity/syntaxTests/events/event_array_v2.sol
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								test/libsolidity/syntaxTests/events/event_array_v2.sol
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| pragma experimental ABIEncoderV2; | ||||
| contract c { | ||||
|     event E(uint[]); | ||||
| } | ||||
| // ---- | ||||
| // Warning: (0-33): Experimental features are turned on. Do not use experimental features on live deployments. | ||||
| @ -0,0 +1,7 @@ | ||||
| pragma experimental ABIEncoderV2; | ||||
| contract c { | ||||
|     event E(uint[][] indexed); | ||||
| } | ||||
| // ---- | ||||
| // Warning: (0-33): Experimental features are turned on. Do not use experimental features on live deployments. | ||||
| // TypeError: (59-67): Reference types cannot be indexed. | ||||
| @ -0,0 +1,6 @@ | ||||
| pragma experimental ABIEncoderV2; | ||||
| contract c { | ||||
|     event E(uint[][]); | ||||
| } | ||||
| // ---- | ||||
| // Warning: (0-33): Experimental features are turned on. Do not use experimental features on live deployments. | ||||
| @ -0,0 +1,8 @@ | ||||
| pragma experimental ABIEncoderV2; | ||||
| contract c { | ||||
|     struct S { uint a ; } | ||||
|     event E(S indexed); | ||||
| } | ||||
| // ---- | ||||
| // Warning: (0-33): Experimental features are turned on. Do not use experimental features on live deployments. | ||||
| // TypeError: (85-86): Reference types cannot be indexed. | ||||
							
								
								
									
										7
									
								
								test/libsolidity/syntaxTests/events/event_struct_v2.sol
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								test/libsolidity/syntaxTests/events/event_struct_v2.sol
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| pragma experimental ABIEncoderV2; | ||||
| contract c { | ||||
|     struct S { uint a ; } | ||||
|     event E(S); | ||||
| } | ||||
| // ---- | ||||
| // Warning: (0-33): Experimental features are turned on. Do not use experimental features on live deployments. | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user