Skip to content

Commit

Permalink
fix waitforchild magic function
Browse files Browse the repository at this point in the history
  • Loading branch information
checkraisefold committed Oct 26, 2024
1 parent 5545b66 commit 22ce441
Showing 1 changed file with 21 additions and 4 deletions.
25 changes: 21 additions & 4 deletions src/platform/roblox/RobloxSourcemap.cpp
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
#include "Luau/TypeFwd.h"
#include "Platform/RobloxPlatform.hpp"

#include "LSP/Workspace.hpp"
Expand Down Expand Up @@ -62,7 +63,13 @@ static void injectChildrenLookupFunctions(
auto findFirstChildFunction = Luau::makeFunction(arena, ty,
{globals.builtinTypes->stringType, Luau::makeOption(globals.builtinTypes, arena, globals.builtinTypes->booleanType)},
{"name", "recursive"}, {optionalInstanceType});
auto waitForChildFunction = Luau::makeFunction(arena, ty, {globals.builtinTypes->stringType}, {"name"}, {*instanceType});

Luau::TypeId waitForChildFunction;
if (FFlag::LuauSolverV2)
waitForChildFunction = Luau::makeFunction(
arena, ty, {globals.builtinTypes->stringType, globals.builtinTypes->optionalNumberType}, {"name"}, {*instanceType});
else
waitForChildFunction = Luau::makeFunction(arena, ty, {globals.builtinTypes->stringType}, {"name"}, {*instanceType});
auto waitForChildWithTimeoutFunction = Luau::makeFunction(
arena, ty, {globals.builtinTypes->stringType, globals.builtinTypes->numberType}, {"name", "timeout"}, {optionalInstanceType});

Expand All @@ -85,7 +92,7 @@ static void injectChildrenLookupFunctions(
return std::nullopt;
});
Luau::attachDcrMagicFunction(lookupFuncTy,
[node, &arena, &globals](Luau::MagicFunctionCallContext context) -> bool
[node, &arena, &globals, optionalInstanceType, lookupFuncTy, waitForChildFunction](Luau::MagicFunctionCallContext context) -> bool
{
if (context.callSite->args.size < 1)
return false;
Expand All @@ -100,15 +107,25 @@ static void injectChildrenLookupFunctions(
->ty.emplace<Luau::BoundTypePack>(context.solver->arena->addTypePack({getSourcemapType(globals, arena, *child)}));
return true;
}

if (context.callSite->args.size >= 2 && lookupFuncTy == waitForChildFunction)
{
asMutable(context.result)->ty.emplace<Luau::BoundTypePack>(context.solver->arena->addTypePack({optionalInstanceType}));
return true;
}

return false;
});
Luau::attachTag(lookupFuncTy, kSourcemapGeneratedTag);
Luau::attachTag(lookupFuncTy, "Children");
}

ctv->props["FindFirstChild"] = Luau::makeProperty(findFirstChildFunction, "@roblox/globaltype/Instance.FindFirstChild");
ctv->props["WaitForChild"] = Luau::makeProperty(
Luau::makeIntersection(arena, {waitForChildFunction, waitForChildWithTimeoutFunction}), "@roblox/globaltype/Instance.WaitForChild");
if (FFlag::LuauSolverV2)
ctv->props["WaitForChild"] = Luau::makeProperty(waitForChildFunction, "@roblox/globaltype/Instance.WaitForChild");
else
ctv->props["WaitForChild"] = Luau::makeProperty(
Luau::makeIntersection(arena, {waitForChildFunction, waitForChildWithTimeoutFunction}), "@roblox/globaltype/Instance.WaitForChild");
}
}

Expand Down

0 comments on commit 22ce441

Please sign in to comment.