From b53e00da9e208f21c76ed18ec6ec6f71f8ea8f96 Mon Sep 17 00:00:00 2001 From: Chi Huu Huynh <73843190+Chi-EEE@users.noreply.github.com> Date: Sun, 5 May 2024 23:18:04 +0100 Subject: [PATCH] luau: update to 0.624 (#3901) * luau: update to 0.623 * luau: add ".lib" * Add another test * luau: remove ".lib" suffix from any libs * luau: test use cxx11 * luau: no links for interface * luau: update * luau: remove limits * luau: disable wasm * luau: use 1 loop * luau: remove more code * luau: remove more code * luau: move if statement * luau: exclude bsd --- packages/l/luau/xmake.lua | 62 +++++++++++++++++++++++++++------------ 1 file changed, 43 insertions(+), 19 deletions(-) diff --git a/packages/l/luau/xmake.lua b/packages/l/luau/xmake.lua index e815afd32..1c000e193 100644 --- a/packages/l/luau/xmake.lua +++ b/packages/l/luau/xmake.lua @@ -4,15 +4,19 @@ package("luau") set_description("A fast, small, safe, gradually typed embeddable scripting language derived from Lua.") set_license("MIT") - add_urls("https://github.com/Roblox/luau.git") - add_versions("0.538", "d3b566c258bee3bdccb655c034a11bfc48a586e3") + add_urls("https://github.com/Roblox/luau/archive/$(version).tar.gz", + "https://github.com/Roblox/luau.git") + + add_versions("0.624", "6d5ce40a7dc0e17da51cc143d2ee1ab32727583c315938f5a69d13ef93ae574d") + add_versions("0.623", "5a72f9e5b996c5ec44ee2c7bd9448d2b2e5061bdf7d057de7490f92fb3003f40") + add_versions("0.538", "8a1240e02a7daacf1e5cff249040a3298c013157fc496c66adce6dcb21cc30be") add_configs("extern_c", { description = "Use extern C for all APIs.", default = false, type = "boolean" }) add_configs("build_web", { description = "Build web module.", default = false, type = "boolean" }) add_deps("cmake") - on_install("linux", "windows", "mingw|x86_64", "macosx", function(package) + on_install("!bsd and !wasm", function(package) local configs = {} table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:debug() and "Debug" or "RelWithDebInfo")) table.insert(configs, "-DBUILD_SHARED_LIBS=" .. (package:config("shared") and "ON" or "OFF")) @@ -20,21 +24,37 @@ package("luau") table.insert(configs, "-DLUAU_BUILD_WEB=" .. (package:config("build_web") and "ON" or "OFF")) table.insert(configs, "-DLUAU_EXTERN_C=" .. (package:config("extern_c") and "ON" or "OFF")) import("package.tools.cmake").install(package, configs, { buildir = "build" }) - os.trycp("VM/include/*.h", package:installdir("include")) - os.trycp("Ast/include/*", package:installdir("include")) - os.trycp("Common/include/*", package:installdir("include")) - os.trycp("Compiler/include/*", package:installdir("include")) - -- need to link with Ast last - local libs = { "Luau.VM", "Luau.Compiler", "Luau.Ast" } - for _, link in ipairs(libs) do + + io.replace("CMakeLists.txt", ".lib", "", {plain = true}) + io.replace("Sources.cmake", ".lib", "", {plain = true}) + + local cmake_file = io.readfile("CMakeLists.txt") + + local links = {} + for library_name, library_type in string.gmatch(cmake_file, "add_library%(([%a|%.]+) ([STATIC|INTERFACE]+)") do + if string.startswith(library_name, "Luau.") then + if library_type == "STATIC" then + table.insert(links, library_name) + end + local include_dir = library_name:gsub("Luau%.", "") + include_dir = include_dir:gsub("%..*", "") + os.trycp(include_dir .. "/include/*", package:installdir("include")) + end + end + + -- we have to link in reverse order + for i = #links, 1, -1 do + local link = links[i] package:add("links", link) end - os.trycp("build/*.a", package:installdir("lib")) - os.trycp("build/*.so", package:installdir("lib")) - os.trycp("build/*.dylib", package:installdir("lib")) - os.trycp("build/*.lib", package:installdir("lib")) - os.trycp("build/*.dll", package:installdir("bin")) + + os.trycp("build/**.a", package:installdir("lib")) + os.trycp("build/**.so", package:installdir("lib")) + os.trycp("build/**.dylib", package:installdir("lib")) + os.trycp("build/**.lib", package:installdir("lib")) + os.trycp("build/**.dll", package:installdir("bin")) os.trycp("build/luau*", package:installdir("bin")) + package:addenv("PATH", "bin") end) @@ -49,8 +69,12 @@ package("luau") luaL_openlibs(L); lua_close(L); } - ]]}) - ) - end) - + ]]}, {configs = {languages = "cxx11"}})) + assert(package:check_cxxsnippets({ test = [[ + #include + void test() { + Luau::FValue v("test", 42, true); + } + ]]}, {configs = {languages = "cxx11"}})) + end)