mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	SHA3 of string literals now should work
This commit is contained in:
		
							parent
							
								
									2c9ff4747d
								
							
						
					
					
						commit
						293344b473
					
				
							
								
								
									
										14
									
								
								AST.cpp
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								AST.cpp
									
									
									
									
									
								
							| @ -493,19 +493,9 @@ void FunctionCall::checkTypeRequirements() | |||||||
| 		if (m_names.empty()) | 		if (m_names.empty()) | ||||||
| 		{ | 		{ | ||||||
| 			for (size_t i = 0; i < m_arguments.size(); ++i) | 			for (size_t i = 0; i < m_arguments.size(); ++i) | ||||||
| 			{ | 				if (functionType->getLocation() != FunctionType::Location::SHA3 && | ||||||
| 				if (functionType->getLocation() == FunctionType::Location::SHA3) | 					!m_arguments[i]->getType()->isImplicitlyConvertibleTo(*parameterTypes[i])) | ||||||
| 				{ |  | ||||||
| #if 0 // are we sure we want that? Literal constant nums can't live outside storage and so sha3(42) will fail
 |  | ||||||
| 					if (!m_arguments[i]->getType()->canLiveOutsideStorage()) |  | ||||||
| 						BOOST_THROW_EXCEPTION(createTypeError("SHA3 called with argument that can't live outside storage")); |  | ||||||
| #endif |  | ||||||
| 					if (!m_arguments[i]->getType()->isImplicitlyConvertibleTo(*parameterTypes[0])) |  | ||||||
| 						BOOST_THROW_EXCEPTION(m_arguments[i]->createTypeError("SHA3 argument can't be converted to hash")); |  | ||||||
| 
 |  | ||||||
| 				} else if (!m_arguments[i]->getType()->isImplicitlyConvertibleTo(*parameterTypes[i])) |  | ||||||
| 					BOOST_THROW_EXCEPTION(createTypeError("Invalid type for argument in function call.")); | 					BOOST_THROW_EXCEPTION(createTypeError("Invalid type for argument in function call.")); | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 		else if (functionType->getLocation() == FunctionType::Location::SHA3) | 		else if (functionType->getLocation() == FunctionType::Location::SHA3) | ||||||
| 			BOOST_THROW_EXCEPTION(createTypeError("Named arguments can't be used for SHA3.")); | 			BOOST_THROW_EXCEPTION(createTypeError("Named arguments can't be used for SHA3.")); | ||||||
|  | |||||||
| @ -851,22 +851,23 @@ unsigned ExpressionCompiler::appendArgumentsCopyToMemory(vector<ASTPointer<Expre | |||||||
| 	// without type conversion
 | 	// without type conversion
 | ||||||
| 	for (unsigned i = 0; i < _arguments.size(); ++i) | 	for (unsigned i = 0; i < _arguments.size(); ++i) | ||||||
| 	{ | 	{ | ||||||
|  | 		bool wantPadding = (_arguments[i]->getType()->getCategory() == Type::Category::STRING) ? false : true; | ||||||
| 		_arguments[i]->accept(*this); | 		_arguments[i]->accept(*this); | ||||||
| 		length += moveTypeToMemory(*_arguments[i]->getType()->getRealType(), _arguments[i]->getLocation(), _memoryOffset + length); | 		length += moveTypeToMemory(*_arguments[i]->getType()->getRealType(), _arguments[i]->getLocation(), _memoryOffset + length, wantPadding); | ||||||
| 	} | 	} | ||||||
| 	return length; | 	return length; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| unsigned ExpressionCompiler::moveTypeToMemory(Type const& _type, Location const& _location, unsigned _memoryOffset) | unsigned ExpressionCompiler::moveTypeToMemory(Type const& _type, Location const& _location, unsigned _memoryOffset, bool _padToWordBoundaries) | ||||||
| { | { | ||||||
| 	unsigned const c_numBytes = CompilerUtils::getPaddedSize(_type.getCalldataEncodedSize()); | 	unsigned const encodedSize = _type.getCalldataEncodedSize(); | ||||||
|  | 	unsigned const c_numBytes = _padToWordBoundaries ? CompilerUtils::getPaddedSize(encodedSize) : encodedSize; | ||||||
| 	if (c_numBytes == 0 || c_numBytes > 32) | 	if (c_numBytes == 0 || c_numBytes > 32) | ||||||
| 		BOOST_THROW_EXCEPTION(CompilerError() | 		BOOST_THROW_EXCEPTION(CompilerError() | ||||||
| 							  << errinfo_sourceLocation(_location) | 							  << errinfo_sourceLocation(_location) | ||||||
| 							  << errinfo_comment("Type " + _type.toString() + " not yet supported.")); | 							  << errinfo_comment("Type " + _type.toString() + " not yet supported.")); | ||||||
| 	bool const c_leftAligned = _type.getCategory() == Type::Category::STRING; | 	bool const c_leftAligned = _type.getCategory() == Type::Category::STRING; | ||||||
| 	bool const c_padToWords = true; | 	return CompilerUtils(m_context).storeInMemory(_memoryOffset, c_numBytes, c_leftAligned, _padToWordBoundaries); | ||||||
| 	return CompilerUtils(m_context).storeInMemory(_memoryOffset, c_numBytes, c_leftAligned, c_padToWords); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| unsigned ExpressionCompiler::appendTypeConversionAndMoveToMemory(Type const& _expectedType, Type const& _type, | unsigned ExpressionCompiler::appendTypeConversionAndMoveToMemory(Type const& _expectedType, Type const& _type, | ||||||
|  | |||||||
| @ -103,7 +103,7 @@ private: | |||||||
| 												 Location const& _location, unsigned _memoryOffset = 0); | 												 Location const& _location, unsigned _memoryOffset = 0); | ||||||
| 	/// Appends code that moves a type to memory
 | 	/// Appends code that moves a type to memory
 | ||||||
| 	/// @returns the number of bytes copied to memory
 | 	/// @returns the number of bytes copied to memory
 | ||||||
| 	unsigned moveTypeToMemory(Type const& _type, Location const& _location, unsigned _memoryOffset); | 	unsigned moveTypeToMemory(Type const& _type, Location const& _location, unsigned _memoryOffset, bool _padToWordBoundaries = true); | ||||||
| 	/// Appends code that evaluates a single expression and copies it to memory (with optional offset).
 | 	/// Appends code that evaluates a single expression and copies it to memory (with optional offset).
 | ||||||
| 	/// @returns the number of bytes copied to memory
 | 	/// @returns the number of bytes copied to memory
 | ||||||
| 	unsigned appendExpressionCopyToMemory(Type const& _expectedType, Expression const& _expression, | 	unsigned appendExpressionCopyToMemory(Type const& _expectedType, Expression const& _expression, | ||||||
|  | |||||||
							
								
								
									
										1
									
								
								Types.h
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								Types.h
									
									
									
									
									
								
							| @ -249,6 +249,7 @@ public: | |||||||
| 
 | 
 | ||||||
| 	virtual std::string toString() const override { return "string" + dev::toString(m_bytes); } | 	virtual std::string toString() const override { return "string" + dev::toString(m_bytes); } | ||||||
| 	virtual u256 literalValue(Literal const* _literal) const override; | 	virtual u256 literalValue(Literal const* _literal) const override; | ||||||
|  | 	virtual TypePointer getRealType() const override { return std::make_shared<StaticStringType>(m_bytes); } | ||||||
| 
 | 
 | ||||||
| 	int getNumBytes() const { return m_bytes; } | 	int getNumBytes() const { return m_bytes; } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user