From 9e7a5d4214e8bfc05912723f0e8829d7309d41ae Mon Sep 17 00:00:00 2001 From: qudix <17361645+qudix@users.noreply.github.com> Date: Fri, 11 Oct 2024 14:38:21 -0500 Subject: [PATCH] feat: xmake | support plugin installation and packaging (#288) - when you build (or run `xmake install`) it will search for the environment variable `XSE_SF_MODS_PATH` or `XSE_SF_GAME_PATH` and copy install files (by default ".dll" and ".pdb") to the root paths listed. More files can be added using `add_installfiles`. - the install path above can be overwritten using `set_installdir` - when you run `xmake package` it will package the same files from above into a zip archive named after the target and the version. - these events can be overwritten on a per-target basis if you wish to make your own install/package logic. --- xmake-extra.lua | 62 +++++++++++++++++++++++++++++++++++++++++++++++-- xmake.lua | 3 +++ 2 files changed, 63 insertions(+), 2 deletions(-) diff --git a/xmake-extra.lua b/xmake-extra.lua index 840ee78d..d8b028fd 100644 --- a/xmake-extra.lua +++ b/xmake-extra.lua @@ -32,7 +32,7 @@ constinit auto SFSEPlugin_Version = []() noexcept { return v; }();]] -local PLUGIN_VERSION_FILE = [[ +local PLUGIN_RC_FILE = [[ #include 1 VERSIONINFO @@ -77,6 +77,15 @@ rule("commonlibsf.plugin") target:set("arch", "x64") target:set("kind", "shared") + target:add("installfiles", target:targetfile(), { prefixdir = "SFSE/Plugins" }) + target:add("installfiles", target:symbolfile(), { prefixdir = "SFSE/Plugins" }) + + if os.getenv("XSE_SF_MODS_PATH") then + target:set("installdir", path.join(os.getenv("XSE_SF_MODS_PATH"), target:name())) + elseif os.getenv("XSE_SF_GAME_PATH") then + target:set("installdir", path.join(os.getenv("XSE_SF_GAME_PATH"), "Data")) + end + local conf = target:extraconf("rules", "commonlibsf.plugin") local conf_dir = path.join(target:autogendir(), "rules", "commonlibsf", "plugin") @@ -151,5 +160,54 @@ rule("commonlibsf.plugin") end add_file("plugin.cpp", PLUGIN_FILE) - add_file("version.rc", PLUGIN_VERSION_FILE) + add_file("version.rc", PLUGIN_RC_FILE) + end) + + on_install(function(target) + local srcfiles, dstfiles = target:installfiles() + if srcfiles and #srcfiles > 0 and dstfiles and #dstfiles > 0 then + for idx, srcfile in ipairs(srcfiles) do + os.trycp(srcfile, dstfiles[idx]) + end + end + end) + + on_package(function(target) + import("core.project.config") + import("core.project.project") + import("utils.archive") + + local archive_name = target:name() .. "-" .. (target:version() or "0.0.0") .. ".zip" + print("packing %s .. ", archive_name) + + local root_dir = path.join(os.tmpdir(), "packages", project.name() or "", target:name()) + os.tryrm(root_dir) + + local srcfiles, dstfiles = target:installfiles(path.join(root_dir, "Data")) + if srcfiles and #srcfiles > 0 and dstfiles and #dstfiles > 0 then + for idx, srcfile in ipairs(srcfiles) do + os.trycp(srcfile, dstfiles[idx]) + end + else + return + end + + local archive_path = path.join(config.buildir(), "packages", archive_name) + local old_dir = os.cd(root_dir) + local archive_files = os.files("**") + os.cd(old_dir) + archive.archive(path.absolute(archive_path), archive_files, { curdir = root_dir }) + end) + + after_build(function(target) + import("core.project.depend") + import("core.project.project") + import("core.project.task") + + depend.on_changed(function() + local srcfiles, dstfiles = target:installfiles() + if srcfiles and #srcfiles > 0 and dstfiles and #dstfiles > 0 then + task.run("install") + end + end, { files = project.allfiles(), changed = target:is_rebuilt()}) end) diff --git a/xmake.lua b/xmake.lua index 09b20365..2002bf2b 100644 --- a/xmake.lua +++ b/xmake.lua @@ -33,6 +33,9 @@ target("commonlibsf") -- set target kind set_kind("static") + -- set build by default + set_default(os.scriptdir() == os.projectdir()) + -- add packages add_packages("spdlog", { public = true })