chore(scripts): improved scripts; deps script is platform independent now

This commit is contained in:
Erica Marigold 2023-08-16 22:31:06 +05:30
parent e46a5fccc4
commit 2970271e91
No known key found for this signature in database
GPG key ID: 23CD97ABBBCC5ED2
2 changed files with 111 additions and 88 deletions

View file

@ -1 +1 @@
darklua process src/init.luau dist/codenamer.luau | sed 's/^/[darklua]: /' ([[ $WALLY_BUILD ]] && darklua process src/init.luau dist/codenamer.luau | sed 's/^/[darklua]: /') || echo "[!] Depth build not supported yet!"

View file

@ -1,112 +1,135 @@
--!strict --!strict
local fs = require("@lune/fs") local fs = require("@lune/fs")
local process = require("@lune/process") local process = require("@lune/process")
local task = require("@lune/task")
local DEPENDENCY_META = table.freeze({ local DEPENDENCY_META = table.freeze({
{ {
["author"] = "kdudedev", ["author"] = "kdudedev",
["pkgname"] = "infinite-math", ["pkgname"] = "infinite-math",
["version"] = "1.3.2" ["version"] = "1.3.2",
} },
}) })
local match = function (val, arms: {[any]: any}): any? local match = function<R>(val, arms: { [any]: any }): R
if arms[val] then if arms[val] then
if typeof(arms[val]) == 'function' then if typeof(arms[val]) == "function" then
return arms[val]() return arms[val]()
else else
return arms[val] return arms[val]
end end
elseif _G["DEBUG"] then elseif _G["DEBUG"] then
print("non exhuastive pattern for ", val) print("non exhuastive pattern for ", val)
end end
if arms["_"] then
if arms["_"] then if typeof(arms["_"]) == "function" then
if typeof(arms["_"]) == 'function' then return arms["_"]()
return arms["_"]() else
else return arms["_"]
return arms["_"] end
end end
end
end end
local log = function(kind: "ERROR" | "INFO" | "WARN", msg: string)
local prefix = match(kind, {
["ERROR"] = "[!]",
["INFO"] = "[*]",
["WARN"] = "[#]",
["_"] = function()
error("invalid log kind")
end,
})
local log = function (kind: "ERROR" | "INFO" | "WARN", msg: string) print(`{prefix} {msg}`)
local prefix = match (kind, {
["ERROR"] = "[!]",
["INFO"] = "[*]",
["WARN"] = "[#]",
["_"] = function ()
error("invalid log kind")
end
})
print(`{prefix} {msg}`)
end end
-- Converts kebab-case to upper CamelCase -- Converts kebab-case to upper CamelCase
local to_camel_case = function (str: string) local to_camel_case = function(str: string)
local parts = string.split(str, "-") local parts = string.split(str, "-")
for pos, part in parts do for pos, part in parts do
parts[pos] = string.gsub(part, "^%l", string.upper) parts[pos] = string.gsub(part, "^%l", string.upper)
end end
return table.concat(parts, "") return table.concat(parts, "")
end end
-- Converts kebab-case to upper snake_case -- Converts kebab-case to upper snake_case
local to_snake_case = function (str: string) local to_snake_case = function(str: string)
local parts = string.split(str, "-") local parts = string.split(str, "-")
return table.concat(parts, "_") return table.concat(parts, "_")
end end
for _, cmd in { "aftman", "wally" } do function main()
log("INFO", `Running \`{cmd} install\``) local shell: {[number]: string} = match(process.os, {
["windows"] = { "cmd.exe" },
["_"] = { "sh", "-c" }
})
process.spawn("sh", { "-c", `{cmd} install`, "|", `sed 's/^/[{cmd}]: /'` }, { local sh_cmd = table.remove(shell, 1)
["stdio"] = "inherit"
}) for _, cmd in { "aftman", "wally" } do
end log("INFO", `Running \`{cmd} install\``)
for _, DEPENDENCY_DATA in DEPENDENCY_META do local log_scope_pat: string = match(process.os, {
local start = os.clock() ["windows"] = "",
["_"] = `| sed 's/^/[{cmd}]: /'`
local dependency_src_dir = `Packages/_Index/{DEPENDENCY_DATA.author}_{DEPENDENCY_DATA.pkgname}@{DEPENDENCY_DATA.version}/{DEPENDENCY_DATA.pkgname}/src/{to_camel_case(DEPENDENCY_DATA.pkgname)}` })
local entrypoint_path = dependency_src_dir .. "/init.lua"
local values_dir: string? process.spawn(sh_cmd, { shell[1] or "", `{cmd} install`, log_scope_pat }, {
["stdio"] = "inherit",
if DEPENDENCY_DATA.pkgname == "infinite-math" then values_dir = dependency_src_dir .. "/Values" end })
end
log("INFO", `Constructed entrypoint path for {DEPENDENCY_DATA.pkgname} -> {string.sub(entrypoint_path, 1, #entrypoint_path - 45) .. "..."}`)
for _, DEPENDENCY_DATA in DEPENDENCY_META do
if not fs.metadata(entrypoint_path).exists then local start = os.clock()
log("ERROR", `Could not find {DEPENDENCY_DATA.pkgname} entrypoint file`)
process.exit(1) local dependency_src_dir =
end `Packages/_Index/{DEPENDENCY_DATA.author}_{DEPENDENCY_DATA.pkgname}@{DEPENDENCY_DATA.version}/{DEPENDENCY_DATA.pkgname}/src/{to_camel_case(DEPENDENCY_DATA.pkgname)}`
local entrypoint_path = dependency_src_dir .. "/init.lua"
if values_dir then local values_dir: string?
log("INFO", `Patching values for {DEPENDENCY_DATA.pkgname}`)
if DEPENDENCY_DATA.pkgname == "infinite-math" then
for _, file in fs.readDir(values_dir) do values_dir = dependency_src_dir .. "/Values"
fs.move(values_dir .. "/" .. file, dependency_src_dir .. "/" .. file) end
end
log(
fs.removeDir(values_dir) "INFO",
`Constructed entrypoint path for {DEPENDENCY_DATA.pkgname} -> {string.sub(entrypoint_path, 1, #entrypoint_path - 45) .. "..."}`
local entrypoint_contents = fs.readFile(entrypoint_path) )
entrypoint_contents = string.gsub(entrypoint_contents, "local values = script.Values", "")
entrypoint_contents = string.gsub(entrypoint_contents, "values.Suffixes", "./Suffixes.lua") if not fs.metadata(entrypoint_path).exists then
entrypoint_contents = string.gsub(entrypoint_contents, "values.FullNames", "./FullNames.lua") log("ERROR", `Could not find {DEPENDENCY_DATA.pkgname} entrypoint file`)
process.exit(1)
fs.writeFile(dependency_src_dir .. "/" .. to_snake_case(DEPENDENCY_DATA.pkgname) .. ".lua", entrypoint_contents) end
log("INFO", `Patched values for {DEPENDENCY_DATA.pkgname}`) if values_dir then
end log("INFO", `Patching values for {DEPENDENCY_DATA.pkgname}`)
log("INFO", `Done with {DEPENDENCY_DATA.pkgname} in {string.sub(tostring(os.clock() - start), 1, 5)}s`) for _, file in fs.readDir(values_dir) do
fs.move(values_dir .. "/" .. file, dependency_src_dir .. "/" .. file)
end
fs.removeDir(values_dir)
local entrypoint_contents = fs.readFile(entrypoint_path)
entrypoint_contents = string.gsub(entrypoint_contents, "local values = script.Values", "")
entrypoint_contents = string.gsub(entrypoint_contents, "values.Suffixes", "'./Suffixes'")
entrypoint_contents = string.gsub(entrypoint_contents, "values.FullNames", "'./FullNames'")
fs.writeFile(
dependency_src_dir .. "/" .. to_snake_case(DEPENDENCY_DATA.pkgname) .. ".lua",
entrypoint_contents
)
log("INFO", `Patched values for {DEPENDENCY_DATA.pkgname}`)
end
log("INFO", `Done with {DEPENDENCY_DATA.pkgname} in {string.sub(tostring(os.clock() - start), 1, 5)}s`)
end
end end
task.spawn(main)