mirror of
https://github.com/CompeyDev/lune-packaging.git
synced 2025-01-09 12:19:09 +00:00
More typedef improvements for roblox builtin
This commit is contained in:
parent
f1c62245da
commit
73efb5fc99
24 changed files with 49 additions and 39 deletions
|
@ -2,7 +2,8 @@ type InstanceProperties = {
|
|||
Parent: Instance?,
|
||||
ClassName: string,
|
||||
Name: string,
|
||||
-- FIXME: This breaks intellisense, but we need some way to access instance properties...
|
||||
-- FIXME: This breaks intellisense, but we need some way to access
|
||||
-- instance properties without casting the entire instance to any...
|
||||
-- [string]: any,
|
||||
}
|
||||
|
||||
|
@ -218,4 +219,8 @@ return {
|
|||
getAuthCookie = function(raw: boolean?): string?
|
||||
return nil :: any
|
||||
end,
|
||||
-- TODO: Make typedefs for all of the datatypes as well...
|
||||
Instance = (nil :: any) :: {
|
||||
new: ((className: "DataModel") -> DataModel) & ((className: string) -> Instance),
|
||||
},
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
local fs = require("@lune/fs")
|
||||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
|
||||
local modelDirs = {}
|
||||
for _, dirName in fs.readDir("tests/roblox/rbx-test-files/places") do
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
local fs = require("@lune/fs")
|
||||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
|
||||
local placeDirs = {}
|
||||
for _, dirName in fs.readDir("tests/roblox/rbx-test-files/places") do
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
local fs = require("@lune/fs")
|
||||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local instances = {
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
local fs = require("@lune/fs")
|
||||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local game = Instance.new("DataModel")
|
||||
|
|
|
@ -1,18 +1,19 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local game = Instance.new("DataModel")
|
||||
|
||||
-- Workspace should always exist as a "Workspace" property, or be created when accessed
|
||||
|
||||
assert(game.Workspace ~= nil)
|
||||
assert(game.Workspace:IsA("Workspace"))
|
||||
assert(game.Workspace == game:FindFirstChildOfClass("Workspace"))
|
||||
local workspace = (game :: any).Workspace
|
||||
assert(workspace ~= nil)
|
||||
assert(workspace:IsA("Workspace"))
|
||||
assert(workspace == game:FindFirstChildOfClass("Workspace"))
|
||||
|
||||
-- GetService and FindService should work, GetService should create services that don't exist
|
||||
|
||||
assert(game:FindService("CSGDictionaryService") == nil)
|
||||
assert(game:GetService("CSGDictionaryService") ~= nil)
|
||||
assert(game:GetService("CSGDictionaryService"))
|
||||
assert(game:FindService("CSGDictionaryService") ~= nil)
|
||||
|
||||
-- Service names should be strict and not allow weird characters or substrings
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local game = Instance.new("DataModel")
|
||||
|
@ -6,12 +6,14 @@ local workspace = game:GetService("Workspace")
|
|||
|
||||
-- Terrain should always exist as a "Terrain" property, or be created when accessed
|
||||
|
||||
assert(workspace.Terrain ~= nil)
|
||||
assert(workspace.Terrain:IsA("Terrain"))
|
||||
assert(workspace.Terrain == workspace:FindFirstChildOfClass("Terrain"))
|
||||
local terrain = (workspace :: any).Terrain
|
||||
assert(terrain ~= nil)
|
||||
assert(terrain:IsA("Terrain"))
|
||||
assert(terrain == workspace:FindFirstChildOfClass("Terrain"))
|
||||
|
||||
-- Camera should always exist as a "CurrentCamera" property, or be created when accessed
|
||||
|
||||
assert(workspace.CurrentCamera ~= nil)
|
||||
assert(workspace.CurrentCamera:IsA("Camera"))
|
||||
assert(workspace.CurrentCamera == workspace:FindFirstChildOfClass("Camera"))
|
||||
local camera = (workspace :: any).CurrentCamera
|
||||
assert(camera ~= nil)
|
||||
assert(camera:IsA("Camera"))
|
||||
assert(camera == workspace:FindFirstChildOfClass("Camera"))
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Model")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Model")
|
||||
|
@ -7,9 +7,9 @@ local objValue1 = Instance.new("ObjectValue")
|
|||
local objValue2 = Instance.new("ObjectValue")
|
||||
|
||||
objValue1.Name = "ObjectValue1"
|
||||
objValue2.Name = "ObjectValue2"
|
||||
objValue1.Value = root
|
||||
objValue2.Value = child
|
||||
objValue2.Name = "ObjectValue2";
|
||||
(objValue1 :: any).Value = root;
|
||||
(objValue2 :: any).Value = child
|
||||
objValue1.Parent = child
|
||||
objValue2.Parent = child
|
||||
child.Parent = root
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
local fs = require("@lune/fs")
|
||||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local modelFile = fs.readFile("tests/roblox/rbx-test-files/models/three-nested-folders/binary.rbxm")
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
local fs = require("@lune/fs")
|
||||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local modelFile = fs.readFile("tests/roblox/rbx-test-files/models/three-nested-folders/binary.rbxm")
|
||||
|
|
|
@ -1,11 +1,13 @@
|
|||
local fs = require("@lune/fs")
|
||||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
|
||||
local modelFile = fs.readFile("tests/roblox/rbx-test-files/models/three-nested-folders/binary.rbxm")
|
||||
local model = roblox.deserializeModel(modelFile)[1]
|
||||
|
||||
local child = model:FindFirstChild("Parent")
|
||||
assert(child ~= nil)
|
||||
local descendant = child:FindFirstChild("Child")
|
||||
assert(descendant ~= nil)
|
||||
|
||||
assert(descendant:GetFullName() == "Grandparent.Parent.Child")
|
||||
assert(child:GetFullName() == "Grandparent.Parent")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local part = Instance.new("Part")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local root = Instance.new("Folder")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
-- Should not allow creating unknown classes
|
||||
|
@ -33,7 +33,7 @@ assert(model.Parent == nil)
|
|||
-- Parenting and indexing should work
|
||||
model.Parent = folder
|
||||
assert(model.Parent == folder)
|
||||
assert(folder.Model == model)
|
||||
assert((folder :: any).Model == model)
|
||||
|
||||
-- Parenting to nil should work
|
||||
model.Parent = nil
|
||||
|
@ -43,6 +43,6 @@ assert(model.Parent == nil)
|
|||
model.Name = "MyCoolModel"
|
||||
assert(model.Name == "MyCoolModel")
|
||||
assert(not pcall(function()
|
||||
model.Name = nil
|
||||
model.Name = nil :: any
|
||||
end))
|
||||
assert(model.Name == "MyCoolModel")
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local roblox = require("@lune/roblox") :: any
|
||||
local roblox = require("@lune/roblox")
|
||||
local Instance = roblox.Instance
|
||||
|
||||
local model = Instance.new("Model")
|
||||
|
|
Loading…
Reference in a new issue