2021-10-29 21:25:12 +01: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/Common.h"
|
|
|
|
|
|
|
|
#include <stdexcept>
|
2022-04-14 22:57:15 +01:00
|
|
|
#include <exception>
|
|
|
|
|
|
|
|
LUAU_FASTFLAG(LuauRecursionLimitException);
|
2021-10-29 21:25:12 +01:00
|
|
|
|
|
|
|
namespace Luau
|
|
|
|
{
|
|
|
|
|
2022-04-14 22:57:15 +01:00
|
|
|
struct RecursionLimitException : public std::exception
|
|
|
|
{
|
|
|
|
const char* what() const noexcept
|
|
|
|
{
|
|
|
|
return "Internal recursion counter limit exceeded";
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-10-29 21:25:12 +01:00
|
|
|
struct RecursionCounter
|
|
|
|
{
|
|
|
|
RecursionCounter(int* count)
|
|
|
|
: count(count)
|
|
|
|
{
|
|
|
|
++(*count);
|
|
|
|
}
|
|
|
|
|
|
|
|
~RecursionCounter()
|
|
|
|
{
|
|
|
|
LUAU_ASSERT(*count > 0);
|
|
|
|
--(*count);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
int* count;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct RecursionLimiter : RecursionCounter
|
|
|
|
{
|
2022-04-14 22:57:15 +01:00
|
|
|
// TODO: remove ctx after LuauRecursionLimitException is removed
|
|
|
|
RecursionLimiter(int* count, int limit, const char* ctx)
|
2021-10-29 21:25:12 +01:00
|
|
|
: RecursionCounter(count)
|
|
|
|
{
|
2022-04-14 22:57:15 +01:00
|
|
|
LUAU_ASSERT(ctx);
|
2021-10-29 21:25:12 +01:00
|
|
|
if (limit > 0 && *count > limit)
|
2022-04-14 22:57:15 +01:00
|
|
|
{
|
|
|
|
if (FFlag::LuauRecursionLimitException)
|
|
|
|
throw RecursionLimitException();
|
|
|
|
else
|
|
|
|
{
|
|
|
|
std::string m = "Internal recursion counter limit exceeded: ";
|
|
|
|
m += ctx;
|
|
|
|
throw std::runtime_error(m);
|
|
|
|
}
|
|
|
|
}
|
2021-10-29 21:25:12 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Luau
|