mirror of
https://github.com/pesde-pkg/scripts.git
synced 2025-01-07 12:09:09 +00:00
refactor: restructure repo and setup as library
Restructures the project to be a library with generator exports, and includes lune scripts as examples on how to use exported generators by the library. Also specifies `includes` and pins a pesde version in the package manifest.
This commit is contained in:
parent
6f4a186af4
commit
84720a2885
8 changed files with 196 additions and 63 deletions
19
.lune/roblox_sync_config_generator.luau
Normal file
19
.lune/roblox_sync_config_generator.luau
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
local function enter(fn: (args: { string }) -> number?): never
|
||||||
|
local process = require("@lune/process")
|
||||||
|
local stdio = require("@lune/stdio")
|
||||||
|
|
||||||
|
local startTime = os.clock()
|
||||||
|
local exitCode = fn(table.clone(process.args))
|
||||||
|
|
||||||
|
stdio.write(
|
||||||
|
`done in {stdio.style("dim")}{string.format("%.2fs", os.clock() - startTime)}{stdio.style("reset")}!\n`
|
||||||
|
)
|
||||||
|
|
||||||
|
return process.exit(exitCode)
|
||||||
|
end
|
||||||
|
|
||||||
|
return enter(function(args: { string }): number?
|
||||||
|
local ok, _ = require("../src").generators.rojo.syncConfig(table.remove(args, 1), args, true)
|
||||||
|
|
||||||
|
return tonumber(ok)
|
||||||
|
end)
|
19
.lune/sourcemap_generator.luau
Normal file
19
.lune/sourcemap_generator.luau
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
local function enter(fn: (args: { string }) -> number?): never
|
||||||
|
local process = require("@lune/process")
|
||||||
|
local stdio = require("@lune/stdio")
|
||||||
|
|
||||||
|
local startTime = os.clock()
|
||||||
|
local exitCode = fn(table.clone(process.args))
|
||||||
|
|
||||||
|
stdio.ewrite(
|
||||||
|
`\ndone in {stdio.style("dim")}{string.format("%.2fs", os.clock() - startTime)}{stdio.style("reset")}!\n`
|
||||||
|
)
|
||||||
|
|
||||||
|
return process.exit(exitCode)
|
||||||
|
end
|
||||||
|
|
||||||
|
return enter(function(args: { string }): number?
|
||||||
|
return tonumber(require("../src").generators.rojo.sourcemap(
|
||||||
|
args[1]
|
||||||
|
))
|
||||||
|
end)
|
|
@ -1,44 +0,0 @@
|
||||||
local fs = require("@lune/fs")
|
|
||||||
local process = require("@lune/process")
|
|
||||||
local serde = require("@lune/serde")
|
|
||||||
|
|
||||||
local package_directory = process.args[1]
|
|
||||||
|
|
||||||
if fs.isFile(package_directory .. "/default.project.json") then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
local output = {
|
|
||||||
tree = {},
|
|
||||||
}
|
|
||||||
|
|
||||||
for i, file in process.args do
|
|
||||||
if i == 1 then
|
|
||||||
continue
|
|
||||||
end
|
|
||||||
|
|
||||||
local name = string.gsub(file, ".luau?$", "")
|
|
||||||
|
|
||||||
if name == "init" then
|
|
||||||
output.tree["$path"] = file
|
|
||||||
continue
|
|
||||||
end
|
|
||||||
|
|
||||||
output.tree[name] = {
|
|
||||||
["$path"] = file,
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
if not output.tree["$path"] then
|
|
||||||
output.tree["$className"] = "Folder"
|
|
||||||
end
|
|
||||||
|
|
||||||
if not output.tree["roblox_packages"] then
|
|
||||||
output.tree["roblox_packages"] = {
|
|
||||||
["$path"] = {
|
|
||||||
optional = "roblox_packages",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
fs.writeFile(package_directory .. "/default.project.json", serde.encode("json", output, true))
|
|
|
@ -1,19 +0,0 @@
|
||||||
local fs = require("@lune/fs")
|
|
||||||
local process = require("@lune/process")
|
|
||||||
local serde = require("@lune/serde")
|
|
||||||
local stdio = require("@lune/stdio")
|
|
||||||
|
|
||||||
local package_directory = process.args[1]
|
|
||||||
|
|
||||||
if fs.isFile(package_directory .. "/default.project.json") then
|
|
||||||
process.spawn("rojo", { "sourcemap", package_directory }, { cwd = process.cwd, stdio = "forward" })
|
|
||||||
elseif fs.isFile(package_directory .. "/init.luau") then
|
|
||||||
local sourcemap = { filePaths = { "init.luau" } }
|
|
||||||
stdio.write(serde.encode("json", sourcemap, false))
|
|
||||||
elseif fs.isFile(package_directory .. "/init.lua") then
|
|
||||||
local sourcemap = { filePaths = { "init.lua" } }
|
|
||||||
stdio.write(serde.encode("json", sourcemap, false))
|
|
||||||
else
|
|
||||||
-- use stderr to avoid this being parsed as the output of the sourcemap command
|
|
||||||
stdio.ewrite("no default.project.json found in " .. package_directory)
|
|
||||||
end
|
|
|
@ -1,12 +1,15 @@
|
||||||
name = "pesde/scripts"
|
name = "pesde/scripts"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
|
pesde_version = "0.5.0-rc.14"
|
||||||
description = "Scripts and other utilities for use with pesde"
|
description = "Scripts and other utilities for use with pesde"
|
||||||
authors = ["dai <contact@daimond113.com> (https://www.daimond113.com/)", "Erica Marigold <hi@devcomp.xyz>"]
|
authors = ["dai <contact@daimond113.com> (https://www.daimond113.com/)", "Erica Marigold <hi@devcomp.xyz>"]
|
||||||
repository = "https://github.com/pesde-pkg/scripts"
|
repository = "https://github.com/pesde-pkg/scripts"
|
||||||
license = "MIT"
|
license = "MIT"
|
||||||
|
includes = ["src/**/*.luau"]
|
||||||
|
|
||||||
[target]
|
[target]
|
||||||
environment = "lune"
|
environment = "lune"
|
||||||
|
lib = "src/init.luau"
|
||||||
|
|
||||||
[indices]
|
[indices]
|
||||||
default = "https://github.com/daimond113/pesde-index"
|
default = "https://github.com/daimond113/pesde-index"
|
||||||
|
|
43
src/generators/rojo/sourcemap.luau
Normal file
43
src/generators/rojo/sourcemap.luau
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
local fs = require("@lune/fs")
|
||||||
|
local process = require("@lune/process")
|
||||||
|
local serde = require("@lune/serde")
|
||||||
|
local stdio = require("@lune/stdio")
|
||||||
|
|
||||||
|
local PLATFORM_SEP = if process.os == "windows" then "\\" else "/"
|
||||||
|
|
||||||
|
--- Writes a Rojo sourcemap for the project in the provided directory or the current
|
||||||
|
--- working directory to standard output.
|
||||||
|
|
||||||
|
--- ## Errors
|
||||||
|
--- * The current process lacks permissions to a file
|
||||||
|
--- * Any I/O error occurs
|
||||||
|
return function(packageDirectory: string?): boolean
|
||||||
|
packageDirectory = packageDirectory or process.cwd
|
||||||
|
|
||||||
|
-- A mapping of things to do depending on the file present
|
||||||
|
local PATH_ACTION_MAP: { [string]: (dir: string) -> number? } = {
|
||||||
|
["default.project.json"] = function(dir)
|
||||||
|
return process.spawn("rojo", { "sourcemap", dir }, {
|
||||||
|
cwd = process.cwd,
|
||||||
|
env = process.env,
|
||||||
|
stdio = "forward",
|
||||||
|
}).code
|
||||||
|
end,
|
||||||
|
|
||||||
|
["init.lua"] = stdio.write(serde.encode("json", { filePaths = { "init.lua" } }, false)),
|
||||||
|
["init.luau"] = stdio.write(serde.encode("json", { filePaths = { "init.luau" } }, false)),
|
||||||
|
}
|
||||||
|
|
||||||
|
-- We go through the action mappings in order of priority and check for the
|
||||||
|
-- file predicates, if present, we execute the action and report our status
|
||||||
|
for path, action in PATH_ACTION_MAP do
|
||||||
|
if fs.isFile(`{packageDirectory}{PLATFORM_SEP}{path}`) then
|
||||||
|
local status = action()
|
||||||
|
return if status ~= nil then status == 0 else true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- If we reached so far, that must mean none of the file predicates matched,
|
||||||
|
-- so we return a `false` signifying an error
|
||||||
|
return false
|
||||||
|
end
|
104
src/generators/rojo/sync_config.luau
Normal file
104
src/generators/rojo/sync_config.luau
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
local fs = require("@lune/fs")
|
||||||
|
local process = require("@lune/process")
|
||||||
|
local serde = require("@lune/serde")
|
||||||
|
|
||||||
|
export type TreeProperties = {
|
||||||
|
Name: never?,
|
||||||
|
Parent: never?,
|
||||||
|
}
|
||||||
|
|
||||||
|
export type TreeBase = {
|
||||||
|
["$className"]: string?,
|
||||||
|
["$ignoreUnknownInstances"]: boolean?,
|
||||||
|
["$path"]: string | { optional: string }?,
|
||||||
|
["$properties"]: TreeProperties?,
|
||||||
|
}
|
||||||
|
|
||||||
|
export type TreeNormal = TreeBase & {
|
||||||
|
[string]: TreeNormal,
|
||||||
|
} & ({ ["$className"]: string } | { ["$path"]: string | { optional: string } })
|
||||||
|
|
||||||
|
export type TreeService = TreeBase & {
|
||||||
|
[string]: TreeNormal,
|
||||||
|
}
|
||||||
|
|
||||||
|
export type DataModelTree = TreeBase & {
|
||||||
|
StarterPlayer: (TreeBase & {
|
||||||
|
StarterPlayerScripts: TreeService?,
|
||||||
|
StarterCharacterScripts: TreeService?,
|
||||||
|
[string]: TreeNormal,
|
||||||
|
})?,
|
||||||
|
[string]: TreeService,
|
||||||
|
}
|
||||||
|
|
||||||
|
export type Tree = (DataModelTree & {
|
||||||
|
["$className"]: "DataModel",
|
||||||
|
}) | TreeNormal
|
||||||
|
|
||||||
|
export type SyncConfig = {
|
||||||
|
name: string,
|
||||||
|
servePort: number?,
|
||||||
|
servePlaceIds: { number }?,
|
||||||
|
placeId: number?,
|
||||||
|
gameId: number?,
|
||||||
|
serveAddress: string?,
|
||||||
|
globIgnorePaths: { string }?,
|
||||||
|
tree: Tree,
|
||||||
|
}
|
||||||
|
|
||||||
|
local PLATFORM_SEP = if process.os == "windows" then "\\" else "/"
|
||||||
|
|
||||||
|
--- Generates a Rojo sync configuration file (`default.project.json`) from a list of
|
||||||
|
--- input files to be included.
|
||||||
|
|
||||||
|
--- ## Errors
|
||||||
|
--- * The current process lacks permissions to a file
|
||||||
|
--- * Any I/O error occurs
|
||||||
|
return function(packageDirectory: string?, files: { string }, writeToFile: boolean?): (boolean, string?)
|
||||||
|
packageDirectory = packageDirectory or process.cwd
|
||||||
|
local syncConfigPath = `{packageDirectory}{PLATFORM_SEP}default.project.json`
|
||||||
|
if fs.isFile(syncConfigPath) then
|
||||||
|
return true, nil
|
||||||
|
end
|
||||||
|
|
||||||
|
local syncConfigTree = {} :: Tree
|
||||||
|
|
||||||
|
for _, file in files do
|
||||||
|
-- Remove the `.lua` or `.luau` file extension from the file name
|
||||||
|
local name = string.gsub(file, ".luau?$", "")
|
||||||
|
|
||||||
|
if name == "init" then
|
||||||
|
syncConfigTree["$path"] = name
|
||||||
|
continue
|
||||||
|
end
|
||||||
|
|
||||||
|
syncConfigTree[name] = {
|
||||||
|
["$path"] = file,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
-- If there isn't a top level path, we mark the entire thing as a Folder
|
||||||
|
if not syncConfigTree["$path"] then
|
||||||
|
syncConfigTree["$className"] = "Folder"
|
||||||
|
end
|
||||||
|
|
||||||
|
-- If the config tree does not include pesde's downloaded roblox dependencies
|
||||||
|
-- directory, we add it as an optional one for the future, once dependencies
|
||||||
|
-- are installed
|
||||||
|
if not syncConfigTree["roblox_packages"] then
|
||||||
|
syncConfigTree["roblox_packages"] = {
|
||||||
|
["$path"] = {
|
||||||
|
optional = "roblox_packages",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Finally, we serialize the config to a JSON string and optionally write it
|
||||||
|
-- to the sync config path
|
||||||
|
local serializedConfig = serde.encode("json", { tree = syncConfigTree }, true)
|
||||||
|
if writeToFile then
|
||||||
|
fs.writeFile(syncConfigPath, serializedConfig)
|
||||||
|
end
|
||||||
|
|
||||||
|
return true, serializedConfig
|
||||||
|
end
|
8
src/init.luau
Normal file
8
src/init.luau
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
return {
|
||||||
|
generators = {
|
||||||
|
rojo = {
|
||||||
|
sourcemap = require("./generators/rojo/sourcemap"),
|
||||||
|
syncConfig = require("./generators/rojo/sync_config"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
Loading…
Reference in a new issue