Merge pull request #14143 from ethereum/remove-type-categoryname

Remove the inaccurate `Type::categoryName()`
This commit is contained in:
Daniel 2023-04-23 22:05:35 +02:00 committed by GitHub
commit cd5ae26e34
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
16 changed files with 13 additions and 57 deletions

View File

@ -2847,11 +2847,7 @@ bool TypeChecker::visit(FunctionCall const& _functionCall)
}
default:
m_errorReporter.fatalTypeError(
5704_error,
_functionCall.location(),
capitalized(Type::categoryName(expressionType->category())) + " is not callable."
);
m_errorReporter.fatalTypeError(5704_error, _functionCall.location(), "This expression is not callable.");
// 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.
funcCallAnno.isPure = argumentsArePure;

View File

@ -294,35 +294,6 @@ Type const* Type::commonType(Type const* _a, Type const* _b)
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
{
if (!m_members[_currentScope])

View File

@ -201,8 +201,6 @@ public:
static Type const* commonType(Type const* _a, Type const* _b);
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
/// only if they have the same identifier.
/// The identifier should start with "t_".

View File

@ -160,15 +160,6 @@ inline std::string toLower(std::string _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.
/// @param _c character to be checked
/// @return true if _c is a decimal digit character, false otherwise

View File

@ -4,4 +4,4 @@ contract C {
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);
}
// ----
// 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);
}
// ----
// 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) { _; }
}
// ----
// 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);
}
// ----
// 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.
// 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.