2024-02-23 18:40:00 +00:00
|
|
|
// This file is part of the Luau programming language and is licensed under MIT License; see LICENSE.txt for details
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "Luau/NotNull.h"
|
|
|
|
#include "Luau/Substitution.h"
|
|
|
|
#include "Luau/TxnLog.h"
|
|
|
|
#include "Luau/TypeFwd.h"
|
|
|
|
#include "Luau/Unifiable.h"
|
|
|
|
|
|
|
|
namespace Luau
|
|
|
|
{
|
|
|
|
|
|
|
|
struct TypeArena;
|
|
|
|
struct TypeCheckLimits;
|
|
|
|
|
|
|
|
struct Replacer : Substitution
|
|
|
|
{
|
|
|
|
DenseHashMap<TypeId, TypeId> replacements;
|
|
|
|
DenseHashMap<TypePackId, TypePackId> replacementPacks;
|
|
|
|
|
|
|
|
Replacer(NotNull<TypeArena> arena, DenseHashMap<TypeId, TypeId> replacements, DenseHashMap<TypePackId, TypePackId> replacementPacks)
|
|
|
|
: Substitution(TxnLog::empty(), arena)
|
|
|
|
, replacements(std::move(replacements))
|
|
|
|
, replacementPacks(std::move(replacementPacks))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
bool isDirty(TypeId ty) override
|
|
|
|
{
|
|
|
|
return replacements.find(ty) != nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool isDirty(TypePackId tp) override
|
|
|
|
{
|
|
|
|
return replacementPacks.find(tp) != nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
TypeId clean(TypeId ty) override
|
|
|
|
{
|
2024-04-12 11:44:40 +01:00
|
|
|
TypeId res = replacements[ty];
|
|
|
|
LUAU_ASSERT(res);
|
|
|
|
dontTraverseInto(res);
|
|
|
|
return res;
|
2024-02-23 18:40:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TypePackId clean(TypePackId tp) override
|
|
|
|
{
|
2024-04-12 11:44:40 +01:00
|
|
|
TypePackId res = replacementPacks[tp];
|
|
|
|
LUAU_ASSERT(res);
|
|
|
|
dontTraverseInto(res);
|
|
|
|
return res;
|
2024-02-23 18:40:00 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// A substitution which replaces generic functions by monomorphic functions
|
2024-11-22 19:41:38 +00:00
|
|
|
struct Instantiation2 final : Substitution
|
2024-02-23 18:40:00 +00:00
|
|
|
{
|
|
|
|
// Mapping from generic types to free types to be used in instantiation.
|
|
|
|
DenseHashMap<TypeId, TypeId> genericSubstitutions{nullptr};
|
|
|
|
// Mapping from generic type packs to `TypePack`s of free types to be used in instantiation.
|
|
|
|
DenseHashMap<TypePackId, TypePackId> genericPackSubstitutions{nullptr};
|
|
|
|
|
|
|
|
Instantiation2(TypeArena* arena, DenseHashMap<TypeId, TypeId> genericSubstitutions, DenseHashMap<TypePackId, TypePackId> genericPackSubstitutions)
|
|
|
|
: Substitution(TxnLog::empty(), arena)
|
|
|
|
, genericSubstitutions(std::move(genericSubstitutions))
|
|
|
|
, genericPackSubstitutions(std::move(genericPackSubstitutions))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2024-03-22 17:21:27 +00:00
|
|
|
bool ignoreChildren(TypeId ty) override;
|
2024-02-23 18:40:00 +00:00
|
|
|
bool isDirty(TypeId ty) override;
|
|
|
|
bool isDirty(TypePackId tp) override;
|
|
|
|
TypeId clean(TypeId ty) override;
|
|
|
|
TypePackId clean(TypePackId tp) override;
|
|
|
|
};
|
|
|
|
|
2024-04-12 11:44:40 +01:00
|
|
|
std::optional<TypeId> instantiate2(
|
2024-08-02 00:25:12 +01:00
|
|
|
TypeArena* arena,
|
|
|
|
DenseHashMap<TypeId, TypeId> genericSubstitutions,
|
|
|
|
DenseHashMap<TypePackId, TypePackId> genericPackSubstitutions,
|
|
|
|
TypeId ty
|
|
|
|
);
|
|
|
|
std::optional<TypePackId> instantiate2(
|
|
|
|
TypeArena* arena,
|
|
|
|
DenseHashMap<TypeId, TypeId> genericSubstitutions,
|
|
|
|
DenseHashMap<TypePackId, TypePackId> genericPackSubstitutions,
|
|
|
|
TypePackId tp
|
|
|
|
);
|
2024-04-12 11:44:40 +01:00
|
|
|
|
2024-02-23 18:40:00 +00:00
|
|
|
} // namespace Luau
|