mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #7057 from ethereum/smt_inlining_flag
[SMTChecker] New VariableUsage flag to inline functions
This commit is contained in:
commit
2bb06561ce
@ -50,6 +50,7 @@ void BMC::analyze(SourceUnit const& _source, shared_ptr<Scanner> const& _scanner
|
||||
m_scanner = _scanner;
|
||||
|
||||
m_context.clear();
|
||||
m_variableUsage.setFunctionInlining(true);
|
||||
|
||||
_source.accept(*this);
|
||||
|
||||
|
@ -57,7 +57,7 @@ void VariableUsage::endVisit(IndexAccess const& _indexAccess)
|
||||
|
||||
void VariableUsage::endVisit(FunctionCall const& _funCall)
|
||||
{
|
||||
/// TODO this should run only in the BMC case, not for Horn.
|
||||
if (m_inlineFunctionCalls)
|
||||
if (auto const& funDef = BMC::inlinedFunctionCallToDefinition(_funCall))
|
||||
if (find(m_callStack.begin(), m_callStack.end(), funDef) == m_callStack.end())
|
||||
funDef->accept(*this);
|
||||
|
@ -38,6 +38,9 @@ public:
|
||||
/// @param _outerCallstack the current callstack in the callers context.
|
||||
std::set<VariableDeclaration const*> touchedVariables(ASTNode const& _node, std::vector<CallableDeclaration const*> const& _outerCallstack);
|
||||
|
||||
/// Sets whether to inline function calls.
|
||||
void setFunctionInlining(bool _inlineFunction) { m_inlineFunctionCalls = _inlineFunction; }
|
||||
|
||||
private:
|
||||
void endVisit(Identifier const& _node) override;
|
||||
void endVisit(IndexAccess const& _node) override;
|
||||
@ -53,6 +56,8 @@ private:
|
||||
std::set<VariableDeclaration const*> m_touchedVariables;
|
||||
std::vector<CallableDeclaration const*> m_callStack;
|
||||
CallableDeclaration const* m_lastCall = nullptr;
|
||||
|
||||
bool m_inlineFunctionCalls = false;
|
||||
};
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user