From b5478ed30139e055d3d6d37a77953aea1eaf011d Mon Sep 17 00:00:00 2001 From: ruki Date: Wed, 21 Aug 2024 23:42:13 +0800 Subject: [PATCH] add cli.archive and cli.extract --- xmake/modules/cli/archive.lua | 51 +++++++++++++++++++++ xmake/modules/cli/extract.lua | 48 +++++++++++++++++++ xmake/modules/utils/archive/archive_xmz.lua | 14 +++++- 3 files changed, 112 insertions(+), 1 deletion(-) create mode 100644 xmake/modules/cli/archive.lua create mode 100644 xmake/modules/cli/extract.lua diff --git a/xmake/modules/cli/archive.lua b/xmake/modules/cli/archive.lua new file mode 100644 index 00000000000..8c32b58fe5f --- /dev/null +++ b/xmake/modules/cli/archive.lua @@ -0,0 +1,51 @@ +--!A cross-platform build utility based on Lua +-- +-- Licensed under the Apache License, Version 2.0 (the "License"); +-- you may not use this file except in compliance with the License. +-- You may obtain a copy of the License at +-- +-- http://www.apache.org/licenses/LICENSE-2.0 +-- +-- Unless required by applicable law or agreed to in writing, software +-- distributed under the License is distributed on an "AS IS" BASIS, +-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +-- See the License for the specific language governing permissions and +-- limitations under the License. +-- +-- Copyright (C) 2015-present, TBOOX Open Source Group. +-- +-- @author ruki +-- @file archive.lua +-- + +-- imports +import("core.base.option") +import("utils.archive.archive") + +-- the options +local options = { + {nil, "compress", "kv", nil, "Set the compress algorithm.", values = {"fastest", "faster", "default", "better", "best"}}, + {'r', "recurse", "k", nil, "Enable recursive pattern."}, + {nil, "excludes", "kv", nil, "Set the excludes patterns.", + "e.g.", + " - xmake l cli.archive --excludes=\"*/dir/*|dir/*\" -o archivefile inputfiles"}, + {'o', "archivefile","kv", nil, "The output archive file."}, + {nil, "inputfiles", "vs", nil, "The input files."} +} + +function main(...) + local argv = table.pack(...) + local args = option.parse(argv, options, "Archive file.", + "", + "Usage: xmake l cli.archive [options]") + local archivefile = assert(args.archivefile, "please set output file!") + local inputfiles = assert(args.inputfiles, "please set input files!") + + local opt = {} + opt.recurse = args.recurse + opt.compress = args.compress + if args.excludes then + opt.excludes = args.excludes:split("|") + end + archive(archivefile, inputfiles, opt) +end diff --git a/xmake/modules/cli/extract.lua b/xmake/modules/cli/extract.lua new file mode 100644 index 00000000000..8028106f8b1 --- /dev/null +++ b/xmake/modules/cli/extract.lua @@ -0,0 +1,48 @@ +--!A cross-platform build utility based on Lua +-- +-- Licensed under the Apache License, Version 2.0 (the "License"); +-- you may not use this file except in compliance with the License. +-- You may obtain a copy of the License at +-- +-- http://www.apache.org/licenses/LICENSE-2.0 +-- +-- Unless required by applicable law or agreed to in writing, software +-- distributed under the License is distributed on an "AS IS" BASIS, +-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +-- See the License for the specific language governing permissions and +-- limitations under the License. +-- +-- Copyright (C) 2015-present, TBOOX Open Source Group. +-- +-- @author ruki +-- @file extract.lua +-- + +-- imports +import("core.base.option") +import("utils.archive.extract") + +-- the options +local options = { + {nil, "excludes", "kv", nil, "Set the excludes patterns.", + "e.g.", + " - xmake l cli.extract --excludes=\"*/dir/*|dir/*\" -o outputdir archivefile"}, + {'o', "outputdir", "kv", nil, "The output directory."}, + {nil, "archivefile","v", nil, "The archive file."} +} + +function main(...) + local argv = table.pack(...) + local args = option.parse(argv, options, "Extract file.", + "", + "Usage: xmake l cli.extract [options]") + local archivefile = assert(args.archivefile, "please set archive file!") + local outputdir = assert(args.outputdir, "please set output directory!") + + local opt = {} + opt.recurse = args.recurse + if args.excludes then + opt.excludes = args.excludes:split("|") + end + extract(archivefile, outputdir, opt) +end diff --git a/xmake/modules/utils/archive/archive_xmz.lua b/xmake/modules/utils/archive/archive_xmz.lua index 77e11005475..d9cf427c600 100644 --- a/xmake/modules/utils/archive/archive_xmz.lua +++ b/xmake/modules/utils/archive/archive_xmz.lua @@ -21,7 +21,7 @@ -- imports import("core.base.option") --- archive archive file +-- archive file -- -- @param archivefile the archive file. e.g. *.tar.gz, *.zip, *.7z, *.tar.bz2, .. -- @param inputfiles the input file or directory or list @@ -29,4 +29,16 @@ import("core.base.option") -- function main(archivefile, inputfiles, opt) opt = opt or {} + local files = {} + for _, inputfile in ipairs(inputfiles) do + if os.isdir(inputfile) then + table.join2(files, os.files(path.join(inputfile, opt.recurse and "**" or "*"))) + elseif os.isfile(inputfile) then + table.insert(files, inputfile) + end + end + inputfiles = files + + print("archivefile", archivefile) + print("inputfiles", inputfiles) end