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
|
|
|
|
#include "ConstraintGraphBuilderFixture.h"
|
|
|
|
|
2023-01-06 16:07:19 +00:00
|
|
|
#include "Luau/TypeReduction.h"
|
|
|
|
|
2022-09-15 23:13:58 +01:00
|
|
|
namespace Luau
|
|
|
|
{
|
|
|
|
|
|
|
|
ConstraintGraphBuilderFixture::ConstraintGraphBuilderFixture()
|
|
|
|
: Fixture()
|
|
|
|
, mainModule(new Module)
|
|
|
|
, forceTheFlag{"DebugLuauDeferredConstraintResolution", true}
|
|
|
|
{
|
2023-01-06 16:07:19 +00:00
|
|
|
mainModule->reduction = std::make_unique<TypeReduction>(NotNull{&mainModule->internalTypes}, builtinTypes, NotNull{&ice});
|
|
|
|
|
2023-01-03 17:33:19 +00:00
|
|
|
BlockedType::nextIndex = 0;
|
2022-09-15 23:13:58 +01:00
|
|
|
BlockedTypePack::nextIndex = 0;
|
|
|
|
}
|
|
|
|
|
2022-10-21 18:33:43 +01:00
|
|
|
void ConstraintGraphBuilderFixture::generateConstraints(const std::string& code)
|
|
|
|
{
|
|
|
|
AstStatBlock* root = parse(code);
|
|
|
|
dfg = std::make_unique<DataFlowGraph>(DataFlowGraphBuilder::build(root, NotNull{&ice}));
|
2023-01-03 17:33:19 +00:00
|
|
|
cgb = std::make_unique<ConstraintGraphBuilder>("MainModule", mainModule, &arena, NotNull(&moduleResolver), builtinTypes, NotNull(&ice),
|
2022-10-21 18:33:43 +01:00
|
|
|
frontend.getGlobalScope(), &logger, NotNull{dfg.get()});
|
|
|
|
cgb->visit(root);
|
|
|
|
rootScope = cgb->rootScope;
|
2022-11-10 22:04:44 +00:00
|
|
|
constraints = Luau::borrowConstraints(cgb->constraints);
|
2022-10-21 18:33:43 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void ConstraintGraphBuilderFixture::solve(const std::string& code)
|
|
|
|
{
|
|
|
|
generateConstraints(code);
|
2023-02-24 18:24:22 +00:00
|
|
|
ConstraintSolver cs{NotNull{&normalizer}, NotNull{rootScope}, constraints, "MainModule", NotNull{mainModule->reduction.get()},
|
|
|
|
NotNull(&moduleResolver), {}, &logger};
|
2022-10-21 18:33:43 +01:00
|
|
|
cs.run();
|
|
|
|
}
|
|
|
|
|
2022-10-13 23:59:53 +01:00
|
|
|
} // namespace Luau
|