mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Specify namespaces
Fix references into solidity::util
This commit is contained in:
parent
a890c82f9d
commit
519e1c9402
@ -129,7 +129,7 @@ void ControlFlowAnalyzer::checkUninitializedAccess(CFGNode const* _entry, CFGNod
|
|||||||
// Propagate changes to all exits and queue them for traversal, if needed.
|
// Propagate changes to all exits and queue them for traversal, if needed.
|
||||||
for (auto const& exit: currentNode->exits)
|
for (auto const& exit: currentNode->exits)
|
||||||
if (
|
if (
|
||||||
auto exists = valueOrNullptr(nodeInfos, exit);
|
auto exists = util::valueOrNullptr(nodeInfos, exit);
|
||||||
nodeInfos[exit].propagateFrom(nodeInfo) || !exists
|
nodeInfos[exit].propagateFrom(nodeInfo) || !exists
|
||||||
)
|
)
|
||||||
nodesToTraverse.insert(exit);
|
nodesToTraverse.insert(exit);
|
||||||
|
@ -57,7 +57,7 @@ void ControlFlowRevertPruner::run()
|
|||||||
|
|
||||||
void ControlFlowRevertPruner::findRevertStates()
|
void ControlFlowRevertPruner::findRevertStates()
|
||||||
{
|
{
|
||||||
std::set<CFG::FunctionContractTuple> pendingFunctions = keys(m_functions);
|
std::set<CFG::FunctionContractTuple> pendingFunctions = util::keys(m_functions);
|
||||||
// We interrupt the search whenever we encounter a call to a function with (yet) unknown
|
// We interrupt the search whenever we encounter a call to a function with (yet) unknown
|
||||||
// revert behaviour. The ``wakeUp`` data structure contains information about which
|
// revert behaviour. The ``wakeUp`` data structure contains information about which
|
||||||
// searches to restart once we know about the behaviour.
|
// searches to restart once we know about the behaviour.
|
||||||
|
@ -97,7 +97,7 @@ CallGraph FunctionCallGraphBuilder::buildDeployedGraph(
|
|||||||
// assigned to state variables and as such may be reachable after deployment as well.
|
// assigned to state variables and as such may be reachable after deployment as well.
|
||||||
builder.m_currentNode = CallGraph::SpecialNode::InternalDispatch;
|
builder.m_currentNode = CallGraph::SpecialNode::InternalDispatch;
|
||||||
set<CallGraph::Node, CallGraph::CompareByID> defaultNode;
|
set<CallGraph::Node, CallGraph::CompareByID> defaultNode;
|
||||||
for (CallGraph::Node const& dispatchTarget: valueOrDefault(_creationGraph.edges, CallGraph::SpecialNode::InternalDispatch, defaultNode))
|
for (CallGraph::Node const& dispatchTarget: util::valueOrDefault(_creationGraph.edges, CallGraph::SpecialNode::InternalDispatch, defaultNode))
|
||||||
{
|
{
|
||||||
solAssert(!holds_alternative<CallGraph::SpecialNode>(dispatchTarget), "");
|
solAssert(!holds_alternative<CallGraph::SpecialNode>(dispatchTarget), "");
|
||||||
solAssert(get<CallableDeclaration const*>(dispatchTarget) != nullptr, "");
|
solAssert(get<CallableDeclaration const*>(dispatchTarget) != nullptr, "");
|
||||||
|
@ -411,12 +411,12 @@ struct ReservedErrorSelector: public PostTypeChecker::Checker
|
|||||||
);
|
);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
uint32_t selector = selectorFromSignature32(_error.functionType(true)->externalSignature());
|
uint32_t selector = util::selectorFromSignature32(_error.functionType(true)->externalSignature());
|
||||||
if (selector == 0 || ~selector == 0)
|
if (selector == 0 || ~selector == 0)
|
||||||
m_errorReporter.syntaxError(
|
m_errorReporter.syntaxError(
|
||||||
2855_error,
|
2855_error,
|
||||||
_error.location(),
|
_error.location(),
|
||||||
"The selector 0x" + toHex(toCompactBigEndian(selector, 4)) + " is reserved. Please rename the error to avoid the collision."
|
"The selector 0x" + util::toHex(toCompactBigEndian(selector, 4)) + " is reserved. Please rename the error to avoid the collision."
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -52,7 +52,7 @@ bool PostTypeContractLevelChecker::check(ContractDefinition const& _contract)
|
|||||||
for (ErrorDefinition const* error: _contract.interfaceErrors())
|
for (ErrorDefinition const* error: _contract.interfaceErrors())
|
||||||
{
|
{
|
||||||
string signature = error->functionType(true)->externalSignature();
|
string signature = error->functionType(true)->externalSignature();
|
||||||
uint32_t hash = selectorFromSignature32(signature);
|
uint32_t hash = util::selectorFromSignature32(signature);
|
||||||
// Fail if there is a different signature for the same hash.
|
// Fail if there is a different signature for the same hash.
|
||||||
if (!errorHashes[hash].empty() && !errorHashes[hash].count(signature))
|
if (!errorHashes[hash].empty() && !errorHashes[hash].count(signature))
|
||||||
{
|
{
|
||||||
|
@ -659,7 +659,7 @@ void TypeChecker::visitManually(
|
|||||||
if (auto const* modifierContract = dynamic_cast<ContractDefinition const*>(modifierDecl->scope()))
|
if (auto const* modifierContract = dynamic_cast<ContractDefinition const*>(modifierDecl->scope()))
|
||||||
if (m_currentContract)
|
if (m_currentContract)
|
||||||
{
|
{
|
||||||
if (!contains(m_currentContract->annotation().linearizedBaseContracts, modifierContract))
|
if (!util::contains(m_currentContract->annotation().linearizedBaseContracts, modifierContract))
|
||||||
m_errorReporter.typeError(
|
m_errorReporter.typeError(
|
||||||
9428_error,
|
9428_error,
|
||||||
_modifier.location(),
|
_modifier.location(),
|
||||||
@ -2137,7 +2137,7 @@ void TypeChecker::typeCheckABIEncodeCallFunction(FunctionCall const& _functionCa
|
|||||||
functionPointerType->declaration().scope() == m_currentContract
|
functionPointerType->declaration().scope() == m_currentContract
|
||||||
)
|
)
|
||||||
msg += " Did you forget to prefix \"this.\"?";
|
msg += " Did you forget to prefix \"this.\"?";
|
||||||
else if (contains(
|
else if (util::contains(
|
||||||
m_currentContract->annotation().linearizedBaseContracts,
|
m_currentContract->annotation().linearizedBaseContracts,
|
||||||
functionPointerType->declaration().scope()
|
functionPointerType->declaration().scope()
|
||||||
) && functionPointerType->declaration().scope() != m_currentContract)
|
) && functionPointerType->declaration().scope() != m_currentContract)
|
||||||
|
@ -221,7 +221,7 @@ vector<EventDefinition const*> const ContractDefinition::usedInterfaceEvents() c
|
|||||||
{
|
{
|
||||||
solAssert(annotation().creationCallGraph.set(), "");
|
solAssert(annotation().creationCallGraph.set(), "");
|
||||||
|
|
||||||
return convertContainer<std::vector<EventDefinition const*>>(
|
return util::convertContainer<std::vector<EventDefinition const*>>(
|
||||||
(*annotation().creationCallGraph)->emittedEvents +
|
(*annotation().creationCallGraph)->emittedEvents +
|
||||||
(*annotation().deployedCallGraph)->emittedEvents
|
(*annotation().deployedCallGraph)->emittedEvents
|
||||||
);
|
);
|
||||||
@ -239,7 +239,7 @@ vector<ErrorDefinition const*> ContractDefinition::interfaceErrors(bool _require
|
|||||||
result +=
|
result +=
|
||||||
(*annotation().creationCallGraph)->usedErrors +
|
(*annotation().creationCallGraph)->usedErrors +
|
||||||
(*annotation().deployedCallGraph)->usedErrors;
|
(*annotation().deployedCallGraph)->usedErrors;
|
||||||
return convertContainer<vector<ErrorDefinition const*>>(move(result));
|
return util::convertContainer<vector<ErrorDefinition const*>>(move(result));
|
||||||
}
|
}
|
||||||
|
|
||||||
vector<pair<util::FixedHash<4>, FunctionTypePointer>> const& ContractDefinition::interfaceFunctionList(bool _includeInheritedFunctions) const
|
vector<pair<util::FixedHash<4>, FunctionTypePointer>> const& ContractDefinition::interfaceFunctionList(bool _includeInheritedFunctions) const
|
||||||
|
@ -505,7 +505,7 @@ bool ASTJsonConverter::visit(EventDefinition const& _node)
|
|||||||
_attributes.emplace_back(
|
_attributes.emplace_back(
|
||||||
make_pair(
|
make_pair(
|
||||||
"eventSelector",
|
"eventSelector",
|
||||||
toHex(u256(h256::Arith(util::keccak256(_node.functionType(true)->externalSignature()))))
|
toHex(u256(util::h256::Arith(util::keccak256(_node.functionType(true)->externalSignature()))))
|
||||||
));
|
));
|
||||||
|
|
||||||
setJsonNode(_node, "EventDefinition", std::move(_attributes));
|
setJsonNode(_node, "EventDefinition", std::move(_attributes));
|
||||||
|
@ -403,7 +403,7 @@ void CompilerContext::appendInlineAssembly(
|
|||||||
{
|
{
|
||||||
if (_insideFunction)
|
if (_insideFunction)
|
||||||
return false;
|
return false;
|
||||||
return contains(_localVariables, _identifier.name.str());
|
return util::contains(_localVariables, _identifier.name.str());
|
||||||
};
|
};
|
||||||
identifierAccess.generateCode = [&](
|
identifierAccess.generateCode = [&](
|
||||||
yul::Identifier const& _identifier,
|
yul::Identifier const& _identifier,
|
||||||
|
@ -235,7 +235,7 @@ size_t ContractCompiler::deployLibrary(ContractDefinition const& _contract)
|
|||||||
m_context.pushSubroutineOffset(m_context.runtimeSub());
|
m_context.pushSubroutineOffset(m_context.runtimeSub());
|
||||||
// This code replaces the address added by appendDeployTimeAddress().
|
// This code replaces the address added by appendDeployTimeAddress().
|
||||||
m_context.appendInlineAssembly(
|
m_context.appendInlineAssembly(
|
||||||
Whiskers(R"(
|
util::Whiskers(R"(
|
||||||
{
|
{
|
||||||
// If code starts at 11, an mstore(0) writes to the full PUSH20 plus data
|
// If code starts at 11, an mstore(0) writes to the full PUSH20 plus data
|
||||||
// without the need for a shift.
|
// without the need for a shift.
|
||||||
@ -672,7 +672,7 @@ bool ContractCompiler::visit(FunctionDefinition const& _function)
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
StackTooDeepError() <<
|
StackTooDeepError() <<
|
||||||
errinfo_sourceLocation(_function.location()) <<
|
errinfo_sourceLocation(_function.location()) <<
|
||||||
errinfo_comment("Stack too deep, try removing local variables.")
|
util::errinfo_comment("Stack too deep, try removing local variables.")
|
||||||
);
|
);
|
||||||
while (!stackLayout.empty() && stackLayout.back() != static_cast<int>(stackLayout.size() - 1))
|
while (!stackLayout.empty() && stackLayout.back() != static_cast<int>(stackLayout.size() - 1))
|
||||||
if (stackLayout.back() < 0)
|
if (stackLayout.back() < 0)
|
||||||
@ -842,7 +842,7 @@ bool ContractCompiler::visit(InlineAssembly const& _inlineAssembly)
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
StackTooDeepError() <<
|
StackTooDeepError() <<
|
||||||
errinfo_sourceLocation(_inlineAssembly.location()) <<
|
errinfo_sourceLocation(_inlineAssembly.location()) <<
|
||||||
errinfo_comment("Stack too deep, try removing local variables.")
|
util::errinfo_comment("Stack too deep, try removing local variables.")
|
||||||
);
|
);
|
||||||
_assembly.appendInstruction(dupInstruction(stackDiff));
|
_assembly.appendInstruction(dupInstruction(stackDiff));
|
||||||
}
|
}
|
||||||
@ -916,7 +916,7 @@ bool ContractCompiler::visit(InlineAssembly const& _inlineAssembly)
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
StackTooDeepError() <<
|
StackTooDeepError() <<
|
||||||
errinfo_sourceLocation(_inlineAssembly.location()) <<
|
errinfo_sourceLocation(_inlineAssembly.location()) <<
|
||||||
errinfo_comment("Stack too deep(" + to_string(stackDiff) + "), try removing local variables.")
|
util::errinfo_comment("Stack too deep(" + to_string(stackDiff) + "), try removing local variables.")
|
||||||
);
|
);
|
||||||
_assembly.appendInstruction(swapInstruction(stackDiff));
|
_assembly.appendInstruction(swapInstruction(stackDiff));
|
||||||
_assembly.appendInstruction(Instruction::POP);
|
_assembly.appendInstruction(Instruction::POP);
|
||||||
@ -1045,7 +1045,7 @@ void ContractCompiler::handleCatch(vector<ASTPointer<TryCatchClause>> const& _ca
|
|||||||
solAssert(m_context.evmVersion().supportsReturndata(), "");
|
solAssert(m_context.evmVersion().supportsReturndata(), "");
|
||||||
|
|
||||||
// stack: <selector>
|
// stack: <selector>
|
||||||
m_context << Instruction::DUP1 << selectorFromSignature32("Error(string)") << Instruction::EQ;
|
m_context << Instruction::DUP1 << util::selectorFromSignature32("Error(string)") << Instruction::EQ;
|
||||||
m_context << Instruction::ISZERO;
|
m_context << Instruction::ISZERO;
|
||||||
m_context.appendConditionalJumpTo(panicTag);
|
m_context.appendConditionalJumpTo(panicTag);
|
||||||
m_context << Instruction::POP; // remove selector
|
m_context << Instruction::POP; // remove selector
|
||||||
@ -1077,7 +1077,7 @@ void ContractCompiler::handleCatch(vector<ASTPointer<TryCatchClause>> const& _ca
|
|||||||
solAssert(m_context.evmVersion().supportsReturndata(), "");
|
solAssert(m_context.evmVersion().supportsReturndata(), "");
|
||||||
|
|
||||||
// stack: <selector>
|
// stack: <selector>
|
||||||
m_context << selectorFromSignature32("Panic(uint256)") << Instruction::EQ;
|
m_context << util::selectorFromSignature32("Panic(uint256)") << Instruction::EQ;
|
||||||
m_context << Instruction::ISZERO;
|
m_context << Instruction::ISZERO;
|
||||||
m_context.appendConditionalJumpTo(fallbackTag);
|
m_context.appendConditionalJumpTo(fallbackTag);
|
||||||
|
|
||||||
|
@ -268,7 +268,7 @@ void ExpressionCompiler::appendStateVariableAccessor(VariableDeclaration const&
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
StackTooDeepError() <<
|
StackTooDeepError() <<
|
||||||
errinfo_sourceLocation(_varDecl.location()) <<
|
errinfo_sourceLocation(_varDecl.location()) <<
|
||||||
errinfo_comment("Stack too deep.")
|
util::errinfo_comment("Stack too deep.")
|
||||||
);
|
);
|
||||||
m_context << dupInstruction(retSizeOnStack + 1);
|
m_context << dupInstruction(retSizeOnStack + 1);
|
||||||
m_context.appendJump(evmasm::AssemblyItem::JumpType::OutOfFunction);
|
m_context.appendJump(evmasm::AssemblyItem::JumpType::OutOfFunction);
|
||||||
@ -350,7 +350,7 @@ bool ExpressionCompiler::visit(Assignment const& _assignment)
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
StackTooDeepError() <<
|
StackTooDeepError() <<
|
||||||
errinfo_sourceLocation(_assignment.location()) <<
|
errinfo_sourceLocation(_assignment.location()) <<
|
||||||
errinfo_comment("Stack too deep, try removing local variables.")
|
util::errinfo_comment("Stack too deep, try removing local variables.")
|
||||||
);
|
);
|
||||||
// value [lvalue_ref] updated_value
|
// value [lvalue_ref] updated_value
|
||||||
for (unsigned i = 0; i < itemSize; ++i)
|
for (unsigned i = 0; i < itemSize; ++i)
|
||||||
@ -1452,7 +1452,7 @@ bool ExpressionCompiler::visit(FunctionCallOptions const& _functionCallOptions)
|
|||||||
solAssert(false, "Unexpected option name!");
|
solAssert(false, "Unexpected option name!");
|
||||||
acceptAndConvert(*_functionCallOptions.options()[i], *requiredType);
|
acceptAndConvert(*_functionCallOptions.options()[i], *requiredType);
|
||||||
|
|
||||||
solAssert(!contains(presentOptions, newOption), "");
|
solAssert(!util::contains(presentOptions, newOption), "");
|
||||||
ptrdiff_t insertPos = presentOptions.end() - lower_bound(presentOptions.begin(), presentOptions.end(), newOption);
|
ptrdiff_t insertPos = presentOptions.end() - lower_bound(presentOptions.begin(), presentOptions.end(), newOption);
|
||||||
|
|
||||||
utils().moveIntoStack(static_cast<unsigned>(insertPos), 1);
|
utils().moveIntoStack(static_cast<unsigned>(insertPos), 1);
|
||||||
@ -2862,7 +2862,7 @@ void ExpressionCompiler::setLValueFromDeclaration(Declaration const& _declaratio
|
|||||||
else
|
else
|
||||||
BOOST_THROW_EXCEPTION(InternalCompilerError()
|
BOOST_THROW_EXCEPTION(InternalCompilerError()
|
||||||
<< errinfo_sourceLocation(_expression.location())
|
<< errinfo_sourceLocation(_expression.location())
|
||||||
<< errinfo_comment("Identifier type not supported or identifier not found."));
|
<< util::errinfo_comment("Identifier type not supported or identifier not found."));
|
||||||
}
|
}
|
||||||
|
|
||||||
void ExpressionCompiler::setLValueToStorageItem(Expression const& _expression)
|
void ExpressionCompiler::setLValueToStorageItem(Expression const& _expression)
|
||||||
|
@ -50,7 +50,7 @@ void StackVariable::retrieveValue(SourceLocation const& _location, bool) const
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
StackTooDeepError() <<
|
StackTooDeepError() <<
|
||||||
errinfo_sourceLocation(_location) <<
|
errinfo_sourceLocation(_location) <<
|
||||||
errinfo_comment("Stack too deep, try removing local variables.")
|
util::errinfo_comment("Stack too deep, try removing local variables.")
|
||||||
);
|
);
|
||||||
solAssert(stackPos + 1 >= m_size, "Size and stack pos mismatch.");
|
solAssert(stackPos + 1 >= m_size, "Size and stack pos mismatch.");
|
||||||
for (unsigned i = 0; i < m_size; ++i)
|
for (unsigned i = 0; i < m_size; ++i)
|
||||||
@ -64,7 +64,7 @@ void StackVariable::storeValue(Type const&, SourceLocation const& _location, boo
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
StackTooDeepError() <<
|
StackTooDeepError() <<
|
||||||
errinfo_sourceLocation(_location) <<
|
errinfo_sourceLocation(_location) <<
|
||||||
errinfo_comment("Stack too deep, try removing local variables.")
|
util::errinfo_comment("Stack too deep, try removing local variables.")
|
||||||
);
|
);
|
||||||
else if (stackDiff > 0)
|
else if (stackDiff > 0)
|
||||||
for (unsigned i = 0; i < m_size; ++i)
|
for (unsigned i = 0; i < m_size; ++i)
|
||||||
@ -436,7 +436,7 @@ void StorageItem::storeValue(Type const& _sourceType, SourceLocation const& _loc
|
|||||||
BOOST_THROW_EXCEPTION(
|
BOOST_THROW_EXCEPTION(
|
||||||
InternalCompilerError()
|
InternalCompilerError()
|
||||||
<< errinfo_sourceLocation(_location)
|
<< errinfo_sourceLocation(_location)
|
||||||
<< errinfo_comment("Invalid non-value type for assignment."));
|
<< util::errinfo_comment("Invalid non-value type for assignment."));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -234,7 +234,7 @@ string IRGenerator::generate(
|
|||||||
t("deployedFunctions", m_context.functionCollector().requestedFunctions());
|
t("deployedFunctions", m_context.functionCollector().requestedFunctions());
|
||||||
t("deployedSubObjects", subObjectSources(m_context.subObjectsCreated()));
|
t("deployedSubObjects", subObjectSources(m_context.subObjectsCreated()));
|
||||||
t("metadataName", yul::Object::metadataName());
|
t("metadataName", yul::Object::metadataName());
|
||||||
t("cborMetadata", toHex(_cborMetadata));
|
t("cborMetadata", util::toHex(_cborMetadata));
|
||||||
|
|
||||||
t("useSrcMapDeployed", formatUseSrcMap(m_context));
|
t("useSrcMapDeployed", formatUseSrcMap(m_context));
|
||||||
|
|
||||||
@ -788,7 +788,7 @@ pair<string, map<ContractDefinition const*, vector<string>>> IRGenerator::evalua
|
|||||||
{
|
{
|
||||||
bool operator()(ContractDefinition const* _c1, ContractDefinition const* _c2) const
|
bool operator()(ContractDefinition const* _c1, ContractDefinition const* _c2) const
|
||||||
{
|
{
|
||||||
solAssert(contains(linearizedBaseContracts, _c1) && contains(linearizedBaseContracts, _c2), "");
|
solAssert(util::contains(linearizedBaseContracts, _c1) && util::contains(linearizedBaseContracts, _c2), "");
|
||||||
auto it1 = find(linearizedBaseContracts.begin(), linearizedBaseContracts.end(), _c1);
|
auto it1 = find(linearizedBaseContracts.begin(), linearizedBaseContracts.end(), _c1);
|
||||||
auto it2 = find(linearizedBaseContracts.begin(), linearizedBaseContracts.end(), _c2);
|
auto it2 = find(linearizedBaseContracts.begin(), linearizedBaseContracts.end(), _c2);
|
||||||
return it1 < it2;
|
return it1 < it2;
|
||||||
|
@ -1497,7 +1497,7 @@ smtutil::Expression CHC::predicate(FunctionCall const& _funCall)
|
|||||||
|
|
||||||
auto const* contract = function->annotation().contract;
|
auto const* contract = function->annotation().contract;
|
||||||
auto const& hierarchy = m_currentContract->annotation().linearizedBaseContracts;
|
auto const& hierarchy = m_currentContract->annotation().linearizedBaseContracts;
|
||||||
solAssert(kind != FunctionType::Kind::Internal || function->isFree() || (contract && contract->isLibrary()) || contains(hierarchy, contract), "");
|
solAssert(kind != FunctionType::Kind::Internal || function->isFree() || (contract && contract->isLibrary()) || util::contains(hierarchy, contract), "");
|
||||||
|
|
||||||
bool usesStaticCall = function->stateMutability() == StateMutability::Pure || function->stateMutability() == StateMutability::View;
|
bool usesStaticCall = function->stateMutability() == StateMutability::Pure || function->stateMutability() == StateMutability::View;
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ map<Predicate const*, set<string>> collectInvariants(
|
|||||||
|
|
||||||
map<string, pair<smtutil::Expression, smtutil::Expression>> equalities;
|
map<string, pair<smtutil::Expression, smtutil::Expression>> equalities;
|
||||||
// Collect equalities where one of the sides is a predicate we're interested in.
|
// Collect equalities where one of the sides is a predicate we're interested in.
|
||||||
BreadthFirstSearch<smtutil::Expression const*>{{&_proof}}.run([&](auto&& _expr, auto&& _addChild) {
|
util::BreadthFirstSearch<smtutil::Expression const*>{{&_proof}}.run([&](auto&& _expr, auto&& _addChild) {
|
||||||
if (_expr->name == "=")
|
if (_expr->name == "=")
|
||||||
for (auto const& t: targets)
|
for (auto const& t: targets)
|
||||||
{
|
{
|
||||||
|
@ -350,7 +350,7 @@ vector<optional<string>> Predicate::summaryStateValues(vector<smtutil::Expressio
|
|||||||
|
|
||||||
vector<smtutil::Expression> stateArgs(stateFirst, stateLast);
|
vector<smtutil::Expression> stateArgs(stateFirst, stateLast);
|
||||||
solAssert(stateArgs.size() == stateVars->size(), "");
|
solAssert(stateArgs.size() == stateVars->size(), "");
|
||||||
auto stateTypes = applyMap(*stateVars, [&](auto const& _var) { return _var->type(); });
|
auto stateTypes = util::applyMap(*stateVars, [&](auto const& _var) { return _var->type(); });
|
||||||
return formatExpressions(stateArgs, stateTypes);
|
return formatExpressions(stateArgs, stateTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -412,7 +412,7 @@ pair<vector<optional<string>>, vector<VariableDeclaration const*>> Predicate::lo
|
|||||||
auto first = _args.end() - static_cast<int>(localVars.size());
|
auto first = _args.end() - static_cast<int>(localVars.size());
|
||||||
vector<smtutil::Expression> outValues(first, _args.end());
|
vector<smtutil::Expression> outValues(first, _args.end());
|
||||||
|
|
||||||
auto mask = applyMap(
|
auto mask = util::applyMap(
|
||||||
localVars,
|
localVars,
|
||||||
[this](auto _var) {
|
[this](auto _var) {
|
||||||
auto varScope = dynamic_cast<ScopeOpener const*>(_var->scope());
|
auto varScope = dynamic_cast<ScopeOpener const*>(_var->scope());
|
||||||
@ -422,7 +422,7 @@ pair<vector<optional<string>>, vector<VariableDeclaration const*>> Predicate::lo
|
|||||||
auto localVarsInScope = util::filter(localVars, mask);
|
auto localVarsInScope = util::filter(localVars, mask);
|
||||||
auto outValuesInScope = util::filter(outValues, mask);
|
auto outValuesInScope = util::filter(outValues, mask);
|
||||||
|
|
||||||
auto outTypes = applyMap(localVarsInScope, [](auto _var) { return _var->type(); });
|
auto outTypes = util::applyMap(localVarsInScope, [](auto _var) { return _var->type(); });
|
||||||
return {formatExpressions(outValuesInScope, outTypes), localVarsInScope};
|
return {formatExpressions(outValuesInScope, outTypes), localVarsInScope};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -496,7 +496,7 @@ optional<string> Predicate::expressionToString(smtutil::Expression const& _expr,
|
|||||||
if (_expr.name == "0")
|
if (_expr.name == "0")
|
||||||
return "0x0";
|
return "0x0";
|
||||||
// For some reason the code below returns "0x" for "0".
|
// For some reason the code below returns "0x" for "0".
|
||||||
return toHex(toCompactBigEndian(bigint(_expr.name)), HexPrefix::Add, HexCase::Lower);
|
return util::toHex(toCompactBigEndian(bigint(_expr.name)), util::HexPrefix::Add, util::HexCase::Lower);
|
||||||
}
|
}
|
||||||
catch (out_of_range const&)
|
catch (out_of_range const&)
|
||||||
{
|
{
|
||||||
|
@ -313,7 +313,7 @@ bool SMTEncoder::visit(InlineAssembly const& _inlineAsm)
|
|||||||
{
|
{
|
||||||
auto const& vars = _assignment.variableNames;
|
auto const& vars = _assignment.variableNames;
|
||||||
for (auto const& identifier: vars)
|
for (auto const& identifier: vars)
|
||||||
if (auto externalInfo = valueOrNullptr(externalReferences, &identifier))
|
if (auto externalInfo = util::valueOrNullptr(externalReferences, &identifier))
|
||||||
if (auto varDecl = dynamic_cast<VariableDeclaration const*>(externalInfo->declaration))
|
if (auto varDecl = dynamic_cast<VariableDeclaration const*>(externalInfo->declaration))
|
||||||
assignedVars.insert(varDecl);
|
assignedVars.insert(varDecl);
|
||||||
}
|
}
|
||||||
|
@ -211,7 +211,7 @@ void SymbolicState::buildABIFunctions(set<FunctionCall const*> const& _abiFuncti
|
|||||||
|
|
||||||
|
|
||||||
auto argTypes = [](auto const& _args) {
|
auto argTypes = [](auto const& _args) {
|
||||||
return applyMap(_args, [](auto arg) { return arg->annotation().type; });
|
return util::applyMap(_args, [](auto arg) { return arg->annotation().type; });
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Since each abi.* function may have a different number of input/output parameters,
|
/// Since each abi.* function may have a different number of input/output parameters,
|
||||||
|
@ -580,7 +580,7 @@ optional<smtutil::Expression> symbolicTypeConversion(frontend::Type const* _from
|
|||||||
return smtutil::Expression(size_t(0));
|
return smtutil::Expression(size_t(0));
|
||||||
auto bytesVec = util::asBytes(strType->value());
|
auto bytesVec = util::asBytes(strType->value());
|
||||||
bytesVec.resize(fixedBytesType->numBytes(), 0);
|
bytesVec.resize(fixedBytesType->numBytes(), 0);
|
||||||
return smtutil::Expression(u256(toHex(bytesVec, util::HexPrefix::Add)));
|
return smtutil::Expression(u256(util::toHex(bytesVec, util::HexPrefix::Add)));
|
||||||
}
|
}
|
||||||
|
|
||||||
return std::nullopt;
|
return std::nullopt;
|
||||||
|
@ -278,7 +278,7 @@ void CompilerStack::setMetadataHash(MetadataHash _metadataHash)
|
|||||||
void CompilerStack::selectDebugInfo(DebugInfoSelection _debugInfoSelection)
|
void CompilerStack::selectDebugInfo(DebugInfoSelection _debugInfoSelection)
|
||||||
{
|
{
|
||||||
if (m_stackState >= CompilationSuccessful)
|
if (m_stackState >= CompilationSuccessful)
|
||||||
BOOST_THROW_EXCEPTION(CompilerError() << errinfo_comment("Must select debug info components before compilation."));
|
BOOST_THROW_EXCEPTION(CompilerError() << util::errinfo_comment("Must select debug info components before compilation."));
|
||||||
m_debugInfoSelection = _debugInfoSelection;
|
m_debugInfoSelection = _debugInfoSelection;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -573,7 +573,7 @@ bool CompilerStack::analyze()
|
|||||||
if (noErrors)
|
if (noErrors)
|
||||||
{
|
{
|
||||||
ModelChecker modelChecker(m_errorReporter, *this, m_smtlib2Responses, m_modelCheckerSettings, m_readFile);
|
ModelChecker modelChecker(m_errorReporter, *this, m_smtlib2Responses, m_modelCheckerSettings, m_readFile);
|
||||||
auto allSources = applyMap(m_sourceOrder, [](Source const* _source) { return _source->ast; });
|
auto allSources = util::applyMap(m_sourceOrder, [](Source const* _source) { return _source->ast; });
|
||||||
modelChecker.enableAllEnginesIfPragmaPresent(allSources);
|
modelChecker.enableAllEnginesIfPragmaPresent(allSources);
|
||||||
modelChecker.checkRequestedSourcesAndContracts(allSources);
|
modelChecker.checkRequestedSourcesAndContracts(allSources);
|
||||||
for (Source const* source: m_sourceOrder)
|
for (Source const* source: m_sourceOrder)
|
||||||
@ -1030,7 +1030,7 @@ Json::Value CompilerStack::interfaceSymbols(string const& _contractName) const
|
|||||||
for (ErrorDefinition const* error: contractDefinition(_contractName).interfaceErrors())
|
for (ErrorDefinition const* error: contractDefinition(_contractName).interfaceErrors())
|
||||||
{
|
{
|
||||||
string signature = error->functionType(true)->externalSignature();
|
string signature = error->functionType(true)->externalSignature();
|
||||||
interfaceSymbols["errors"][signature] = toHex(toCompactBigEndian(selectorFromSignature32(signature), 4));
|
interfaceSymbols["errors"][signature] = util::toHex(toCompactBigEndian(util::selectorFromSignature32(signature), 4));
|
||||||
}
|
}
|
||||||
|
|
||||||
for (EventDefinition const* event: ranges::concat_view(
|
for (EventDefinition const* event: ranges::concat_view(
|
||||||
@ -1040,7 +1040,7 @@ Json::Value CompilerStack::interfaceSymbols(string const& _contractName) const
|
|||||||
if (!event->isAnonymous())
|
if (!event->isAnonymous())
|
||||||
{
|
{
|
||||||
string signature = event->functionType(true)->externalSignature();
|
string signature = event->functionType(true)->externalSignature();
|
||||||
interfaceSymbols["events"][signature] = toHex(u256(h256::Arith(keccak256(signature))));
|
interfaceSymbols["events"][signature] = toHex(u256(h256::Arith(util::keccak256(signature))));
|
||||||
}
|
}
|
||||||
|
|
||||||
return interfaceSymbols;
|
return interfaceSymbols;
|
||||||
@ -1494,7 +1494,7 @@ string CompilerStack::createMetadata(Contract const& _contract, bool _forIR) con
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
solAssert(s.second.charStream, "Character stream not available");
|
solAssert(s.second.charStream, "Character stream not available");
|
||||||
meta["sources"][s.first]["keccak256"] = "0x" + toHex(s.second.keccak256().asBytes());
|
meta["sources"][s.first]["keccak256"] = "0x" + util::toHex(s.second.keccak256().asBytes());
|
||||||
if (optional<string> licenseString = s.second.ast->licenseString())
|
if (optional<string> licenseString = s.second.ast->licenseString())
|
||||||
meta["sources"][s.first]["license"] = *licenseString;
|
meta["sources"][s.first]["license"] = *licenseString;
|
||||||
if (m_metadataLiteralSources)
|
if (m_metadataLiteralSources)
|
||||||
@ -1502,7 +1502,7 @@ string CompilerStack::createMetadata(Contract const& _contract, bool _forIR) con
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
meta["sources"][s.first]["urls"] = Json::arrayValue;
|
meta["sources"][s.first]["urls"] = Json::arrayValue;
|
||||||
meta["sources"][s.first]["urls"].append("bzz-raw://" + toHex(s.second.swarmHash().asBytes()));
|
meta["sources"][s.first]["urls"].append("bzz-raw://" + util::toHex(s.second.swarmHash().asBytes()));
|
||||||
meta["sources"][s.first]["urls"].append(s.second.ipfsUrl());
|
meta["sources"][s.first]["urls"].append(s.second.ipfsUrl());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1565,7 +1565,7 @@ string CompilerStack::createMetadata(Contract const& _contract, bool _forIR) con
|
|||||||
|
|
||||||
meta["settings"]["libraries"] = Json::objectValue;
|
meta["settings"]["libraries"] = Json::objectValue;
|
||||||
for (auto const& library: m_libraries)
|
for (auto const& library: m_libraries)
|
||||||
meta["settings"]["libraries"][library.first] = "0x" + toHex(library.second.asBytes());
|
meta["settings"]["libraries"][library.first] = "0x" + util::toHex(library.second.asBytes());
|
||||||
|
|
||||||
meta["output"]["abi"] = contractABI(_contract);
|
meta["output"]["abi"] = contractABI(_contract);
|
||||||
meta["output"]["userdoc"] = natspecUser(_contract);
|
meta["output"]["userdoc"] = natspecUser(_contract);
|
||||||
|
@ -253,7 +253,7 @@ bool LanguageServer::run()
|
|||||||
string const methodName = (*jsonMessage)["method"].asString();
|
string const methodName = (*jsonMessage)["method"].asString();
|
||||||
id = (*jsonMessage)["id"];
|
id = (*jsonMessage)["id"];
|
||||||
|
|
||||||
if (auto handler = valueOrDefault(m_handlers, methodName))
|
if (auto handler = util::valueOrDefault(m_handlers, methodName))
|
||||||
handler(id, (*jsonMessage)["params"]);
|
handler(id, (*jsonMessage)["params"]);
|
||||||
else
|
else
|
||||||
m_client.error(id, ErrorCode::MethodNotFound, "Unknown method " + methodName);
|
m_client.error(id, ErrorCode::MethodNotFound, "Unknown method " + methodName);
|
||||||
@ -375,7 +375,7 @@ void LanguageServer::handleTextDocumentDidChange(Json::Value const& _args)
|
|||||||
lspAssert(
|
lspAssert(
|
||||||
change && change->hasText(),
|
change && change->hasText(),
|
||||||
ErrorCode::RequestFailed,
|
ErrorCode::RequestFailed,
|
||||||
"Invalid source range: " + jsonCompactPrint(jsonContentChange["range"])
|
"Invalid source range: " + util::jsonCompactPrint(jsonContentChange["range"])
|
||||||
);
|
);
|
||||||
|
|
||||||
string buffer = m_fileRepository.sourceUnits().at(sourceUnitName);
|
string buffer = m_fileRepository.sourceUnits().at(sourceUnitName);
|
||||||
|
@ -69,7 +69,7 @@ private:
|
|||||||
{ \
|
{ \
|
||||||
BOOST_THROW_EXCEPTION( \
|
BOOST_THROW_EXCEPTION( \
|
||||||
RequestError(errorCode) << \
|
RequestError(errorCode) << \
|
||||||
errinfo_comment(errorMessage) \
|
util::errinfo_comment(errorMessage) \
|
||||||
); \
|
); \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ bytes encodeLinkData(bytes const& _data)
|
|||||||
string base58Encode(bytes const& _data)
|
string base58Encode(bytes const& _data)
|
||||||
{
|
{
|
||||||
static string const alphabet{"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"};
|
static string const alphabet{"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"};
|
||||||
bigint data(toHex(_data, HexPrefix::Add));
|
bigint data(util::toHex(_data, HexPrefix::Add));
|
||||||
string output;
|
string output;
|
||||||
while (data)
|
while (data)
|
||||||
{
|
{
|
||||||
|
@ -91,13 +91,13 @@ string Object::toString(
|
|||||||
set<YulString> Object::qualifiedDataNames() const
|
set<YulString> Object::qualifiedDataNames() const
|
||||||
{
|
{
|
||||||
set<YulString> qualifiedNames =
|
set<YulString> qualifiedNames =
|
||||||
name.empty() || contains(name.str(), '.') ?
|
name.empty() || util::contains(name.str(), '.') ?
|
||||||
set<YulString>{} :
|
set<YulString>{} :
|
||||||
set<YulString>{name};
|
set<YulString>{name};
|
||||||
for (shared_ptr<ObjectNode> const& subObjectNode: subObjects)
|
for (shared_ptr<ObjectNode> const& subObjectNode: subObjects)
|
||||||
{
|
{
|
||||||
yulAssert(qualifiedNames.count(subObjectNode->name) == 0, "");
|
yulAssert(qualifiedNames.count(subObjectNode->name) == 0, "");
|
||||||
if (contains(subObjectNode->name.str(), '.'))
|
if (util::contains(subObjectNode->name.str(), '.'))
|
||||||
continue;
|
continue;
|
||||||
qualifiedNames.insert(subObjectNode->name);
|
qualifiedNames.insert(subObjectNode->name);
|
||||||
if (auto const* subObject = dynamic_cast<Object const*>(subObjectNode.get()))
|
if (auto const* subObject = dynamic_cast<Object const*>(subObjectNode.get()))
|
||||||
|
@ -367,7 +367,7 @@ void DataFlowAnalyzer::joinKnowledgeHelper(
|
|||||||
// of m_memory and thus any overlapping write would have cleared the keys
|
// of m_memory and thus any overlapping write would have cleared the keys
|
||||||
// that are not known to be different inside m_memory already.
|
// that are not known to be different inside m_memory already.
|
||||||
cxx20::erase_if(_this, mapTuple([&_older](auto&& key, auto&& currentValue){
|
cxx20::erase_if(_this, mapTuple([&_older](auto&& key, auto&& currentValue){
|
||||||
YulString const* oldValue = valueOrNullptr(_older, key);
|
YulString const* oldValue = util::valueOrNullptr(_older, key);
|
||||||
return !oldValue || *oldValue != currentValue;
|
return !oldValue || *oldValue != currentValue;
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
@ -54,13 +54,13 @@ void EqualStoreEliminator::visit(Statement& _statement)
|
|||||||
{
|
{
|
||||||
if (auto vars = isSimpleStore(StoreLoadLocation::Storage, *expression))
|
if (auto vars = isSimpleStore(StoreLoadLocation::Storage, *expression))
|
||||||
{
|
{
|
||||||
if (auto const* currentValue = valueOrNullptr(m_storage, vars->first))
|
if (auto const* currentValue = util::valueOrNullptr(m_storage, vars->first))
|
||||||
if (*currentValue == vars->second)
|
if (*currentValue == vars->second)
|
||||||
m_pendingRemovals.insert(&_statement);
|
m_pendingRemovals.insert(&_statement);
|
||||||
}
|
}
|
||||||
else if (auto vars = isSimpleStore(StoreLoadLocation::Memory, *expression))
|
else if (auto vars = isSimpleStore(StoreLoadLocation::Memory, *expression))
|
||||||
{
|
{
|
||||||
if (auto const* currentValue = valueOrNullptr(m_memory, vars->first))
|
if (auto const* currentValue = util::valueOrNullptr(m_memory, vars->first))
|
||||||
if (*currentValue == vars->second)
|
if (*currentValue == vars->second)
|
||||||
m_pendingRemovals.insert(&_statement);
|
m_pendingRemovals.insert(&_statement);
|
||||||
}
|
}
|
||||||
|
@ -464,7 +464,7 @@ void CommandLineInterface::readInputFiles()
|
|||||||
for (auto const& [sourceUnitName, normalizedInputPaths]: collisions)
|
for (auto const& [sourceUnitName, normalizedInputPaths]: collisions)
|
||||||
{
|
{
|
||||||
message += sourceUnitName + " matches: ";
|
message += sourceUnitName + " matches: ";
|
||||||
message += joinHumanReadable(normalizedInputPaths | ranges::views::transform(pathToQuotedString)) + "\n";
|
message += util::joinHumanReadable(normalizedInputPaths | ranges::views::transform(pathToQuotedString)) + "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
solThrow(CommandLineValidationError, message);
|
solThrow(CommandLineValidationError, message);
|
||||||
@ -963,7 +963,7 @@ void CommandLineInterface::link()
|
|||||||
string foundPlaceholder(it, it + placeholderSize);
|
string foundPlaceholder(it, it + placeholderSize);
|
||||||
if (librariesReplacements.count(foundPlaceholder))
|
if (librariesReplacements.count(foundPlaceholder))
|
||||||
{
|
{
|
||||||
string hexStr(toHex(librariesReplacements.at(foundPlaceholder).asBytes()));
|
string hexStr(util::toHex(librariesReplacements.at(foundPlaceholder).asBytes()));
|
||||||
copy(hexStr.begin(), hexStr.end(), it);
|
copy(hexStr.begin(), hexStr.end(), it);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -166,7 +166,7 @@ ostream& operator<<(ostream& _out, CompilerOutputs const& _selection)
|
|||||||
if (_selection.*component)
|
if (_selection.*component)
|
||||||
serializedSelection.push_back(CompilerOutputs::componentName(component));
|
serializedSelection.push_back(CompilerOutputs::componentName(component));
|
||||||
|
|
||||||
return _out << joinHumanReadable(serializedSelection, ",");
|
return _out << util::joinHumanReadable(serializedSelection, ",");
|
||||||
}
|
}
|
||||||
|
|
||||||
string const& CompilerOutputs::componentName(bool CompilerOutputs::* _component)
|
string const& CompilerOutputs::componentName(bool CompilerOutputs::* _component)
|
||||||
@ -197,7 +197,7 @@ ostream& operator<<(ostream& _out, CombinedJsonRequests const& _requests)
|
|||||||
if (_requests.*component)
|
if (_requests.*component)
|
||||||
serializedRequests.push_back(CombinedJsonRequests::componentName(component));
|
serializedRequests.push_back(CombinedJsonRequests::componentName(component));
|
||||||
|
|
||||||
return _out << joinHumanReadable(serializedRequests, ",");
|
return _out << util::joinHumanReadable(serializedRequests, ",");
|
||||||
}
|
}
|
||||||
|
|
||||||
string const& CombinedJsonRequests::componentName(bool CombinedJsonRequests::* _component)
|
string const& CombinedJsonRequests::componentName(bool CombinedJsonRequests::* _component)
|
||||||
@ -343,17 +343,17 @@ void CommandLineParser::parseLibraryOption(string const& _input)
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (fs::is_regular_file(_input))
|
if (fs::is_regular_file(_input))
|
||||||
data = readFileAsString(_input);
|
data = util::readFileAsString(_input);
|
||||||
}
|
}
|
||||||
catch (fs::filesystem_error const&)
|
catch (fs::filesystem_error const&)
|
||||||
{
|
{
|
||||||
// Thrown e.g. if path is too long.
|
// Thrown e.g. if path is too long.
|
||||||
}
|
}
|
||||||
catch (FileNotFound const&)
|
catch (util::FileNotFound const&)
|
||||||
{
|
{
|
||||||
// Should not happen if `fs::is_regular_file` is correct.
|
// Should not happen if `fs::is_regular_file` is correct.
|
||||||
}
|
}
|
||||||
catch (NotAFile const&)
|
catch (util::NotAFile const&)
|
||||||
{
|
{
|
||||||
// Should not happen if `fs::is_regular_file` is correct.
|
// Should not happen if `fs::is_regular_file` is correct.
|
||||||
}
|
}
|
||||||
@ -418,15 +418,15 @@ void CommandLineParser::parseLibraryOption(string const& _input)
|
|||||||
"Invalid length for address for library \"" + libName + "\": " +
|
"Invalid length for address for library \"" + libName + "\": " +
|
||||||
to_string(addrString.length()) + " instead of 40 characters."
|
to_string(addrString.length()) + " instead of 40 characters."
|
||||||
);
|
);
|
||||||
if (!passesAddressChecksum(addrString, false))
|
if (!util::passesAddressChecksum(addrString, false))
|
||||||
solThrow(
|
solThrow(
|
||||||
CommandLineValidationError,
|
CommandLineValidationError,
|
||||||
"Invalid checksum on address for library \"" + libName + "\": " + addrString + "\n"
|
"Invalid checksum on address for library \"" + libName + "\": " + addrString + "\n"
|
||||||
"The correct checksum is " + getChecksummedAddress(addrString)
|
"The correct checksum is " + util::getChecksummedAddress(addrString)
|
||||||
);
|
);
|
||||||
bytes binAddr = fromHex(addrString);
|
bytes binAddr = util::fromHex(addrString);
|
||||||
h160 address(binAddr, h160::AlignRight);
|
util::h160 address(binAddr, util::h160::AlignRight);
|
||||||
if (binAddr.size() > 20 || address == h160())
|
if (binAddr.size() > 20 || address == util::h160())
|
||||||
solThrow(
|
solThrow(
|
||||||
CommandLineValidationError,
|
CommandLineValidationError,
|
||||||
"Invalid address for library \"" + libName + "\": " + addrString
|
"Invalid address for library \"" + libName + "\": " + addrString
|
||||||
@ -461,9 +461,9 @@ void CommandLineParser::parseOutputSelection()
|
|||||||
solAssert(false);
|
solAssert(false);
|
||||||
case InputMode::Compiler:
|
case InputMode::Compiler:
|
||||||
case InputMode::CompilerWithASTImport:
|
case InputMode::CompilerWithASTImport:
|
||||||
return contains(compilerModeOutputs, _outputName);
|
return util::contains(compilerModeOutputs, _outputName);
|
||||||
case InputMode::Assembler:
|
case InputMode::Assembler:
|
||||||
return contains(assemblerModeOutputs, _outputName);
|
return util::contains(assemblerModeOutputs, _outputName);
|
||||||
case InputMode::StandardJson:
|
case InputMode::StandardJson:
|
||||||
case InputMode::Linker:
|
case InputMode::Linker:
|
||||||
return false;
|
return false;
|
||||||
@ -582,15 +582,15 @@ General Information)").c_str(),
|
|||||||
)
|
)
|
||||||
(
|
(
|
||||||
g_strRevertStrings.c_str(),
|
g_strRevertStrings.c_str(),
|
||||||
po::value<string>()->value_name(joinHumanReadable(g_revertStringsArgs, ",")),
|
po::value<string>()->value_name(util::joinHumanReadable(g_revertStringsArgs, ",")),
|
||||||
"Strip revert (and require) reason strings or add additional debugging information."
|
"Strip revert (and require) reason strings or add additional debugging information."
|
||||||
)
|
)
|
||||||
(
|
(
|
||||||
g_strDebugInfo.c_str(),
|
g_strDebugInfo.c_str(),
|
||||||
po::value<string>()->default_value(toString(DebugInfoSelection::Default())),
|
po::value<string>()->default_value(util::toString(DebugInfoSelection::Default())),
|
||||||
("Debug info components to be included in the produced EVM assembly and Yul code. "
|
("Debug info components to be included in the produced EVM assembly and Yul code. "
|
||||||
"Value can be all, none or a comma-separated list containing one or more of the "
|
"Value can be all, none or a comma-separated list containing one or more of the "
|
||||||
"following components: " + joinHumanReadable(DebugInfoSelection::componentMap() | ranges::views::keys) + ".").c_str()
|
"following components: " + util::joinHumanReadable(DebugInfoSelection::componentMap() | ranges::views::keys) + ".").c_str()
|
||||||
)
|
)
|
||||||
(
|
(
|
||||||
g_strStopAfter.c_str(),
|
g_strStopAfter.c_str(),
|
||||||
@ -648,12 +648,12 @@ General Information)").c_str(),
|
|||||||
assemblyModeOptions.add_options()
|
assemblyModeOptions.add_options()
|
||||||
(
|
(
|
||||||
g_strMachine.c_str(),
|
g_strMachine.c_str(),
|
||||||
po::value<string>()->value_name(joinHumanReadable(g_machineArgs, ",")),
|
po::value<string>()->value_name(util::joinHumanReadable(g_machineArgs, ",")),
|
||||||
"Target machine in assembly or Yul mode."
|
"Target machine in assembly or Yul mode."
|
||||||
)
|
)
|
||||||
(
|
(
|
||||||
g_strYulDialect.c_str(),
|
g_strYulDialect.c_str(),
|
||||||
po::value<string>()->value_name(joinHumanReadable(g_yulDialectArgs, ",")),
|
po::value<string>()->value_name(util::joinHumanReadable(g_yulDialectArgs, ",")),
|
||||||
"Input dialect to use in assembly or yul mode."
|
"Input dialect to use in assembly or yul mode."
|
||||||
)
|
)
|
||||||
;
|
;
|
||||||
@ -726,7 +726,7 @@ General Information)").c_str(),
|
|||||||
)
|
)
|
||||||
(
|
(
|
||||||
g_strCombinedJson.c_str(),
|
g_strCombinedJson.c_str(),
|
||||||
po::value<string>()->value_name(joinHumanReadable(CombinedJsonRequests::componentMap() | ranges::views::keys, ",")),
|
po::value<string>()->value_name(util::joinHumanReadable(CombinedJsonRequests::componentMap() | ranges::views::keys, ",")),
|
||||||
"Output a single json document containing the specified information."
|
"Output a single json document containing the specified information."
|
||||||
)
|
)
|
||||||
;
|
;
|
||||||
@ -736,7 +736,7 @@ General Information)").c_str(),
|
|||||||
metadataOptions.add_options()
|
metadataOptions.add_options()
|
||||||
(
|
(
|
||||||
g_strMetadataHash.c_str(),
|
g_strMetadataHash.c_str(),
|
||||||
po::value<string>()->value_name(joinHumanReadable(g_metadataHashArgs, ",")),
|
po::value<string>()->value_name(util::joinHumanReadable(g_metadataHashArgs, ",")),
|
||||||
"Choose hash method for the bytecode metadata or disable it."
|
"Choose hash method for the bytecode metadata or disable it."
|
||||||
)
|
)
|
||||||
(
|
(
|
||||||
@ -1011,11 +1011,11 @@ void CommandLineParser::processArgs()
|
|||||||
|
|
||||||
if (m_args.count(g_strPrettyJson) > 0)
|
if (m_args.count(g_strPrettyJson) > 0)
|
||||||
{
|
{
|
||||||
m_options.formatting.json.format = JsonFormat::Pretty;
|
m_options.formatting.json.format = util::JsonFormat::Pretty;
|
||||||
}
|
}
|
||||||
if (!m_args[g_strJsonIndent].defaulted())
|
if (!m_args[g_strJsonIndent].defaulted())
|
||||||
{
|
{
|
||||||
m_options.formatting.json.format = JsonFormat::Pretty;
|
m_options.formatting.json.format = util::JsonFormat::Pretty;
|
||||||
m_options.formatting.json.indent = m_args[g_strJsonIndent].as<uint32_t>();
|
m_options.formatting.json.indent = m_args[g_strJsonIndent].as<uint32_t>();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1289,7 +1289,7 @@ size_t CommandLineParser::countEnabledOptions(vector<string> const& _optionNames
|
|||||||
|
|
||||||
string CommandLineParser::joinOptionNames(vector<string> const& _optionNames, string _separator)
|
string CommandLineParser::joinOptionNames(vector<string> const& _optionNames, string _separator)
|
||||||
{
|
{
|
||||||
return joinHumanReadable(
|
return util::joinHumanReadable(
|
||||||
_optionNames | ranges::views::transform([](string const& _option){ return "--" + _option; }),
|
_optionNames | ranges::views::transform([](string const& _option){ return "--" + _option; }),
|
||||||
_separator
|
_separator
|
||||||
);
|
);
|
||||||
|
@ -70,10 +70,10 @@ SemanticTest::SemanticTest(
|
|||||||
static set<string> const legacyRunTriggers{"also", "false", "default"};
|
static set<string> const legacyRunTriggers{"also", "false", "default"};
|
||||||
|
|
||||||
string compileViaYul = m_reader.stringSetting("compileViaYul", "default");
|
string compileViaYul = m_reader.stringSetting("compileViaYul", "default");
|
||||||
if (!contains(compileViaYulAllowedValues, compileViaYul))
|
if (!util::contains(compileViaYulAllowedValues, compileViaYul))
|
||||||
BOOST_THROW_EXCEPTION(runtime_error("Invalid compileViaYul value: " + compileViaYul + "."));
|
BOOST_THROW_EXCEPTION(runtime_error("Invalid compileViaYul value: " + compileViaYul + "."));
|
||||||
m_testCaseWantsYulRun = contains(yulRunTriggers, compileViaYul);
|
m_testCaseWantsYulRun = util::contains(yulRunTriggers, compileViaYul);
|
||||||
m_testCaseWantsLegacyRun = contains(legacyRunTriggers, compileViaYul);
|
m_testCaseWantsLegacyRun = util::contains(legacyRunTriggers, compileViaYul);
|
||||||
|
|
||||||
// Do not enforce via yul and ewasm, if via yul was explicitly denied.
|
// Do not enforce via yul and ewasm, if via yul was explicitly denied.
|
||||||
if (compileViaYul == "false")
|
if (compileViaYul == "false")
|
||||||
@ -189,7 +189,7 @@ vector<SideEffectHook> SemanticTest::makeSideEffectHooks() const
|
|||||||
{
|
{
|
||||||
vector<string> result;
|
vector<string> result;
|
||||||
for (auto const& argument: _call.arguments.parameters)
|
for (auto const& argument: _call.arguments.parameters)
|
||||||
result.emplace_back(toHex(argument.rawBytes));
|
result.emplace_back(util::toHex(argument.rawBytes));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
return {};
|
return {};
|
||||||
|
@ -4074,12 +4074,12 @@ BOOST_AUTO_TEST_CASE(strip_reason_strings)
|
|||||||
m_optimiserSettings == OptimiserSettings::none()
|
m_optimiserSettings == OptimiserSettings::none()
|
||||||
)
|
)
|
||||||
// check that the reason string IS part of the binary.
|
// check that the reason string IS part of the binary.
|
||||||
BOOST_CHECK(toHex(m_output).find("736f6d6520726561736f6e") != std::string::npos);
|
BOOST_CHECK(util::toHex(m_output).find("736f6d6520726561736f6e") != std::string::npos);
|
||||||
|
|
||||||
m_revertStrings = RevertStrings::Strip;
|
m_revertStrings = RevertStrings::Strip;
|
||||||
compileAndRun(sourceCode, 0, "C");
|
compileAndRun(sourceCode, 0, "C");
|
||||||
// check that the reason string is NOT part of the binary.
|
// check that the reason string is NOT part of the binary.
|
||||||
BOOST_CHECK(toHex(m_output).find("736f6d6520726561736f6e") == std::string::npos);
|
BOOST_CHECK(util::toHex(m_output).find("736f6d6520726561736f6e") == std::string::npos);
|
||||||
|
|
||||||
ABI_CHECK(callContractFunction("f(bool)", true), encodeArgs(7));
|
ABI_CHECK(callContractFunction("f(bool)", true), encodeArgs(7));
|
||||||
ABI_CHECK(callContractFunction("f(bool)", false), encodeArgs());
|
ABI_CHECK(callContractFunction("f(bool)", false), encodeArgs());
|
||||||
|
@ -350,7 +350,7 @@ BOOST_AUTO_TEST_CASE(arithmetic)
|
|||||||
uint8_t(Instruction::JUMPDEST),
|
uint8_t(Instruction::JUMPDEST),
|
||||||
uint8_t(Instruction::PUSH32)
|
uint8_t(Instruction::PUSH32)
|
||||||
} +
|
} +
|
||||||
fromHex("4E487B7100000000000000000000000000000000000000000000000000000000") +
|
util::fromHex("4E487B7100000000000000000000000000000000000000000000000000000000") +
|
||||||
bytes{
|
bytes{
|
||||||
uint8_t(Instruction::PUSH1), 0x0,
|
uint8_t(Instruction::PUSH1), 0x0,
|
||||||
uint8_t(Instruction::MSTORE),
|
uint8_t(Instruction::MSTORE),
|
||||||
|
@ -98,8 +98,8 @@ public:
|
|||||||
BOOST_CHECK_MESSAGE(!optimizedOutput.empty(), "No optimized output for " + _sig);
|
BOOST_CHECK_MESSAGE(!optimizedOutput.empty(), "No optimized output for " + _sig);
|
||||||
BOOST_CHECK_MESSAGE(!nonOptimizedOutput.empty(), "No un-optimized output for " + _sig);
|
BOOST_CHECK_MESSAGE(!nonOptimizedOutput.empty(), "No un-optimized output for " + _sig);
|
||||||
BOOST_CHECK_MESSAGE(nonOptimizedOutput == optimizedOutput, "Computed values do not match."
|
BOOST_CHECK_MESSAGE(nonOptimizedOutput == optimizedOutput, "Computed values do not match."
|
||||||
"\nNon-Optimized: " + toHex(nonOptimizedOutput) +
|
"\nNon-Optimized: " + util::toHex(nonOptimizedOutput) +
|
||||||
"\nOptimized: " + toHex(optimizedOutput));
|
"\nOptimized: " + util::toHex(optimizedOutput));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @returns the number of instructions in the given bytecode, not taking the metadata hash
|
/// @returns the number of instructions in the given bytecode, not taking the metadata hash
|
||||||
|
@ -47,6 +47,7 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
using namespace solidity::util;
|
||||||
using namespace solidity::langutil;
|
using namespace solidity::langutil;
|
||||||
using namespace solidity::frontend;
|
using namespace solidity::frontend;
|
||||||
|
|
||||||
|
@ -219,7 +219,7 @@ string BytesUtils::formatString(bytes const& _bytes, size_t _cutOff)
|
|||||||
if (isprint(v))
|
if (isprint(v))
|
||||||
os << v;
|
os << v;
|
||||||
else
|
else
|
||||||
os << "\\x" << toHex(v, HexCase::Lower);
|
os << "\\x" << util::toHex(v, HexCase::Lower);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
os << "\"";
|
os << "\"";
|
||||||
|
@ -324,7 +324,7 @@ string TestFunctionCall::formatRawParameters(
|
|||||||
for (auto const c: param.rawString)
|
for (auto const c: param.rawString)
|
||||||
// NOTE: Even though we have a toHex() overload specifically for uint8_t, the compiler
|
// NOTE: Even though we have a toHex() overload specifically for uint8_t, the compiler
|
||||||
// chooses the one for bytes if the second argument is omitted.
|
// chooses the one for bytes if the second argument is omitted.
|
||||||
os << (c >= ' ' ? string(1, c) : "\\x" + toHex(static_cast<uint8_t>(c), HexCase::Lower));
|
os << (c >= ' ' ? string(1, c) : "\\x" + util::toHex(static_cast<uint8_t>(c), HexCase::Lower));
|
||||||
if (¶m != &_params.back())
|
if (¶m != &_params.back())
|
||||||
os << ", ";
|
os << ", ";
|
||||||
}
|
}
|
||||||
|
@ -43,6 +43,7 @@
|
|||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace solidity::frontend;
|
using namespace solidity::frontend;
|
||||||
using namespace solidity::test;
|
using namespace solidity::test;
|
||||||
|
using namespace solidity::util;
|
||||||
|
|
||||||
using PathSet = set<boost::filesystem::path>;
|
using PathSet = set<boost::filesystem::path>;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user