1
0
mirror of https://github.com/SKCraft/Launcher.git synced 2025-01-06 19:18:27 +01:00
🚀 Distribute your Minecraft modpacks with a custom launcher
Go to file
2015-02-19 22:08:31 -08:00
gradle/wrapper Switch to Gradle. Use git log --follow for history. 2015-02-18 21:30:25 -08:00
launcher Remove extra fields on LauncherFrame. 2015-02-19 22:08:31 -08:00
launcher-bootstrap Add bootstrap project. 2015-02-19 14:30:09 -08:00
launcher-builder Switch to Gradle. Use git log --follow for history. 2015-02-18 21:30:25 -08:00
launcher-fancy Update copyright in FancyLauncher. 2015-02-19 04:07:37 -08:00
readme Update the README. 2015-02-19 16:10:59 -08:00
sample-files Add missing sample project .jars. 2015-02-19 13:28:16 -08:00
.gitignore Add missing sample project .jars. 2015-02-19 13:28:16 -08:00
build.gradle Switch to Gradle. Use git log --follow for history. 2015-02-18 21:30:25 -08:00
gradlew Switch to Gradle. Use git log --follow for history. 2015-02-18 21:30:25 -08:00
gradlew.bat Switch to Gradle. Use git log --follow for history. 2015-02-18 21:30:25 -08:00
LICENSE.txt Initial commit. 2014-01-08 15:09:06 -08:00
README.md Update the README. 2015-02-19 16:10:59 -08:00
settings.gradle Add bootstrap project. 2015-02-19 14:30:09 -08:00

SKCraft Launcher

This project provides an open-source Minecraft launcher platform for downloading, installing, and updating modpacks.

The launcher has its roots in MC Alpha as a launcher for sk89q's server.

Note: There are two names to the launcher:

  • "SKMCLauncher" is the older version of this launcher. It is a more generic all-purpose launcher. It is no longer supported.
  • This project is called "SKCraft Launcher." It is supported and in active use.

Screenshots

Main Launcher

Skinned version (in launcher-fancy):

Skinned

Options

Optional Features

COnsole

Features

For the modpack creator:

  • No config files (aside from two at the start) needed to make a modpack -- you just make a folder with the modpack's files and run the builder tool on it
  • Supports putting default files (config files, etc.) that are not overridden on a future update
  • Supports the removal of files (which, from the PoV of the modpack creator, just involves deleting the file from the folder)
  • Supports "optional" files or file sets that can be toggled on or off by the user
  • The same directory can be used to create both a client modpack and a server modpack simultaneously (with server-only or client-only files) so you don't need to maintain two separate copies of the same files

Technical features:

  • Fast parallel downloads
  • Incremental updates (downloading only changed files)
  • Can update from ANY previous version to the latest version
  • Updates can be resumed if they've failed or have been cancelled
  • Updates also resume from where they left off
  • Static file structure so it can be placed on a CDN without modification
  • Files are deduplicated (on the file host) so you only ever have ONE version of a file across all modpacks and all modpack versions
  • Option for users to enter a special key in the options dialog that can be used to show additional modpacks (i.e. private ones for testing) -- this requires some server-side code
  • Can be used with a continuous integration system so you can combine it with your favorite version control (i.e. Git, SVN) and automatically deploy a new modpack update on push/tag

Client features:

  • Multiple modpacks are supported
  • Custom news page for showing custom information
  • Multiple profile support
  • Log messages dialog with upload log option
  • Options to adjust memory settings and Java flags
  • Everything happens in a background thread so the UI never freezes
  • All tasks have cancel buttons and (reasonably accurate) progress dialogs if things take too long
  • Self-update mechanism (however, this requires a separate bootstrapper project)

Getting Started

Compiling

In your command prompt or terminal, run:

./gradlew clean build

If you are on Windows:

gradlew clean build

If you wish to import the project into an IDE, you must add support for Project Lombok (IntelliJ IDEA users: also enable annotation processing in compiler settings).

Contributing

Pull requests can be submitted on GitHub, but we will accept them at our discretion. Please note that your code must follow Oracle's Java Code Conventions.

Contributions by third parties must be dual licensed under the two licenses described within LICENSE.txt (GNU General Public License, version 3, and the 3-clause BSD license).

License

The launcher is licensed under the GNU General Public License, version 3.