Skip to content

Latest commit

 

History

History
432 lines (303 loc) · 15.9 KB

CHANGELOG.md

File metadata and controls

432 lines (303 loc) · 15.9 KB

Changelog

Unreleased

v0.25.0

Highlights

  • Implemented the pakku fetch --shelve flag.
  • Removed the pakku sync command's subpath auto-detection. (It did not work properly, and it's not worth rewriting it.)
  • Fixed error when requesting GitHub projects generated from a template repository.

pakku fetch --shelve Explanation

This feature was implemented to help revive old modpacks that use mods outside any platform.

When pakku fetch --shelve is used, Pakku will move unknown project files to a shelf instead of deleting them. The shelf directory is located at .pakku/shelf/.

This feature can be used together with the pakku sync command in the following way:

  • Run the pakku -y sync command to detect and add your local project files.
  • Run the pakku fetch --shelve command to move any other project files outside any platform to the shelf.
  • Decide what you want to do with each project file on the shelf.
    • You can move the project to the project overrides directory .pakku/overrides/mods/.
    • You can try to search for the project online. (For example, there is a chance that some of these files will be on GitHub.)

v0.24.1

  • Refactored sync command's subpath search algorithm to async.
  • Fixed export profiles' orElse function not working as intended. (Optional integration with FileDirector did not work.)

v0.24.0

Highlights

  • Fixed a major bug where projects were not being exported to modpack manifests.
  • Implemented the sync command.
    • This command can be used to sync your modpack with local project files.
  • Limited max number of retries for fetch command to 3 instead of 10.

Other

  • Made most of the commands print help on empty args and added a spinner progress bar to some of them.
  • Projects will now be compared with lowercase and white space filtered project names and their project file hashes.
  • Trailing commas are now allowed in the config file and lock file.
  • Added a better error message to ProjNotFound errors.
  • .jar.meta is now allowed extension when removing old files on fetch.
  • Created tests for CurseForge and Modrinth modpack models.

v0.23.0

  • Fixed that updating GitHub projects was not working properly.

Technical Notes

  • Implemented DSL builder for export profiles.
  • Implemented error severity and made the AlreadyAdded error only a notice.

v0.22.0

Highlights

  • When removing a project, Pakku will always ask whether you want to remove each of its dependencies.
  • Added glob pattern support for specifying overrides, server_overrides and client_overrides, in #70.
    • This new implementation is optimized to work with large modpacks.
    • For more info see v0.20.0.

Fixes

  • Removed hyperlink from exported modpack file path messages. They didn't work properly on all platforms.

API

  • Breaking change: Refactored action errors to separate data classes.
  • Created a mini framework for simplifying tests.

v0.21.0

  • Improved projects updating, by @SettingDust in #49.
    • Projects now prefer their current loaders of project files when updating.
  • Added option the specify the project type when adding projects, by @SettingDust in #54.
    • Fixed duplicated project files when updating.
  • Updated Exporting a Modpack docs page and improved the Managing Projects docs page.

v0.20.2

  • Fixed an issue that caused project files from CurseForge to be outdated due to incorrect release date parsing.

v0.20.1

  • Reverted glob pattern matching support for overrides, due to performance limitations with large modpacks.
    • It will be reintroduced in the next releases.

v0.20.0

