diff options
author | chriseth <c@ethdev.com> | 2015-09-08 18:57:27 +0800 |
---|---|---|
committer | chriseth <c@ethdev.com> | 2015-09-08 22:51:14 +0800 |
commit | 985eb80695bf9c2a757397374a0ec30ea09d17c1 (patch) | |
tree | fda7e5e9e19744f78e24cc4e87a36d8af545fb0b /libsolidity/NameAndTypeResolver.cpp | |
parent | ea981cb0f5e5b131a56e420db97e944644ac95d6 (diff) | |
download | dexon-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.cpp | 8 |
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(); |