aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/NameAndTypeResolver.cpp
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2015-09-08 18:57:27 +0800
committerchriseth <c@ethdev.com>2015-09-08 22:51:14 +0800
commit985eb80695bf9c2a757397374a0ec30ea09d17c1 (patch)
treefda7e5e9e19744f78e24cc4e87a36d8af545fb0b /libsolidity/NameAndTypeResolver.cpp
parentea981cb0f5e5b131a56e420db97e944644ac95d6 (diff)
downloaddexon-solidity-985eb80695bf9c2a757397374a0ec30ea09d17c1.tar.gz
dexon-solidity-985eb80695bf9c2a757397374a0ec30ea09d17c1.tar.zst
dexon-solidity-985eb80695bf9c2a757397374a0ec30ea09d17c1.zip
Fix for constant strings.
Diffstat (limited to 'libsolidity/NameAndTypeResolver.cpp')
-rw-r--r--libsolidity/NameAndTypeResolver.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/libsolidity/NameAndTypeResolver.cpp b/libsolidity/NameAndTypeResolver.cpp
index 96800ec3..c3b49abd 100644
--- a/libsolidity/NameAndTypeResolver.cpp
+++ b/libsolidity/NameAndTypeResolver.cpp
@@ -457,6 +457,14 @@ void ReferencesResolver::endVisit(VariableDeclaration& _variable)
}
else
{
+ if (_variable.isConstant())
+ {
+ if (loc != Location::Default && loc != Location::Memory)
+ BOOST_THROW_EXCEPTION(_variable.createTypeError(
+ "Storage location has to be \"memory\" (or unspecified) for constants."
+ ));
+ loc = Location::Memory;
+ }
if (loc == Location::Default)
loc = _variable.isCallableParameter() ? Location::Memory : Location::Storage;
bool isPointer = !_variable.isStateVariable();