What's new?

  • Implemented glob pattern support for specifying overrides. by @SettingDust in #43, and @juraj-hrivnak.
    • An asterisk "*" matches anything except a slash. The character "?" matches any one character except "/". The range notation, e.g. [a-zA-Z], can be used to match one of the characters in a range.
    • Two consecutive asterisks ("**") means match in all directories; <directory>/** means match everything inside the directory.
    • An optional prefix "!" negates the pattern; any matching file included by a previous pattern will become excluded again.
  • Implemented retry logic for the fetch command.
    • Use pakku fetch --retry to retry downloading when it fails, with an optional number of times to retry. (Defaults to 2.)
  • Added support for specifying a different version of an already added project using the add command.
  • Added simple colored diff for showing changes to file names when using the status command.
  • The newest file from all providers is now preferred when downloading, by @SettingDust in #41.

v0.19.0

Highlights

  • Added the cfg command for configuring properties of the config file, by @SettingDust in #29.
    • This change deprecated the pakku set [<projects>] argument. Use the config file (pakku.json) or the cfg prj subcommand instead.
  • Implemented configurable subpaths for projects and configurable paths for project types.
  • Implemented configurable project aliases, by @SettingDust in #34.
  • Added support for data packs.
  • Added better support for multi-loader modpacks, by @SettingDust in #36 and #37. (Sinytra Connector support.)
    • Project files are now also sorted in order of loaders in the lock file.
  • Rewritten fetch command's deleting algorithm to account for subpaths.
    • Saves & screenshots are always excluded.
  • Improved the UI of the status command.
    • Now it's much nicer and shows you changes to project files.

Fixes

  • Fixed ConcurrentModificationException on running fetch command in some cases.
  • Fixed setting loaders using the set command when projects have unusual loaders.

Configurable Subpaths

There is now a new subpath property for projects that you configure in the config file or using the cfg prj subcommand.

Config file - syntax:

{
  "projects": {
    "<project>": {
      "subpath": "<path>"
    }
  }
}

Config file - example usage:

{
  "projects": {
    "sodium-extras": {
      "subpath": "optimize.client"
    },
    "iris": {
      "subpath": "decoration.client"
    }
  }
}

Configurable Paths for Project Types

There is now a variable for each project type that you configure in the config file or using the cfg command.

Config file - syntax:

{
  "paths": {
    "mods": "<path>",
    "resource_packs": "<path>",
    "data_packs": "<path>",
    "worlds": "<path>",
    "shaders": "<path>"
  }
}

Project Aliases

There is now a new aliases property of type array for projects that you configure in the config file or using the cfg prj subcommand.

Config file - syntax:

{
  "projects": {
    "<project>": {
      "aliases": ["<alias>"]
    }
  }
}

Config file - example usage:

{
  "projects": {
    "forgified-fabric-api": {
      "aliases": ["fabric-api"]
    }
  }
}

API

  • Updated Clikt to 5.0.0 & Mordant to 3.0.0.
  • Improved docs generation with better subcommand support.

v0.18.2

  • Fixed error when GitHub license URL is null.

v0.18.1

  • Fixed tag parsing in GitHub project arguments.

v0.18.0

Highlights

Pakku now fully supports GitHub.

Adding GitHub projects

GitHub repositories with releases can be added as projects. To add a GitHub project, run pakku add {owner}/{repo} or pakku add https://github.com/{owner}/{repo}.

You can also use the prj subcommand: pakku add prj --gh {owner}/{repo} or pakku add prj --gh https://github.com/{owner}/{repo}

Combining projects is also possible: pakku add prj --mr greenery --gh juraj-hrivnak/Greenery

To add a specific version (tag) of a GitHub project, run pakku add {owner}/{repo}@{tag}, pakku add https://github.com/{owner}/{repo}/releases/tag/{tag} or pakku add https://github.com/{owner}/{repo}/tree/{tag}.

Updating

GitHub projects can be updated using the pakku update command. They are also recognized in other commands as expected.

Exporting

For CurseForge, GitHub projects are added to the overrides. For Modrinth, GitHub projects are added to the modrinth.index.json also with generated sha512 and sha1 hashes.

The project side of GitHub projects defaults to BOTH. If you need to change this, do so in pakku.json. Pakku determines whether the GitHub project is redistributable based on its licence's spdx code. No licence means ARR.

UI

GitHub projects are displayed in the format: gh={owner}/{repo}

gh_support

Other Changes

  • Project types can now be overridden in the config file (pakku.json).
  • Deprecated set command's -s,--side and -r, --redistributable options. Use the config file (pakku.json) instead.

Technical Notes

  • Many functions now support IProjectProviders instead of Platforms only.

  • The lock file is now sorted by project names instead of slugs.

  • Implemented the ProjectArg monad to better handle project additions.

    • Its fold() function can be used to map the possible arg types:

      arg.fold(
          commonArg = { },
          gitHubArg = { }
      )
  • Integrity checking will now allow projects without hashes (GitHub) and will warn the user instead.

v0.17.1

  • Fixed add command not being invoked without a subcommand. (#22)
  • Updated to the latest snapshot of the Clikt library.

v0.17.0

  • Added the prj subcommand for the add command.
    • With this subcommand you can specify the project you want to add precisely, using the --cf and/or --mr options.
    • This subcommand can be used multiple times.
    • Example usage: pakku add prj --mr iris --cf irisshaders
    • Note that the add command functionality remains the same.
  • Added descriptions to command arguments.

v0.16.0

  • When adding projects, slugs are now more robustly resolved.
    • Project additions are now stricter. Pakku now doesn't allow you to add projects without any files.
    • Fixed #15.
  • Added backup handling when writing to files. When an error occurs during writing to a file a backup is restored.
  • Pakku now shows you the project type alongside the slugs in all messages.

v0.15.1

  • Fixed modpack @var@ replacements not working.
  • URLs in FileDirector's config are now encoded. This is a workaround for FileDirector#19.

v0.15.0

  • Refactored deleting old files in fetch command. (Improved performance.)
  • The status command now also shows you the Minecraft version, loaders and author.
  • Removed cache4k dependency.

v0.14.3

  • Fixed that resource and shader packs were exported to the server pack when their project side was missing.

v0.14.2

  • Fixed typo in the export command output path.

v0.14.1

  • Implemented auto generation of command parameters and arguments for docs.
  • Updated the docs with better info on importing and command references.
  • Made CLI message prefix color inverted (like it was before).

v0.14.0

  • Fixed import not recognizing files outside modpack folder.
  • Removed korlibs.io dependency and added kotlinx.atomicfu.
  • Unzipping files now uses okio under the hood.

v0.13.1

  • Removed unwanted File not found: '.\.pakku\cli-config.json' print when CLI Config does not exist.
  • Set default CLI theme to Pakku's default theme instead of the default one.

v0.13.0

  • Implemented the CLI Config (cli-config.json), an optional file which can be used to modify the UI aspects of the Pakku CLI.
    • It must be located in the Pakku directory (.pakku).
    • The relative path from the .minecraft directory should be: .pakku/cli-config.json.
    • Properties:
      • theme: can be default or ascii. (Defaults to default 😜.)
      • ansi_level: can be none, ansi16, ansi256 or truecolor. (By default it is automatically detected based on your terminal/CMD.)
  • NoSuchFileException is now wrapped as FileNotFound action error.
  • Errors when creating the modpack zip file now return early.

v0.12.1

  • Fixed exceptions being uncaught when writing output files on export.
  • Pakku now detects terminal interactivity and ansiLevel by default.

v0.12.0

  • Rewritten exporting and implemented export rules and export profiles.
    • Exporting is now cached and asynchronous.
    • Internally, exporting a modpack is now controlled by a list of rules which control what should happen with the content you want to export/package.
      • Export rules must be part of an export profile to be executed.
      • Each export profile is independent of each other and will result in one exported file.
      • This functionality can be currently only controlled using the API. For more information see the pull request #18.
  • Improved ZIP creation and removed zip4j.
  • Dependencies are now not resolved on import by default. - by @Wxrlds in pull request #16.
    • There now is a -D, --deps flag, which resolves dependencies like before.
  • Added "Updated" section to diff when using the diff command. - by @Wxrlds in pull request #17.
    • There now is a -v, --verbose flag which displays detailed information about which version of a project was updated to which version.
  • Implemented modpack @var@ replacements on export. @name@, @version@, @description@ and @author@ will be respectively replaced with the correct values from the config file in the exported modpack.
  • Improved some error messages and added hyperlinks to the exported modpack file path.
  • Refactored project override syncing (with the modpack directory).
  • Added initial lockfile_version: 1 property to lock file. Lock file without this property is still treated as v1.

v0.11.3

  • Improved resolving old files on fetch.

v0.11.2

  • Fixed error with fetch command.
  • Added better path info for files on fetch.

v0.11.1

What's new?

  • Fixed error with null icon in CurseForge projects.
  • Fixed the fetch command not resolving files other than from CurseForge.

v0.11.0

  • Refactored the fetch command to use the new fetch action API call.
    • Downloading project files and writing to disk are now in separate threads, making it way faster.
    • Hashes are now the preferred way to check for old project files instead of file names.
  • Increased timeouts for HTTP requests to avoid issues with big modpacks.

v0.10.0

What's new?

  • Implemented new UI for most of the CLI.
    • Slugs now contain hyperlinks. The ls command is now better formatted and contains type and side information for projects.
  • Implemented the status command as a better way to check for updates than the ls -c command.
  • Improved rm command with better "autocomplete" for slugs.
  • Improved importing - now supports importing without manually setting Minecraft versions and loaders.
  • Fixed issue with the fetch command not properly listing platforms.

Docs

  • Implemented auto generation for CLI Commands reference for docs.
  • Added option to switch between Java and PATH examples in docs.

API

  • Refactored models