aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/analysis
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2015-12-10 00:53:15 +0800
committerchriseth <c@ethdev.com>2015-12-10 00:57:34 +0800
commit39f57a9c718159448b0f9df199c3a0a019f32ca2 (patch)
tree27b593c6539cb8711f2623f3a0d12347bc793183 /libsolidity/analysis
parent15a1468c3fcf520b9c8f0af22159ea729cf9f085 (diff)
downloaddexon-solidity-39f57a9c718159448b0f9df199c3a0a019f32ca2.tar.gz
dexon-solidity-39f57a9c718159448b0f9df199c3a0a019f32ca2.tar.zst
dexon-solidity-39f57a9c718159448b0f9df199c3a0a019f32ca2.zip
Fix: Segfaults connected to paramater types.
parameterTypes does not return by const reference anymore.
Diffstat (limited to 'libsolidity/analysis')
-rw-r--r--libsolidity/analysis/TypeChecker.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp
index 851266bd..425f9299 100644
--- a/libsolidity/analysis/TypeChecker.cpp
+++ b/libsolidity/analysis/TypeChecker.cpp
@@ -950,7 +950,7 @@ bool TypeChecker::visit(FunctionCall const& _functionCall)
else
_functionCall.annotation().type = make_shared<TupleType>(functionType->returnParameterTypes());
- TypePointers const& parameterTypes = functionType->parameterTypes();
+ TypePointers parameterTypes = functionType->parameterTypes();
if (!functionType->takesArbitraryParameters() && parameterTypes.size() != arguments.size())
{
string msg =
@@ -1079,7 +1079,7 @@ void TypeChecker::endVisit(NewExpression const& _newExpression)
);
auto contractType = make_shared<ContractType>(*contract);
- TypePointers const& parameterTypes = contractType->constructorType()->parameterTypes();
+ TypePointers parameterTypes = contractType->constructorType()->parameterTypes();
_newExpression.annotation().type = make_shared<FunctionType>(
parameterTypes,
TypePointers{contractType},