Remove the inaccurate Type::categoryName() and change the error message for invalid calls to one independent of the category

This commit is contained in:
Kamil Śliwak 2023-04-20 13:39:08 +02:00
parent a77d4e281f
commit 34da6c8811
16 changed files with 13 additions and 57 deletions

View File

@ -2847,11 +2847,7 @@ bool TypeChecker::visit(FunctionCall const& _functionCall)
} }
default: default:
m_errorReporter.fatalTypeError( m_errorReporter.fatalTypeError(5704_error, _functionCall.location(), "This expression is not callable.");
5704_error,
_functionCall.location(),
capitalized(Type::categoryName(expressionType->category())) + " is not callable."
);
// Unreachable, because fatalTypeError throws. We don't set kind, but that's okay because the switch below // Unreachable, because fatalTypeError throws. We don't set kind, but that's okay because the switch below
// is never reached. And, even if it was, SetOnce would trigger an assertion violation and not UB. // is never reached. And, even if it was, SetOnce would trigger an assertion violation and not UB.
funcCallAnno.isPure = argumentsArePure; funcCallAnno.isPure = argumentsArePure;

View File

@ -294,35 +294,6 @@ Type const* Type::commonType(Type const* _a, Type const* _b)
return nullptr; return nullptr;
} }
char const* Type::categoryName(Type::Category _category)
{
switch (_category)
{
case Category::Address: return "address";
case Category::Integer: return "integer";
case Category::RationalNumber: return "rational number literal";
case Category::StringLiteral: return "string literal";
case Category::Bool: return "boolean";
case Category::FixedPoint: return "fixed-point number";
case Category::Array: return "array";
case Category::ArraySlice: return "array slice";
case Category::FixedBytes: return "fixed-size byte array";
case Category::Contract: return "contract";
case Category::Struct: return "struct";
case Category::Function: return "function";
case Category::Enum: return "enum";
case Category::UserDefinedValueType: return "user-defined value type";
case Category::Tuple: return "tuple";
case Category::Mapping: return "mapping";
case Category::TypeType: return "type of a type";
case Category::Modifier: return "modifier";
case Category::Magic: return "magic variable";
case Category::Module: return "module";
case Category::InaccessibleDynamic: return "inaccessible dynamic value";
}
util::unreachable();
}
MemberList const& Type::members(ASTNode const* _currentScope) const MemberList const& Type::members(ASTNode const* _currentScope) const
{ {
if (!m_members[_currentScope]) if (!m_members[_currentScope])

View File

@ -201,8 +201,6 @@ public:
static Type const* commonType(Type const* _a, Type const* _b); static Type const* commonType(Type const* _a, Type const* _b);
virtual Category category() const = 0; virtual Category category() const = 0;
static char const* categoryName(Type::Category _category);
/// @returns a valid solidity identifier such that two types should compare equal if and /// @returns a valid solidity identifier such that two types should compare equal if and
/// only if they have the same identifier. /// only if they have the same identifier.
/// The identifier should start with "t_". /// The identifier should start with "t_".

View File

@ -160,15 +160,6 @@ inline std::string toLower(std::string _s)
return _s; return _s;
} }
/// Returns a copy of the string with the first character converted to its uppercase equivalent.
/// Uses the classic "C" locale semantics.
inline std::string capitalized(std::string _s)
{
if (_s.size() > 0)
_s[0] = toUpper(_s[0]);
return _s;
}
/// Checks whether _c is a decimal digit character. It uses the classic "C" locale semantics. /// Checks whether _c is a decimal digit character. It uses the classic "C" locale semantics.
/// @param _c character to be checked /// @param _c character to be checked
/// @return true if _c is a decimal digit character, false otherwise /// @return true if _c is a decimal digit character, false otherwise

View File

@ -4,4 +4,4 @@ contract C {
uint a = E.B(1000); uint a = E.B(1000);
} }
// ---- // ----
// TypeError 5704: (46-55): Enum is not callable. // TypeError 5704: (46-55): This expression is not callable.

View File

@ -5,4 +5,4 @@ contract C
} }
} }
// ---- // ----
// TypeError 5704: (53-60): Rational number literal is not callable. // TypeError 5704: (53-60): This expression is not callable.

View File

@ -2,4 +2,4 @@ contract C {
uint a = msg(1000); uint a = msg(1000);
} }
// ---- // ----
// TypeError 5704: (26-35): Magic variable is not callable. // TypeError 5704: (26-35): This expression is not callable.

View File

@ -3,4 +3,4 @@ contract C {
uint a = m(1000); uint a = m(1000);
} }
// ---- // ----
// TypeError 5704: (56-63): Mapping is not callable. // TypeError 5704: (56-63): This expression is not callable.

View File

@ -4,4 +4,4 @@ contract C {
modifier m(uint) { _; } modifier m(uint) { _; }
} }
// ---- // ----
// TypeError 5704: (26-33): Modifier is not callable. // TypeError 5704: (26-33): This expression is not callable.

View File

@ -6,4 +6,4 @@ contract C {
uint a = A(1000); uint a = A(1000);
} }
// ---- // ----
// TypeError 5704: (B.sol:48-55): Module is not callable. // TypeError 5704: (B.sol:48-55): This expression is not callable.

View File

@ -6,4 +6,4 @@ contract C {
} }
} }
// ---- // ----
// TypeError 5704: (72-78): Contract is not callable. // TypeError 5704: (72-78): This expression is not callable.

View File

@ -6,4 +6,4 @@ contract C {
} }
} }
// ---- // ----
// TypeError 5704: (90-108): Rational number literal is not callable. // TypeError 5704: (90-108): This expression is not callable.

View File

@ -6,4 +6,4 @@ contract C {
} }
} }
// ---- // ----
// TypeError 5704: (153-157): Mapping is not callable. // TypeError 5704: (153-157): This expression is not callable.

View File

@ -11,4 +11,4 @@ contract SomeContract {
} }
// ---- // ----
// DeclarationError 2333: (106-145): Identifier already declared. // DeclarationError 2333: (106-145): Identifier already declared.
// TypeError 5704: (185-195): Integer is not callable. // TypeError 5704: (185-195): This expression is not callable.

View File

@ -7,4 +7,4 @@ contract CrashContract {
} }
} }
// ---- // ----
// TypeError 5704: (170-177): Rational number literal is not callable. // TypeError 5704: (170-177): This expression is not callable.

View File

@ -4,4 +4,4 @@ contract C {
} }
} }
// ---- // ----
// TypeError 5704: (59-63): Rational number literal is not callable. // TypeError 5704: (59-63): This expression is not callable.