luau-unzip/CHANGELOG.md

4.4 KiB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

Unreleased

Added

  • Added doc comments powered by moonwave
  • Added markdown doc generator lune script and configured pesde docs

Fixed

  • Fixed incorrect type signatures for some functions

Changed

  • Applied stylua formatter on code

0.1.1 - 2025-02-18

Added

  • Added GitHub Actions powered CI workflows
  • Started using nix for reproducible development environments

Fixed

  • Fixed repeated path components when using ZipEntry:getPath for some ZIP files

Changed

  • Pinned tooling dependencies (stylua, luau-lsp, pesde, lune) in manifest
  • README includes contributing guidelines and basic setup instructions
  • Updated dependencies

0.1.0 - 2025-01-12

luau-unzip is finally stable and tested enough for a v0.1.0 release! This release includes important bug fixes and a handful of new features as well. It does also have have breaking changes, so please take a look at the changed section below for those.

Added

  • PKZip version validation before extracting files
  • ZipEntry now has a versionMadeBy field which includes information about the host system and version of the ZIP file
  • ZipEntry now has a compressedSize field which indicates the size of the compressed data
  • Added method ZipEntry:compressionEfficiency to return compression efficiency in the form of a percentage
  • Added method ZipEntry:unixMode to parse and extract unix mode information from external file attributes
  • Added methods to handle path safety and sanitization were added to ZipEntry:
-- NOTE: All paths returned by methods use `/` as the path separator

-- Returns the path if it is safe, otherwise returns nil
entry:getSafePath()

-- Converts a potentially unsafe path to a safe one, possibly losing some information
entry:sanitizePath()

Changed

  • Renamed isAscii field for ZipEntry to isText
  • Renamed isString option for ZipReader:extract to isText

Fixed

  • Fixed a bug where ZipReader:extract would not correctly error when there was a mismatch between the count of entries specified in the EoCD and the number of entries found
  • Removed any typecast for internal decompression utilities due to table.freeze interfering with types

0.0.1 - 2025-01-07

Changed

  • Improved output format for tour example
  • Relaxed MSLV requirement to 0.593
  • Refactored utilities as separate modules
  • Improved test coverage with more edge case tests

0.0.1-rc.2 - 2025-01-06

Added

  • Support for symlinks - checking whether an entry is a symlink and following symlinks
local unzip = require("unzip")

local zip = unzip.load(...)

-- Given a ZIP of the structure: path/to/symlink -> path/to/target
local entry = zip:findEntry("path/to/symlink")

-- The following will return "path/to/target"
local targetPath = zip:extract(entry, { isString = true, followSymlinks = false })
print("Symlink target:", targetPath)

-- The following will return the contents of "path/to/target"
local followedTargetContents = zip:extract(entry, { isString = true, followSymlinks = true })
local targetContents = zip:extract(zip:findEntry("path/to/target"), { isString = true })

-- Following the symlink should give us the contents of the target file
assert(targetContents == followedTargetContents, "Symlink must lead to the target file!")
  • Added the isAscii field and automatic compressed data type detection when the isString option is not provided using internal file attributes

Fixed

  • Fixed a bug where ZIPs that contained an end of central directory record with a misaligned comment window would not be correctly read
  • Fixed an underflow while trying to align the byte boundary while decompressing uncompressed inflate blocks

0.0.1-rc.1 - 2025-01-06

Added

  • Initial library release 🎉