Unzip implementation in pure Luau
Find a file
2025-02-09 17:16:31 +00:00
.lune chore(lune): add dev lune scripts 2025-01-10 11:01:11 +00:00
.vscode chore: init, the basics 2024-12-28 17:19:37 +00:00
examples feat: add ZipEntry:unixMode() to get unix mode values as octals 2025-01-09 16:16:38 +00:00
lib style: add missed line after method decl 2025-01-12 08:02:18 +00:00
scripts style: apply stylua formatter 2025-01-10 11:01:58 +00:00
tests chore(tests): include case for zip version validation 2025-01-10 10:36:30 +00:00
.gitignore chore(gitignore): include zip test data 2025-01-07 13:43:15 +00:00
.luaurc chore: remove pkg alias 2025-01-06 06:08:34 +00:00
CHANGELOG.md chore(pkg): prepare for v0.1.0 2025-01-12 08:06:50 +00:00
dev.nix chore(nix): apply formatting with nixpkgs-fmt 2025-02-09 17:16:31 +00:00
flake.lock chore: include nix configs for devenv 2025-02-09 11:05:58 +00:00
flake.nix chore(nix): apply formatting with nixpkgs-fmt 2025-02-09 17:16:31 +00:00
LICENSE.md chore(LICENSE): change copyright field 2024-12-30 11:12:45 +00:00
pesde.lock chore(pkg): prepare for v0.1.0 2025-01-12 08:06:50 +00:00
pesde.toml chore(pkg): prepare for v0.1.0 2025-01-12 08:06:50 +00:00
README.md chore(README): fix MSLV again, fr this time 2025-01-10 22:50:53 +05:30

luau-unzip

Discord Pesde Lune

A Luau library to unzip and extract files from ZIP archives. The implementation is based on the PKZip APPNOTE v6.3.9.

Features

  • Extract files from ZIP archives.
  • Supports INFLATE and STORE decompression methods.
  • Traverse and list archive contents.
  • Retrieve archive statistics (file count, directory count, total size) and metadata.

Usage

local fs = require("@lune/fs")
local zip = require("luau-unzip")

-- Read the ZIP file
local file = fs.readFile("test.zip")

-- Load the ZIP archive
local reader = zip.load(buffer.fromstring(file))

-- Print directory structure
print("Directory structure:")
reader:walk(function(entry, depth)
    local prefix = string.rep("  ", depth)
    local suffix = if not entry.isDirectory
        then string.format(" (%d bytes), content: %s", entry.size, reader:extract(entry, { type = "text" }) :: string)
        else ""
    print(prefix .. entry.name .. suffix)
end)

-- List children of root directory
print("\nChildren of `/`:")
local assets = reader:listDirectory("/")
for _, entry in assets do
    print(string.format("    %s - %s (%s)", entry.name, if entry.isDirectory then "DIR" else "FILE", entry.method))
end

-- Get archive statistics
local stats = reader:getStats()
print("\nArchive stats:")
print("Files:", stats.fileCount)
print("Directories:", stats.dirCount)
print("Total size:", stats.totalSize, "bytes")

MSLV (Minimum Supported Luau Version)

This library requires at least Luau 0.629 (specifically requires leading |, buffer built-in and idiv operator support).

License

This project is licensed under the MIT license.