mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge pull request #2416 from federicobond/multiple-specifiers
Display error if payable or constant is specified multiple times
This commit is contained in:
		
						commit
						b3a7b5a145
					
				| @ -323,11 +323,17 @@ Parser::FunctionHeaderParserResult Parser::parseFunctionHeader(bool _forceEmptyN | ||||
| 		Token::Value token = m_scanner->currentToken(); | ||||
| 		if (token == Token::Const) | ||||
| 		{ | ||||
| 			if (result.isDeclaredConst) | ||||
| 				parserError(string("Multiple \"constant\" specifiers.")); | ||||
| 
 | ||||
| 			result.isDeclaredConst = true; | ||||
| 			m_scanner->next(); | ||||
| 		} | ||||
| 		else if (m_scanner->currentToken() == Token::Payable) | ||||
| 		{ | ||||
| 			if (result.isPayable) | ||||
| 				parserError(string("Multiple \"payable\" specifiers.")); | ||||
| 
 | ||||
| 			result.isPayable = true; | ||||
| 			m_scanner->next(); | ||||
| 		} | ||||
|  | ||||
| @ -901,6 +901,24 @@ BOOST_AUTO_TEST_CASE(multiple_visibility_specifiers) | ||||
| 	CHECK_PARSE_ERROR(text, "Visibility already specified"); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(multiple_payable_specifiers) | ||||
| { | ||||
| 	char const* text = R"( | ||||
| 		contract c { | ||||
| 			function f() payable payable {} | ||||
| 		})"; | ||||
| 	CHECK_PARSE_ERROR(text, "Multiple \"payable\" specifiers."); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(multiple_constant_specifiers) | ||||
| { | ||||
| 	char const* text = R"( | ||||
| 		contract c { | ||||
| 			function f() constant constant {} | ||||
| 		})"; | ||||
| 	CHECK_PARSE_ERROR(text, "Multiple \"constant\" specifiers."); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(literal_constants_with_ether_subdenominations) | ||||
| { | ||||
| 	char const* text = R"( | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user