aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2017-07-06 03:14:06 +0800
committerGitHub <noreply@github.com>2017-07-06 03:14:06 +0800
commit4bde6fa96122a308296e00dfb32da25905c5ef34 (patch)
tree78ca85f3fa9834cdd54ad77449704337603b500f /libsolidity
parent2dd9070a4f8426fb16a4d611f21ed0f98f670195 (diff)
parentdd34277ca60fcd9803a6fbb5a5944a1ed2533c73 (diff)
downloaddexon-solidity-4bde6fa96122a308296e00dfb32da25905c5ef34.tar
dexon-solidity-4bde6fa96122a308296e00dfb32da25905c5ef34.tar.gz
dexon-solidity-4bde6fa96122a308296e00dfb32da25905c5ef34.tar.bz2
dexon-solidity-4bde6fa96122a308296e00dfb32da25905c5ef34.tar.lz
dexon-solidity-4bde6fa96122a308296e00dfb32da25905c5ef34.tar.xz
dexon-solidity-4bde6fa96122a308296e00dfb32da25905c5ef34.tar.zst
dexon-solidity-4bde6fa96122a308296e00dfb32da25905c5ef34.zip
Merge pull request #2528 from ethereum/warnNoStorage
Warn if local storage reference variable does not use "storage" explicitly.
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/analysis/ReferencesResolver.cpp15
-rw-r--r--libsolidity/analysis/TypeChecker.cpp10
2 files changed, 20 insertions, 5 deletions
diff --git a/libsolidity/analysis/ReferencesResolver.cpp b/libsolidity/analysis/ReferencesResolver.cpp
index 2a5f27df..cc95c294 100644
--- a/libsolidity/analysis/ReferencesResolver.cpp
+++ b/libsolidity/analysis/ReferencesResolver.cpp
@@ -289,7 +289,20 @@ void ReferencesResolver::endVisit(VariableDeclaration const& _variable)
typeLoc = DataLocation::Memory;
}
else if (varLoc == Location::Default)
- typeLoc = _variable.isCallableParameter() ? DataLocation::Memory : DataLocation::Storage;
+ {
+ if (_variable.isCallableParameter())
+ typeLoc = DataLocation::Memory;
+ else
+ {
+ typeLoc = DataLocation::Storage;
+ if (!_variable.isStateVariable())
+ m_errorReporter.warning(
+ _variable.location(),
+ "Variable is declared as a storage pointer. "
+ "Use an explicit \"storage\" keyword to silence this warning."
+ );
+ }
+ }
else
typeLoc = varLoc == Location::Memory ? DataLocation::Memory : DataLocation::Storage;
isPointer = !_variable.isStateVariable();
diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp
index 1563467c..7306a36d 100644
--- a/libsolidity/analysis/TypeChecker.cpp
+++ b/libsolidity/analysis/TypeChecker.cpp
@@ -854,10 +854,12 @@ bool TypeChecker::visit(VariableDeclarationStatement const& _statement)
if (auto ref = dynamic_cast<ReferenceType const*>(type(varDecl).get()))
{
if (ref->dataStoredIn(DataLocation::Storage))
- m_errorReporter.warning(
- varDecl.location(),
- "Uninitialized storage pointer. Did you mean '<type> memory " + varDecl.name() + "'?"
- );
+ {
+ string errorText{"Uninitialized storage pointer."};
+ if (varDecl.referenceLocation() == VariableDeclaration::Location::Default)
+ errorText += " Did you mean '<type> memory " + varDecl.name() + "'?";
+ m_errorReporter.warning(varDecl.location(), errorText);
+ }
}
else if (dynamic_cast<MappingType const*>(type(varDecl).get()))
m_errorReporter.typeError(