mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Disallowed --metadata-literal, --model-checker-show-unproved, --model-checker-div-mod-no-slacks ----metadata-hash=swarm outside of compiler mode
This commit is contained in:
		
							parent
							
								
									f904bb0615
								
							
						
					
					
						commit
						697821b96b
					
				| @ -7,6 +7,7 @@ Compiler Features: | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| Bugfixes: | Bugfixes: | ||||||
|  |  * Commandline Interface: Disallow the following options outside of the compiler mode: ``--via-ir``,``--metadata-literal``, ``--metadata-hash``, ``--model-checker-show-unproved``, ``--model-checker-div-mod-no-slacks``, ``--model-checker-engine``, ``--model-checker-invariants``, ``--model-checker-solvers``, ``--model-checker-timeout``, ``--model-checker-contracts``, ``--model-checker-targets``. | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ### 0.8.15 (2022-06-15) | ### 0.8.15 (2022-06-15) | ||||||
|  | |||||||
| @ -911,12 +911,26 @@ void CommandLineParser::processArgs() | |||||||
| 		// TODO: This should eventually contain all options.
 | 		// TODO: This should eventually contain all options.
 | ||||||
| 		{g_strErrorRecovery, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | 		{g_strErrorRecovery, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
| 		{g_strExperimentalViaIR, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | 		{g_strExperimentalViaIR, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
| 		{g_strViaIR, {InputMode::Compiler, InputMode::CompilerWithASTImport}} | 		{g_strViaIR, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strMetadataLiteral, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strMetadataHash, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerShowUnproved, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerDivModNoSlacks, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerEngine, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerInvariants, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerSolvers, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerTimeout, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerContracts, {InputMode::Compiler, InputMode::CompilerWithASTImport}}, | ||||||
|  | 		{g_strModelCheckerTargets, {InputMode::Compiler, InputMode::CompilerWithASTImport}} | ||||||
| 	}; | 	}; | ||||||
| 	vector<string> invalidOptionsForCurrentInputMode; | 	vector<string> invalidOptionsForCurrentInputMode; | ||||||
| 	for (auto const& [optionName, inputModes]: validOptionInputModeCombinations) | 	for (auto const& [optionName, inputModes]: validOptionInputModeCombinations) | ||||||
| 	{ | 	{ | ||||||
| 		if (m_args.count(optionName) > 0 && inputModes.count(m_options.input.mode) == 0) | 		if ( | ||||||
|  | 			m_args.count(optionName) > 0 && | ||||||
|  | 			inputModes.count(m_options.input.mode) == 0 && | ||||||
|  | 			!m_args[optionName].defaulted() | ||||||
|  | 		) | ||||||
| 			invalidOptionsForCurrentInputMode.push_back(optionName); | 			invalidOptionsForCurrentInputMode.push_back(optionName); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -281,20 +281,6 @@ BOOST_AUTO_TEST_CASE(assembly_mode_options) | |||||||
| 			"--libraries=" | 			"--libraries=" | ||||||
| 				"dir1/file1.sol:L=0x1234567890123456789012345678901234567890," | 				"dir1/file1.sol:L=0x1234567890123456789012345678901234567890," | ||||||
| 				"dir2/file2.sol:L=0x1111122222333334444455555666667777788888", | 				"dir2/file2.sol:L=0x1111122222333334444455555666667777788888", | ||||||
| 			"--metadata-hash=swarm",       // Ignored in assembly mode
 |  | ||||||
| 			"--metadata-literal",          // Ignored in assembly mode
 |  | ||||||
| 			"--model-checker-contracts="   // Ignored in assembly mode
 |  | ||||||
| 				"contract1.yul:A," |  | ||||||
| 				"contract2.yul:B", |  | ||||||
| 			"--model-checker-div-mod-no-slacks", // Ignored in assembly mode
 |  | ||||||
| 			"--model-checker-engine=bmc",  // Ignored in assembly mode
 |  | ||||||
| 			"--model-checker-invariants=contract,reentrancy",  // Ignored in assembly mode
 |  | ||||||
| 			"--model-checker-show-unproved", // Ignored in assembly mode
 |  | ||||||
| 			"--model-checker-solvers=z3,smtlib2", // Ignored in assembly mode
 |  | ||||||
| 			"--model-checker-targets="     // Ignored in assembly mode
 |  | ||||||
| 				"underflow," |  | ||||||
| 				"divByZero", |  | ||||||
| 			"--model-checker-timeout=5",   // Ignored in assembly mode
 |  | ||||||
| 			"--asm", | 			"--asm", | ||||||
| 			"--bin", | 			"--bin", | ||||||
| 			"--ir-optimized", | 			"--ir-optimized", | ||||||
| @ -378,20 +364,6 @@ BOOST_AUTO_TEST_CASE(standard_json_mode_options) | |||||||
| 			"dir2/file2.sol:L=0x1111122222333334444455555666667777788888", | 			"dir2/file2.sol:L=0x1111122222333334444455555666667777788888", | ||||||
| 		"--gas",                           // Accepted but has no effect in Standard JSON mode
 | 		"--gas",                           // Accepted but has no effect in Standard JSON mode
 | ||||||
| 		"--combined-json=abi,bin",         // Accepted but has no effect in Standard JSON mode
 | 		"--combined-json=abi,bin",         // Accepted but has no effect in Standard JSON mode
 | ||||||
| 		"--metadata-hash=swarm",           // Ignored in Standard JSON mode
 |  | ||||||
| 		"--metadata-literal",              // Ignored in Standard JSON mode
 |  | ||||||
| 		"--model-checker-contracts="       // Ignored in Standard JSON mode
 |  | ||||||
| 			"contract1.yul:A," |  | ||||||
| 			"contract2.yul:B", |  | ||||||
| 		"--model-checker-div-mod-no-slacks", // Ignored in Standard JSON mode
 |  | ||||||
| 		"--model-checker-engine=bmc",      // Ignored in Standard JSON mode
 |  | ||||||
| 		"--model-checker-invariants=contract,reentrancy",      // Ignored in Standard JSON mode
 |  | ||||||
| 		"--model-checker-show-unproved",      // Ignored in Standard JSON mode
 |  | ||||||
| 		"--model-checker-solvers=z3,smtlib2", // Ignored in Standard JSON mode
 |  | ||||||
| 		"--model-checker-targets="         // Ignored in Standard JSON mode
 |  | ||||||
| 			"underflow," |  | ||||||
| 			"divByZero", |  | ||||||
| 		"--model-checker-timeout=5",       // Ignored in Standard JSON mode
 |  | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	CommandLineOptions expectedOptions; | 	CommandLineOptions expectedOptions; | ||||||
| @ -424,16 +396,30 @@ BOOST_AUTO_TEST_CASE(invalid_options_input_modes_combinations) | |||||||
| 		// TODO: This should eventually contain all options.
 | 		// TODO: This should eventually contain all options.
 | ||||||
| 		{"--error-recovery", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | 		{"--error-recovery", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
| 		{"--experimental-via-ir", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | 		{"--experimental-via-ir", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
| 		{"--via-ir", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}} | 		{"--via-ir", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--metadata-literal", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--metadata-hash=swarm", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-show-unproved", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-div-mod-no-slacks", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-engine=bmc", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-invariants=contract,reentrancy", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-solvers=z3,smtlib2", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-timeout=5", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-contracts=contract1.yul:A,contract2.yul:B", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}}, | ||||||
|  | 		{"--model-checker-targets=underflow,divByZero", {"--assemble", "--yul", "--strict-assembly", "--standard-json", "--link"}} | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	for (auto const& [optionName, inputModes]: invalidOptionInputModeCombinations) | 	for (auto const& [optionName, inputModes]: invalidOptionInputModeCombinations) | ||||||
| 		for (string const& inputMode: inputModes) | 		for (string const& inputMode: inputModes) | ||||||
| 		{ | 		{ | ||||||
| 			stringstream serr; | 			stringstream serr; | ||||||
|  | 			size_t separatorPosition = optionName.find("="); | ||||||
|  | 			string optionNameWithoutValue = optionName.substr(0, separatorPosition); | ||||||
|  | 			soltestAssert(!optionNameWithoutValue.empty()); | ||||||
|  | 
 | ||||||
| 			vector<string> commandLine = {"solc", optionName, "file", inputMode}; | 			vector<string> commandLine = {"solc", optionName, "file", inputMode}; | ||||||
| 
 | 
 | ||||||
| 			string expectedMessage = "The following options are not supported in the current input mode: " + optionName; | 			string expectedMessage = "The following options are not supported in the current input mode: " + optionNameWithoutValue; | ||||||
| 			auto hasCorrectMessage = [&](CommandLineValidationError const& _exception) { return _exception.what() == expectedMessage; }; | 			auto hasCorrectMessage = [&](CommandLineValidationError const& _exception) { return _exception.what() == expectedMessage; }; | ||||||
| 
 | 
 | ||||||
| 			BOOST_CHECK_EXCEPTION(parseCommandLine(commandLine), CommandLineValidationError, hasCorrectMessage); | 			BOOST_CHECK_EXCEPTION(parseCommandLine(commandLine), CommandLineValidationError, hasCorrectMessage); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user