luau/tests/ConstraintGeneratorFixture.cpp

52 lines
1.5 KiB
C++
Raw Normal View History

2022-09-15 23:13:58 +01:00
// This file is part of the Luau programming language and is licensed under MIT License; see LICENSE.txt for details
2023-11-03 19:47:28 +00:00
#include "ConstraintGeneratorFixture.h"
#include "ScopedFlags.h"
2024-08-30 20:28:44 +01:00
LUAU_FASTFLAG(LuauSolverV2);
2022-09-15 23:13:58 +01:00
namespace Luau
{
2023-11-03 19:47:28 +00:00
ConstraintGeneratorFixture::ConstraintGeneratorFixture()
2022-09-15 23:13:58 +01:00
: Fixture()
, mainModule(new Module)
2024-08-30 20:28:44 +01:00
, forceTheFlag{FFlag::LuauSolverV2, true}
2022-09-15 23:13:58 +01:00
{
2023-04-21 22:41:03 +01:00
mainModule->name = "MainModule";
mainModule->humanReadableName = "MainModule";
2023-01-06 16:07:19 +00:00
2022-09-15 23:13:58 +01:00
BlockedTypePack::nextIndex = 0;
}
2023-11-03 19:47:28 +00:00
void ConstraintGeneratorFixture::generateConstraints(const std::string& code)
2022-10-21 18:33:43 +01:00
{
AstStatBlock* root = parse(code);
dfg = std::make_unique<DataFlowGraph>(DataFlowGraphBuilder::build(root, NotNull{&ice}));
2024-08-02 00:25:12 +01:00
cg = std::make_unique<ConstraintGenerator>(
mainModule,
NotNull{&normalizer},
NotNull(&moduleResolver),
builtinTypes,
NotNull(&ice),
frontend.globals.globalScope,
/*prepareModuleScope*/ nullptr,
&logger,
NotNull{dfg.get()},
std::vector<RequireCycle>()
);
2023-11-03 19:47:28 +00:00
cg->visitModuleRoot(root);
rootScope = cg->rootScope;
constraints = Luau::borrowConstraints(cg->constraints);
2022-10-21 18:33:43 +01:00
}
2023-11-03 19:47:28 +00:00
void ConstraintGeneratorFixture::solve(const std::string& code)
2022-10-21 18:33:43 +01:00
{
generateConstraints(code);
2024-09-27 18:11:46 +01:00
ConstraintSolver cs{
NotNull{&normalizer}, NotNull{&typeFunctionRuntime}, NotNull{rootScope}, constraints, "MainModule", NotNull(&moduleResolver), {}, &logger, {}
};
2022-10-21 18:33:43 +01:00
cs.run();
}
2022-10-13 23:59:53 +01:00
} // namespace Luau