mirror of
https://github.com/luau-lang/luau.git
synced 2025-04-03 18:30:54 +01:00
Store resolved types in astResolvedTypes
(#574)
This commit is contained in:
parent
6303ae30c4
commit
4d98a16ea8
5 changed files with 48 additions and 7 deletions
|
@ -345,6 +345,7 @@ private:
|
|||
TypePackId freshTypePack(TypeLevel level);
|
||||
|
||||
TypeId resolveType(const ScopePtr& scope, const AstType& annotation);
|
||||
TypeId resolveTypeWorker(const ScopePtr& scope, const AstType& annotation);
|
||||
TypePackId resolveTypePack(const ScopePtr& scope, const AstTypeList& types);
|
||||
TypePackId resolveTypePack(const ScopePtr& scope, const AstTypePack& annotation);
|
||||
TypeId instantiateTypeFun(const ScopePtr& scope, const TypeFun& tf, const std::vector<TypeId>& typeParams,
|
||||
|
|
|
@ -496,6 +496,8 @@ CheckResult Frontend::check(const ModuleName& name, std::optional<FrontendOption
|
|||
module->astTypes.clear();
|
||||
module->astExpectedTypes.clear();
|
||||
module->astOriginalCallTypes.clear();
|
||||
module->astResolvedTypes.clear();
|
||||
module->astResolvedTypePacks.clear();
|
||||
module->scopes.resize(1);
|
||||
}
|
||||
|
||||
|
|
|
@ -4884,6 +4884,13 @@ TypePackId TypeChecker::freshTypePack(TypeLevel level)
|
|||
}
|
||||
|
||||
TypeId TypeChecker::resolveType(const ScopePtr& scope, const AstType& annotation)
|
||||
{
|
||||
TypeId ty = resolveTypeWorker(scope, annotation);
|
||||
currentModule->astResolvedTypes[&annotation] = ty;
|
||||
return ty;
|
||||
}
|
||||
|
||||
TypeId TypeChecker::resolveTypeWorker(const ScopePtr& scope, const AstType& annotation)
|
||||
{
|
||||
if (const auto& lit = annotation.as<AstTypeReference>())
|
||||
{
|
||||
|
@ -5200,9 +5207,10 @@ TypePackId TypeChecker::resolveTypePack(const ScopePtr& scope, const AstTypeList
|
|||
|
||||
TypePackId TypeChecker::resolveTypePack(const ScopePtr& scope, const AstTypePack& annotation)
|
||||
{
|
||||
TypePackId result;
|
||||
if (const AstTypePackVariadic* variadic = annotation.as<AstTypePackVariadic>())
|
||||
{
|
||||
return addTypePack(TypePackVar{VariadicTypePack{resolveType(scope, *variadic->variadicType)}});
|
||||
result = addTypePack(TypePackVar{VariadicTypePack{resolveType(scope, *variadic->variadicType)}});
|
||||
}
|
||||
else if (const AstTypePackGeneric* generic = annotation.as<AstTypePackGeneric>())
|
||||
{
|
||||
|
@ -5216,10 +5224,12 @@ TypePackId TypeChecker::resolveTypePack(const ScopePtr& scope, const AstTypePack
|
|||
else
|
||||
reportError(TypeError{generic->location, UnknownSymbol{genericName, UnknownSymbol::Type}});
|
||||
|
||||
return errorRecoveryTypePack(scope);
|
||||
result = errorRecoveryTypePack(scope);
|
||||
}
|
||||
else
|
||||
{
|
||||
result = *genericTy;
|
||||
}
|
||||
|
||||
return *genericTy;
|
||||
}
|
||||
else if (const AstTypePackExplicit* explicitTp = annotation.as<AstTypePackExplicit>())
|
||||
{
|
||||
|
@ -5229,14 +5239,17 @@ TypePackId TypeChecker::resolveTypePack(const ScopePtr& scope, const AstTypePack
|
|||
types.push_back(resolveType(scope, *type));
|
||||
|
||||
if (auto tailType = explicitTp->typeList.tailType)
|
||||
return addTypePack(types, resolveTypePack(scope, *tailType));
|
||||
|
||||
return addTypePack(types);
|
||||
result = addTypePack(types, resolveTypePack(scope, *tailType));
|
||||
else
|
||||
result = addTypePack(types);
|
||||
}
|
||||
else
|
||||
{
|
||||
ice("Unknown AstTypePack kind");
|
||||
}
|
||||
|
||||
currentModule->astResolvedTypePacks[&annotation] = result;
|
||||
return result;
|
||||
}
|
||||
|
||||
bool ApplyTypeFunction::isDirty(TypeId ty)
|
||||
|
|
|
@ -791,6 +791,8 @@ TEST_CASE_FIXTURE(FrontendFixture, "discard_type_graphs")
|
|||
CHECK_EQ(0, module->internalTypes.typeVars.size());
|
||||
CHECK_EQ(0, module->internalTypes.typePacks.size());
|
||||
CHECK_EQ(0, module->astTypes.size());
|
||||
CHECK_EQ(0, module->astResolvedTypes.size());
|
||||
CHECK_EQ(0, module->astResolvedTypePacks.size());
|
||||
}
|
||||
|
||||
TEST_CASE_FIXTURE(FrontendFixture, "it_should_be_safe_to_stringify_errors_when_full_type_graph_is_discarded")
|
||||
|
|
|
@ -1003,4 +1003,27 @@ TEST_CASE_FIXTURE(Fixture, "do_not_bind_a_free_table_to_a_union_containing_that_
|
|||
)");
|
||||
}
|
||||
|
||||
TEST_CASE_FIXTURE(Fixture, "types stored in astResolvedTypes")
|
||||
{
|
||||
CheckResult result = check(R"(
|
||||
type alias = typeof("hello")
|
||||
local function foo(param: alias)
|
||||
end
|
||||
)");
|
||||
|
||||
auto node = findNodeAtPosition(*getMainSourceModule(), {2, 16});
|
||||
auto ty = lookupType("alias");
|
||||
REQUIRE(node);
|
||||
REQUIRE(node->is<AstExprFunction>());
|
||||
REQUIRE(ty);
|
||||
|
||||
auto func = node->as<AstExprFunction>();
|
||||
REQUIRE(func->args.size == 1);
|
||||
|
||||
auto arg = *func->args.begin();
|
||||
auto annotation = arg->annotation;
|
||||
|
||||
CHECK_EQ(*getMainModule()->astResolvedTypes.find(annotation), *ty);
|
||||
}
|
||||
|
||||
TEST_SUITE_END();
|
||||
|
|
Loading…
Add table
Reference in a new issue