diff --git a/libsolidity/formal/SymbolicTypes.cpp b/libsolidity/formal/SymbolicTypes.cpp index 45b872b3d..ad001e8e5 100644 --- a/libsolidity/formal/SymbolicTypes.cpp +++ b/libsolidity/formal/SymbolicTypes.cpp @@ -23,12 +23,24 @@ #include #include #include +#include #include #include using namespace solidity::util; using namespace solidity::smtutil; +namespace +{ + // HACK to get around Z3 bug in printing type names with spaces (https://github.com/Z3Prover/z3/issues/6850) + void sanitizeTypeName(std::string& name) + { + std::replace(name.begin(), name.end(), ' ', '_'); + std::replace(name.begin(), name.end(), '(', '['); + std::replace(name.begin(), name.end(), ')', ']'); + } +} + namespace solidity::frontend::smt { @@ -118,13 +130,16 @@ SortPointer smtSort(frontend::Type const& _type) else if (baseType->category() == frontend::Type::Category::FixedBytes) tupleName = "fixedbytes"; else + { tupleName = arrayType->baseType()->toString(true); + } tupleName += "_array"; } else tupleName = _type.toString(true); + sanitizeTypeName(tupleName); tupleName += "_tuple"; return std::make_shared( @@ -136,7 +151,9 @@ SortPointer smtSort(frontend::Type const& _type) case Kind::Tuple: { std::vector members; - auto const& tupleName = _type.toString(true); + auto tupleName = _type.toString(true); + sanitizeTypeName(tupleName); + std::vector sorts; if (auto const* tupleType = dynamic_cast(&_type))