Roblox-File-Format/Plugins/GenerateApiDump/Formatting.lua

334 lines
7.0 KiB
Lua
Raw Normal View History

--!strict
2022-06-28 20:21:05 +00:00
local Format: Format = {}
2022-12-16 20:22:34 +00:00
local LegacyFonts = require(script.Parent.LegacyFonts)
local Vector2_consts = table.freeze({
[Vector2.one] = "Vector2.one",
[Vector2.zero] = "Vector2.zero",
[Vector2.xAxis] = "Vector2.xAxis",
[Vector2.yAxis] = "Vector2.yAxis",
})
local Vector3_consts = table.freeze({
[Vector3.one] = "Vector3.one",
[Vector3.zero] = "Vector3.zero",
[Vector3.xAxis] = "Vector3.xAxis",
[Vector3.yAxis] = "Vector3.yAxis",
[Vector3.zAxis] = "Vector3.zAxis",
})
2022-06-28 20:21:05 +00:00
export type FormatFunc = (any) -> string
export type Format = { [string]: FormatFunc }
2022-12-16 20:22:34 +00:00
export type IEnum = { GetEnumItems: (IEnum) -> { EnumItem } }
local function flags(flagType: any, enum: Enum): string
2022-06-28 20:21:05 +00:00
local value = 0
2022-12-16 20:22:34 +00:00
for i, item: EnumItem in enum:GetEnumItems() do
2022-12-16 20:22:34 +00:00
if flagType[item.Name] then
2022-06-28 20:21:05 +00:00
value += (2 ^ item.Value)
end
end
2022-12-16 20:22:34 +00:00
2022-06-28 20:21:05 +00:00
return tostring(value)
end
2022-06-28 20:21:05 +00:00
function Format.Null(value: any): string
return ""
end
function Format.Bytes(value: string): string
if #value > 0 then
return string.format("Convert.FromBase64String(%q)", value)
2020-08-14 17:35:27 +00:00
end
2022-12-16 20:22:34 +00:00
return "Array.Empty<byte>()"
2020-08-14 17:35:27 +00:00
end
2022-06-28 20:21:05 +00:00
function Format.Bool(value: boolean?): string
return (if value then "true" else "")
end
function Format.String(value: string): string
return string.format("%q", value)
end
function Format.Int(value: number): string
2022-12-16 20:22:34 +00:00
if value == 2 ^ 31 - 1 then
return "int.MaxValue"
2022-12-16 20:22:34 +00:00
elseif value == -2 ^ 31 then
return "int.MinValue"
else
return string.format("%i", value)
end
end
function Format.Number(value: number): string
local int = math.floor(value)
2022-12-16 20:22:34 +00:00
if math.abs(value - int) < 0.001 then
return Format.Int(int)
end
2022-12-16 20:22:34 +00:00
local result = string.format("%.5f", value)
result = result:gsub("%.?0+$", "")
2022-12-16 20:22:34 +00:00
return result
end
function Format.Double(value: number): string
local result = Format.Number(value)
2022-12-16 20:22:34 +00:00
if result == "inf" then
return "double.MaxValue"
elseif result == "-inf" then
return "double.MinValue"
else
return result
end
end
function Format.Float(value: number): string
local result = Format.Number(value)
2022-12-16 20:22:34 +00:00
if result == "inf" then
return "float.MaxValue"
elseif result == "-inf" then
return "float.MinValue"
else
if result:find("%.") then
2022-12-16 20:22:34 +00:00
result = result .. "f"
end
2022-12-16 20:22:34 +00:00
return result
end
end
2022-06-28 20:21:05 +00:00
function Format.Axes(axes: Axes): string
return "(Axes)" .. flags(axes, Enum.Axis)
end
2022-06-28 20:21:05 +00:00
function Format.Faces(faces: Faces): string
return "(Faces)" .. flags(faces, Enum.NormalId)
end
function Format.EnumItem(item: EnumItem): string
local enum = tostring(item.EnumType)
2022-12-16 20:22:34 +00:00
return enum .. "." .. item.Name
end
function Format.BrickColor(brickColor: BrickColor): string
local fmt = "BrickColor.FromNumber(%i)"
return fmt:format(brickColor.Number)
end
function Format.Color3(color: Color3): string
if color == Color3.new() then
return "new Color3()"
end
2022-12-16 20:22:34 +00:00
local r = Format.Float(color.R)
local g = Format.Float(color.G)
local b = Format.Float(color.B)
2022-12-16 20:22:34 +00:00
local fmt = "%s(%s, %s, %s)"
local constructor = "new Color3"
if string.find(r .. g .. b, "f") then
2020-08-14 17:35:27 +00:00
r = Format.Int(color.R * 255)
g = Format.Int(color.G * 255)
b = Format.Int(color.B * 255)
2022-12-16 20:22:34 +00:00
constructor = "Color3.FromRGB"
end
2022-12-16 20:22:34 +00:00
return fmt:format(constructor, r, g, b)
end
function Format.UDim(udim: UDim): string
if udim == UDim.new() then
return "new UDim()"
end
2022-12-16 20:22:34 +00:00
local scale = Format.Float(udim.Scale)
local offset = Format.Int(udim.Offset)
2022-12-16 20:22:34 +00:00
local fmt = "new UDim(%s, %s)"
return fmt:format(scale, offset)
end
function Format.UDim2(udim2: UDim2): string
if udim2 == UDim2.new() then
return "new UDim2()"
end
2022-12-16 20:22:34 +00:00
local xScale = Format.Float(udim2.X.Scale)
local yScale = Format.Float(udim2.Y.Scale)
2022-12-16 20:22:34 +00:00
local xOffset = Format.Int(udim2.X.Offset)
local yOffset = Format.Int(udim2.Y.Offset)
2022-12-16 20:22:34 +00:00
local fmt = "new UDim2(%s, %s, %s, %s)"
return fmt:format(xScale, xOffset, yScale, yOffset)
end
function Format.Vector2(v2: Vector2): string
2022-12-16 20:22:34 +00:00
for const, str in Vector2_consts do
if v2 == const then
return str
end
end
2022-12-16 20:22:34 +00:00
local x = Format.Float(v2.X)
local y = Format.Float(v2.Y)
2022-12-16 20:22:34 +00:00
local fmt = "new Vector2(%s, %s)"
return fmt:format(x, y)
end
function Format.Vector3(v3: Vector3): string
2022-12-16 20:22:34 +00:00
for const, str in Vector3_consts do
if v3 == const then
return str
end
end
2022-12-16 20:22:34 +00:00
local x = Format.Float(v3.X)
local y = Format.Float(v3.Y)
local z = Format.Float(v3.Z)
2022-12-16 20:22:34 +00:00
local fmt = "new Vector3(%s, %s, %s)"
return fmt:format(x, y, z)
end
function Format.CFrame(cf: CFrame): string
if cf == CFrame.identity then
2022-12-16 20:22:34 +00:00
return "CFrame.identity"
end
2022-12-16 20:22:34 +00:00
if cf.Rotation == CFrame.identity then
local x = Format.Float(cf.X)
local y = Format.Float(cf.Y)
local z = Format.Float(cf.Z)
2022-12-16 20:22:34 +00:00
return string.format("new CFrame(%s, %s, %s)", x, y, z)
else
local comp = { cf:GetComponents() }
local matrix = ""
2022-12-16 20:22:34 +00:00
for i = 1, 12 do
local sep = (if i > 1 then ", " else "")
matrix ..= sep .. Format.Float(comp[i])
end
2022-12-16 20:22:34 +00:00
return string.format("new CFrame(%s)", matrix)
end
end
function Format.NumberRange(nr: NumberRange): string
2022-06-28 20:21:05 +00:00
local min = Format.Float(nr.Min)
local max = Format.Float(nr.Max)
2022-12-16 20:22:34 +00:00
local fmt = "new NumberRange(%s)"
2022-06-28 20:21:05 +00:00
local value = min
2022-12-16 20:22:34 +00:00
if min ~= max then
2022-06-28 20:21:05 +00:00
value ..= ", " .. max
end
2022-12-16 20:22:34 +00:00
return fmt:format(value)
end
function Format.Ray(ray: Ray): string
2022-06-28 20:21:05 +00:00
if ray.Origin == Vector3.zero then
if ray.Direction == Vector3.zero then
return "new Ray()"
end
end
2022-12-16 20:22:34 +00:00
local origin = Format.Vector3(ray.Origin)
local direction = Format.Vector3(ray.Direction)
2022-12-16 20:22:34 +00:00
local fmt = "new Ray(%s, %s)"
return fmt:format(origin, direction)
end
function Format.Rect(rect: Rect): string
local min: any = rect.Min
local max: any = rect.Max
2022-12-16 20:22:34 +00:00
if min == max and min == Vector2.zero then
return "new Rect()"
end
2022-12-16 20:22:34 +00:00
min = Format.Vector2(min)
max = Format.Vector2(max)
2022-12-16 20:22:34 +00:00
local fmt = "new Rect(%s, %s)"
return fmt:format(min, max)
end
function Format.ColorSequence(cs: ColorSequence): string
local csKey = cs.Keypoints[1]
local value = tostring(csKey.Value)
2022-12-16 20:22:34 +00:00
local fmt = "new ColorSequence(%s)"
return fmt:format(value)
end
function Format.NumberSequence(ns: NumberSequence): string
local nsKey = ns.Keypoints[1]
local fmt = "new NumberSequence(%s)"
2022-12-16 20:22:34 +00:00
local value = Format.Float(nsKey.Value)
return fmt:format(value)
end
function Format.Vector3int16(v3: Vector3int16): string
if v3 == Vector3int16.new() then
return "new Vector3int16()"
end
2022-12-16 20:22:34 +00:00
local x = Format.Int(v3.X)
local y = Format.Int(v3.Y)
local z = Format.Int(v3.Z)
2022-12-16 20:22:34 +00:00
local fmt = "new Vector3int16(%s, %s, %s)"
return fmt:format(x, y, z)
end
function Format.SharedString(str: string): string
local fmt = "SharedString.FromBase64(%q)"
return fmt:format(str)
end
function Format.FontFace(font: Font): string
2022-12-16 20:22:34 +00:00
local legacyFont = LegacyFonts[tostring(font)]
if legacyFont then
local fmt = "FontFace.FromEnum(Enums.Font.%s)"
return fmt:format(legacyFont.Name)
end
2022-06-28 20:21:05 +00:00
local family = string.format("%q", font.Family)
local args = { family }
2022-12-16 20:22:34 +00:00
2022-06-28 20:21:05 +00:00
local style = font.Style
local weight = font.Weight
2022-12-16 20:22:34 +00:00
2022-06-28 20:21:05 +00:00
if style ~= Enum.FontStyle.Normal then
table.insert(args, "FontStyle." .. style.Name)
end
2022-05-06 19:37:23 +00:00
2022-06-28 20:21:05 +00:00
if #args > 1 or weight ~= Enum.FontWeight.Regular then
table.insert(args, "FontWeight." .. weight.Name)
end
2022-12-16 20:22:34 +00:00
2022-06-28 20:21:05 +00:00
local fmt = "new FontFace(%s)"
local argStr = table.concat(args, ", ")
2022-12-16 20:22:34 +00:00
2022-06-28 20:21:05 +00:00
return fmt:format(argStr)
end
2022-12-16 20:22:34 +00:00
return Format