Merge branch 'develop' into feature/close_after_launch
This commit is contained in:
		
							
								
								
									
										107
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,107 @@
 | 
			
		||||
name: build_portable
 | 
			
		||||
 | 
			
		||||
on:
 | 
			
		||||
  [push, pull_request, workflow_dispatch]
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  build:
 | 
			
		||||
    strategy:
 | 
			
		||||
      fail-fast: false
 | 
			
		||||
      matrix:
 | 
			
		||||
        include:
 | 
			
		||||
 | 
			
		||||
          - os: ubuntu-20.04
 | 
			
		||||
            qt_version: 5.12.8
 | 
			
		||||
            qt_host: linux
 | 
			
		||||
 | 
			
		||||
          - os: windows-2022
 | 
			
		||||
            qt_version: 5.15.2
 | 
			
		||||
            qt_host: windows
 | 
			
		||||
            qt_arch: win64_mingw81
 | 
			
		||||
 | 
			
		||||
          - os: macos-11
 | 
			
		||||
            qt_version: 5.12.12
 | 
			
		||||
            qt_host: mac
 | 
			
		||||
            macosx_deployment_target: 10.12
 | 
			
		||||
 | 
			
		||||
    runs-on: ${{ matrix.os }}
 | 
			
		||||
 | 
			
		||||
    env:
 | 
			
		||||
      MACOSX_DEPLOYMENT_TARGET: ${{matrix.macosx_deployment_target}}
 | 
			
		||||
 | 
			
		||||
    steps:
 | 
			
		||||
 | 
			
		||||
      - name: Checkout
 | 
			
		||||
        uses: actions/checkout@v2
 | 
			
		||||
        with:
 | 
			
		||||
          submodules: 'true'
 | 
			
		||||
 | 
			
		||||
      - name: Install OpenJDK
 | 
			
		||||
        uses: AdoptOpenJDK/install-jdk@v1
 | 
			
		||||
        with:
 | 
			
		||||
          version: '17'
 | 
			
		||||
 | 
			
		||||
      - name: Cache Qt
 | 
			
		||||
        id: cache-qt
 | 
			
		||||
        uses: actions/cache@v2
 | 
			
		||||
        with:
 | 
			
		||||
          path: "${{ github.workspace }}/Qt/"
 | 
			
		||||
          key: ${{ runner.os }}-${{ matrix.qt_version }}-qt_cache
 | 
			
		||||
 | 
			
		||||
      - name: Install Qt
 | 
			
		||||
        uses: jurplel/install-qt-action@v2
 | 
			
		||||
        with:
 | 
			
		||||
          version: ${{ matrix.qt_version }}
 | 
			
		||||
          host: ${{ matrix.qt_host }}
 | 
			
		||||
          arch: ${{ matrix.qt_arch }}
 | 
			
		||||
          cached: ${{ steps.cache-qt.outputs.cache-hit }}
 | 
			
		||||
          dir: "${{ github.workspace }}/Qt/"
 | 
			
		||||
 | 
			
		||||
      - name: Install Ninja
 | 
			
		||||
        uses: urkle/action-get-ninja@v1
 | 
			
		||||
 | 
			
		||||
      - name: Configure CMake
 | 
			
		||||
        run: |
 | 
			
		||||
          cmake -S . -B build -DCMAKE_INSTALL_PREFIX=install -DCMAKE_BUILD_TYPE=Debug -G Ninja
 | 
			
		||||
 | 
			
		||||
      - name: Build
 | 
			
		||||
        run: |
 | 
			
		||||
          cmake --build build
 | 
			
		||||
 | 
			
		||||
      - name: Install
 | 
			
		||||
        run: |
 | 
			
		||||
          cmake --install build
 | 
			
		||||
 | 
			
		||||
      - name: Install OpenSSL libs
 | 
			
		||||
        if: runner.os == 'Windows'
 | 
			
		||||
        run: |
 | 
			
		||||
          python -m pip install --upgrade pip
 | 
			
		||||
          python -m pip install aqtinstall==2.0.5
 | 
			
		||||
          python -m aqt install-tool -O "${{ github.workspace }}\Qt\" windows desktop tools_openssl_x64
 | 
			
		||||
          copy "${{ github.workspace }}\Qt\Tools\OpenSSL\Win_x64\bin\libssl-1_1-x64.dll" "${{ github.workspace }}\install\"
 | 
			
		||||
          copy "${{ github.workspace }}\Qt\Tools\OpenSSL\Win_x64\bin\libcrypto-1_1-x64.dll" "${{ github.workspace }}\install\"
 | 
			
		||||
 | 
			
		||||
      - name: chmod binary on macOS
 | 
			
		||||
        if: runner.os == 'macOS'
 | 
			
		||||
        run: |
 | 
			
		||||
          chmod +x "${{ github.workspace }}/install/PolyMC.app/Contents/MacOS/polymc"
 | 
			
		||||
 | 
			
		||||
      - name: tar bundle on macOS
 | 
			
		||||
        if: runner.os == 'macOS'
 | 
			
		||||
        run: |
 | 
			
		||||
          cd install
 | 
			
		||||
          tar -czf ../polymc.tar.gz *
 | 
			
		||||
 | 
			
		||||
      - name: Upload package for Linux and Windows
 | 
			
		||||
        if: runner.os != 'macOS'
 | 
			
		||||
        uses: actions/upload-artifact@v2
 | 
			
		||||
        with:
 | 
			
		||||
          name: polymc-${{ matrix.os }}-portable
 | 
			
		||||
          path: install/**
 | 
			
		||||
 | 
			
		||||
      - name: Upload package for macOS
 | 
			
		||||
        if: runner.os == 'macOS'
 | 
			
		||||
        uses: actions/upload-artifact@v2
 | 
			
		||||
        with:
 | 
			
		||||
          name: polymc-${{ matrix.os }}-portable
 | 
			
		||||
          path: polymc.tar.gz
 | 
			
		||||
							
								
								
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -40,13 +40,5 @@ run/
 | 
			
		||||
 | 
			
		||||
.cache/
 | 
			
		||||
 | 
			
		||||
# Flatpak builds
 | 
			
		||||
.flatpak-builder
 | 
			
		||||
flatbuild
 | 
			
		||||
builddir
 | 
			
		||||
# Deb
 | 
			
		||||
packages/debian/polymc/usr/
 | 
			
		||||
packages/debian/polymc.deb
 | 
			
		||||
packages/debian/polymc/DEBIAN/control
 | 
			
		||||
# Nix/NixOS
 | 
			
		||||
result/
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										15
									
								
								BUILD.md
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								BUILD.md
									
									
									
									
									
								
							@@ -25,7 +25,6 @@ The rest of the documentation assumes you have already cloned the repository.
 | 
			
		||||
Getting the project to build and run on Linux is easy if you use any modern and up-to-date linux distribution.
 | 
			
		||||
 | 
			
		||||
## Build dependencies
 | 
			
		||||
 | 
			
		||||
- A C++ compiler capable of building C++11 code.
 | 
			
		||||
- Qt Development tools 5.6 or newer (`qtbase5-dev qtchooser qt5-qmake qtbase5-dev-tools libqt5core5a libqt5network5 libqt5gui5` on Debian-based system)
 | 
			
		||||
- cmake 3.1 or newer (`cmake` on Debian-based system)
 | 
			
		||||
@@ -116,7 +115,7 @@ The path to the rpm packages will be printed when the build is complete.
 | 
			
		||||
 | 
			
		||||
### Building a flatpak
 | 
			
		||||
 | 
			
		||||
You only need to clone the flatpak sources  
 | 
			
		||||
You only need to clone the flatpak sources
 | 
			
		||||
`flatpak` and `flatpak-builder` need to be installed on your system
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
@@ -256,8 +255,8 @@ zlib1.dll
 | 
			
		||||
 | 
			
		||||
- Install XCode Command Line tools
 | 
			
		||||
- Install the official build of CMake (https://cmake.org/download/)
 | 
			
		||||
- Install JDK 8 (https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html)
 | 
			
		||||
- Get Qt 5.6 and install it (https://download.qt.io/new_archive/qt/5.6/5.6.3/)
 | 
			
		||||
- Install JDK 8 (https://adoptium.net/releases.html?variant=openjdk8&jvmVariant=hotspot)
 | 
			
		||||
- Get Qt 5.6 and install it (https://download.qt.io/new_archive/qt/5.6/5.6.3/) or higher (tested) (https://www.qt.io/download-qt-installer?utm_referrer=https%3A%2F%2Fwww.qt.io%2Fdownload-open-source)
 | 
			
		||||
 | 
			
		||||
You can use `homebrew` to simplify the installation of build dependencies
 | 
			
		||||
 | 
			
		||||
@@ -271,7 +270,7 @@ xcode-select --install
 | 
			
		||||
 | 
			
		||||
### Build
 | 
			
		||||
 | 
			
		||||
Pick an installation path - this is where the final `.app` will be constructed when you run `make install`. Supply it as the `CMAKE_INSTALL_PREFIX` argument during CMake configuration.
 | 
			
		||||
Pick an installation path - this is where the final `PolyMC.app` will be constructed when you run `make install`. Supply it as the `CMAKE_INSTALL_PREFIX` argument during CMake configuration. By default, it's in the dist folder under PolyMC
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
mkdir build
 | 
			
		||||
@@ -281,15 +280,15 @@ cmake \
 | 
			
		||||
 -DCMAKE_CXX_COMPILER=/usr/bin/clang++ \
 | 
			
		||||
 -DCMAKE_BUILD_TYPE=Release \
 | 
			
		||||
 -DCMAKE_INSTALL_PREFIX:PATH="$(dirname $PWD)/dist/" \
 | 
			
		||||
 -DCMAKE_PREFIX_PATH="/path/to/Qt5.6/" \
 | 
			
		||||
 -DQt5_DIR="/path/to/Qt5.6/" \
 | 
			
		||||
 -DCMAKE_PREFIX_PATH="/path/to/Qt/" \
 | 
			
		||||
 -DQt5_DIR="/path/to/Qt/" \
 | 
			
		||||
 -DLauncher_LAYOUT=mac-bundle \
 | 
			
		||||
 -DCMAKE_OSX_DEPLOYMENT_TARGET=10.7 \
 | 
			
		||||
 ..
 | 
			
		||||
make install
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Remember to replace `/path/to/Qt5.6/` with the actual path. For newer Qt installations, it is often in your home directory.
 | 
			
		||||
Remember to replace `/path/to/Qt/` with the actual path. For newer Qt installations, it is often in your home directory.
 | 
			
		||||
 | 
			
		||||
**Note:** The final app bundle may not run due to code signing issues, which
 | 
			
		||||
need to be fixed with `codesign -fs -`.
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										32
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								README.md
									
									
									
									
									
								
							@@ -10,6 +10,8 @@ This is a **fork** of the MultiMC Launcher and not endorsed by MultiMC. The Poly
 | 
			
		||||
<br>
 | 
			
		||||
 | 
			
		||||
# Installation
 | 
			
		||||
- All packages (archived by version) can be found [here](https://packages.polymc.org/) ([latest](https://packages.polymc.org/latest)).
 | 
			
		||||
- Last build status: https://jenkins.polymc.org/job/PolyMC/lastBuild/
 | 
			
		||||
 | 
			
		||||
## 🐧 Linux
 | 
			
		||||
 | 
			
		||||
@@ -20,15 +22,13 @@ This is a **fork** of the MultiMC Launcher and not endorsed by MultiMC. The Poly
 | 
			
		||||
<a href="https://packages.polymc.org/latest/appimage/PolyMC-latest-x86_64.AppImage"><img src="https://docs.appimage.org/_images/download-appimage-banner.svg" width="240" alt="Download as AppImage" /></a>
 | 
			
		||||
 | 
			
		||||
- [AppImage SHA256](https://packages.polymc.org/latest/appimage/PolyMC-latest-x86_64.AppImage.sha256)
 | 
			
		||||
- All packages (archived by version) can be found [here](https://packages.polymc.org/) ([latest](https://packages.polymc.org/latest)).
 | 
			
		||||
- Last build status: https://jenkins.polymc.org/job/PolyMC/lastBuild/
 | 
			
		||||
- [System Package (AMD64)](https://packages.polymc.org/latest/lin64-system/lin64-system.tar.zst) ([SHA256](https://packages.polymc.org/latest/lin64-system/lin64-system.tar.zst.sha256)) - a generic system package intended to be used as a base for making distro-specific packages
 | 
			
		||||
 | 
			
		||||
### <img src="https://www.vectorlogo.zone/logos/archlinux/archlinux-icon.svg" height="20"/> Arch Linux
 | 
			
		||||
 | 
			
		||||
There are several AUR packages available:  
 | 
			
		||||
[](https://aur.archlinux.org/packages/polymc/)  
 | 
			
		||||
[](https://aur.archlinux.org/packages/polymc-bin/)  
 | 
			
		||||
There are several AUR packages available:
 | 
			
		||||
 | 
			
		||||
[](https://aur.archlinux.org/packages/polymc/)
 | 
			
		||||
[](https://aur.archlinux.org/packages/polymc-bin/)
 | 
			
		||||
[](https://aur.archlinux.org/packages/polymc-git/)
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
@@ -42,11 +42,11 @@ yay -S polymc-git
 | 
			
		||||
 | 
			
		||||
### <img src="https://www.vectorlogo.zone/logos/debian/debian-icon.svg" height="20" /> Debian
 | 
			
		||||
 | 
			
		||||
We use [makedeb](https://docs.makedeb.org/) for our Debian packages.  
 | 
			
		||||
We use [makedeb](https://docs.makedeb.org/) for our Debian packages.
 | 
			
		||||
Several MPR packages are available:
 | 
			
		||||
 | 
			
		||||
[](https://mpr.makedeb.org/packages/polymc)  
 | 
			
		||||
[](https://mpr.makedeb.org/packages/polymc-bin)  
 | 
			
		||||
[](https://mpr.makedeb.org/packages/polymc)
 | 
			
		||||
[](https://mpr.makedeb.org/packages/polymc-bin)
 | 
			
		||||
[](https://mpr.makedeb.org/packages/polymc-git)
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
@@ -69,7 +69,7 @@ A Gentoo ebuild is available in the [swirl](https://git.swurl.xyz/swirl/ebuilds)
 | 
			
		||||
```sh
 | 
			
		||||
# as root:
 | 
			
		||||
emerge --oneshot eselect-repository
 | 
			
		||||
eselect-repository enable swirl
 | 
			
		||||
eselect repository enable swirl
 | 
			
		||||
emaint sync -r swirl
 | 
			
		||||
emerge polymc
 | 
			
		||||
# to use latest git version:
 | 
			
		||||
@@ -78,7 +78,14 @@ sudo tee -a /etc/portage/package.accept_keywords <<< "=games-action/polymc-9999
 | 
			
		||||
 | 
			
		||||
### <img src="https://www.vectorlogo.zone/logos/getfedora/getfedora-icon.svg" height="20"> Fedora
 | 
			
		||||
 | 
			
		||||
An RPM package is available on [COPR](https://copr.fedorainfracloud.org/coprs/sentry/polymc/)
 | 
			
		||||
An RPM package is available on [COPR](https://copr.fedorainfracloud.org/coprs/polymc/polymc/).
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
sudo dnf copr enable polymc/polymc
 | 
			
		||||
sudo dnf install polymc
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Alternatively, a COPR maintained by a PolyMC user (instead of Jenkins' automated builds) is available [here](https://copr.fedorainfracloud.org/coprs/sentry/polymc).
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
sudo dnf copr enable sentry/polymc
 | 
			
		||||
@@ -91,7 +98,7 @@ sudo dnf install polymc
 | 
			
		||||
 | 
			
		||||
## <img src="https://www.vectorlogo.zone/logos/apple/apple-tile.svg" height="20" /> MacOS
 | 
			
		||||
 | 
			
		||||
MacOS currently does not have any packages. We are still working on setting up MacOS packaging.
 | 
			
		||||
MacOS currently does not have any packages. We are still working on setting up MacOS packaging. Meanwhile, you can [build](https://github.com/PolyMC/PolyMC/blob/develop/BUILD.md#macos) it for yourself.
 | 
			
		||||
 | 
			
		||||
# Help & Support
 | 
			
		||||
 | 
			
		||||
@@ -119,7 +126,6 @@ If you want to contribute to PolyMC you might find it useful to join our Discord
 | 
			
		||||
If you want to build PolyMC yourself, check [BUILD.md](BUILD.md) for build instructions.
 | 
			
		||||
 | 
			
		||||
## Code formatting
 | 
			
		||||
 | 
			
		||||
Just follow the existing formatting.
 | 
			
		||||
 | 
			
		||||
In general, in order of importance:
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										1532
									
								
								changelog.md
									
									
									
									
									
								
							
							
						
						
									
										1532
									
								
								changelog.md
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										12
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										12
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							@@ -18,11 +18,11 @@
 | 
			
		||||
    },
 | 
			
		||||
    "flake-utils": {
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1638122382,
 | 
			
		||||
        "narHash": "sha256-sQzZzAbvKEqN9s0bzWuYmRaA03v40gaJ4+iL1LXjaeI=",
 | 
			
		||||
        "lastModified": 1642700792,
 | 
			
		||||
        "narHash": "sha256-XqHrk7hFb+zBvRg6Ghl+AZDq03ov6OshJLiSWOoX5es=",
 | 
			
		||||
        "owner": "numtide",
 | 
			
		||||
        "repo": "flake-utils",
 | 
			
		||||
        "rev": "74f7e4319258e287b0f9cb95426c9853b282730b",
 | 
			
		||||
        "rev": "846b2ae0fc4cc943637d3d1def4454213e203cba",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
@@ -49,11 +49,11 @@
 | 
			
		||||
    },
 | 
			
		||||
    "nixpkgs": {
 | 
			
		||||
      "locked": {
 | 
			
		||||
        "lastModified": 1641887635,
 | 
			
		||||
        "narHash": "sha256-kDGpufwzVaiGe5e1sBUBPo9f1YN+nYHJlYqCaVpZTQQ=",
 | 
			
		||||
        "lastModified": 1643169865,
 | 
			
		||||
        "narHash": "sha256-+KIpNRazbc8Gac9jdWCKQkFv9bjceaLaLhlwqUEYu8c=",
 | 
			
		||||
        "owner": "nixos",
 | 
			
		||||
        "repo": "nixpkgs",
 | 
			
		||||
        "rev": "b2737d4980a17cc2b7d600d7d0b32fd7333aca88",
 | 
			
		||||
        "rev": "945ec499041db73043f745fad3b2a3a01e826081",
 | 
			
		||||
        "type": "github"
 | 
			
		||||
      },
 | 
			
		||||
      "original": {
 | 
			
		||||
 
 | 
			
		||||
@@ -32,8 +32,14 @@ QString getCreditsHtml()
 | 
			
		||||
    QTextStream stream(&output);
 | 
			
		||||
    stream.setCodec(QTextCodec::codecForName("UTF-8"));
 | 
			
		||||
    stream << "<center>\n";
 | 
			
		||||
 | 
			
		||||
    stream << "<h3>" << QObject::tr("PolyMC Developers", "About Credits") << "</h3>\n";
 | 
			
		||||
    stream << "<p>swirl <<a href='mailto:swurl@swurl.xyz'>swurl@swurl.xyz </a>></p>\n";
 | 
			
		||||
    stream << "<p>LennyMcLennington <<a href='mailto:lenny@sneed.church'>lenny@sneed.church</a>></p>\n";
 | 
			
		||||
    stream << "<br />\n";
 | 
			
		||||
 | 
			
		||||
    // TODO: possibly retrieve from git history at build time?
 | 
			
		||||
    stream << "<h3>" << QObject::tr("Developers", "About Credits") << "</h3>\n";
 | 
			
		||||
    stream << "<h3>" << QObject::tr("MultiMC Developers", "About Credits") << "</h3>\n";
 | 
			
		||||
    stream << "<p>Andrew Okin <<a href='mailto:forkk@forkk.net'>forkk@forkk.net</a>></p>\n";
 | 
			
		||||
    stream << "<p>Petr Mrázek <<a href='mailto:peterix@gmail.com'>peterix@gmail.com</a>></p>\n";
 | 
			
		||||
    stream << "<p>Sky Welch <<a href='mailto:multimc@bunnies.io'>multimc@bunnies.io</a>></p>\n";
 | 
			
		||||
@@ -47,6 +53,7 @@ QString getCreditsHtml()
 | 
			
		||||
    stream << "<p>Kilobyte <<a href='mailto:stiepen22@gmx.de'>stiepen22@gmx.de</a>></p>\n";
 | 
			
		||||
    stream << "<p>Rootbear75 <<a href='https://twitter.com/rootbear75'>@rootbear75</a>></p>\n";
 | 
			
		||||
    stream << "<p>Zeker Zhayard <<a href='https://twitter.com/zeker_zhayard'>@Zeker_Zhayard</a>></p>\n";
 | 
			
		||||
    stream << "<p>Everyone else who <a href='https://github.com/PolyMC/PolyMC/graphs/contributors'>contributed</a>!</p>\n";
 | 
			
		||||
    stream << "<br />\n";
 | 
			
		||||
 | 
			
		||||
    stream << "</center>\n";
 | 
			
		||||
@@ -83,8 +90,12 @@ AboutDialog::AboutDialog(QWidget *parent) : QDialog(parent), ui(new Ui::AboutDia
 | 
			
		||||
    ui->icon->setPixmap(APPLICATION->getThemedIcon("logo").pixmap(64));
 | 
			
		||||
    ui->title->setText(launcherName);
 | 
			
		||||
 | 
			
		||||
    ui->versionLabel->setText(tr("Version") +": " + BuildConfig.printableVersionString());
 | 
			
		||||
    ui->platformLabel->setText(tr("Platform") +": " + BuildConfig.BUILD_PLATFORM);
 | 
			
		||||
    ui->versionLabel->setText(BuildConfig.printableVersionString());
 | 
			
		||||
 | 
			
		||||
    if (!BuildConfig.BUILD_PLATFORM.isEmpty())
 | 
			
		||||
        ui->platformLabel->setText(tr("Platform") +": " + BuildConfig.BUILD_PLATFORM);
 | 
			
		||||
    else
 | 
			
		||||
        ui->platformLabel->setVisible(false);
 | 
			
		||||
 | 
			
		||||
    if (BuildConfig.VERSION_BUILD >= 0)
 | 
			
		||||
        ui->buildNumLabel->setText(tr("Build Number") +": " + QString::number(BuildConfig.VERSION_BUILD));
 | 
			
		||||
 
 | 
			
		||||
@@ -86,6 +86,13 @@
 | 
			
		||||
      <set>Qt::AlignCenter</set>
 | 
			
		||||
     </property>
 | 
			
		||||
    </widget>
 | 
			
		||||
   </item>
 | 
			
		||||
      <item>
 | 
			
		||||
    <widget class="QLabel" name="versionLabel">
 | 
			
		||||
     <property name="alignment">
 | 
			
		||||
      <set>Qt::AlignCenter</set>
 | 
			
		||||
     </property>
 | 
			
		||||
    </widget>
 | 
			
		||||
   </item>
 | 
			
		||||
   <item>
 | 
			
		||||
    <widget class="QTabWidget" name="tabWidget">
 | 
			
		||||
@@ -151,16 +158,6 @@
 | 
			
		||||
         </property>
 | 
			
		||||
        </widget>
 | 
			
		||||
       </item>
 | 
			
		||||
       <item>
 | 
			
		||||
        <widget class="QLabel" name="versionLabel">
 | 
			
		||||
         <property name="text">
 | 
			
		||||
          <string>Version:</string>
 | 
			
		||||
         </property>
 | 
			
		||||
         <property name="alignment">
 | 
			
		||||
          <set>Qt::AlignCenter</set>
 | 
			
		||||
         </property>
 | 
			
		||||
        </widget>
 | 
			
		||||
       </item>
 | 
			
		||||
       <item>
 | 
			
		||||
        <widget class="QLabel" name="platformLabel">
 | 
			
		||||
         <property name="text">
 | 
			
		||||
 
 | 
			
		||||
@@ -250,6 +250,12 @@ bool ScreenshotsPage::eventFilter(QObject *obj, QEvent *evt)
 | 
			
		||||
        return QWidget::eventFilter(obj, evt);
 | 
			
		||||
    }
 | 
			
		||||
    QKeyEvent *keyEvent = static_cast<QKeyEvent *>(evt);
 | 
			
		||||
 | 
			
		||||
    if (keyEvent->matches(QKeySequence::Copy)) {
 | 
			
		||||
        on_actionCopy_File_s_triggered();
 | 
			
		||||
        return true;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    switch (keyEvent->key())
 | 
			
		||||
    {
 | 
			
		||||
    case Qt::Key_Delete:
 | 
			
		||||
@@ -272,6 +278,11 @@ ScreenshotsPage::~ScreenshotsPage()
 | 
			
		||||
void ScreenshotsPage::ShowContextMenu(const QPoint& pos)
 | 
			
		||||
{
 | 
			
		||||
    auto menu = ui->toolBar->createContextMenu(this, tr("Context menu"));
 | 
			
		||||
 | 
			
		||||
    if (ui->listView->selectionModel()->selectedRows().size() > 1) {
 | 
			
		||||
        menu->removeAction( ui->actionCopy_Image );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    menu->exec(ui->listView->mapToGlobal(pos));
 | 
			
		||||
    delete menu;
 | 
			
		||||
}
 | 
			
		||||
@@ -377,6 +388,42 @@ void ScreenshotsPage::on_actionUpload_triggered()
 | 
			
		||||
    m_uploadActive = false;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void ScreenshotsPage::on_actionCopy_Image_triggered()
 | 
			
		||||
{
 | 
			
		||||
    auto selection = ui->listView->selectionModel()->selectedRows();
 | 
			
		||||
    if(selection.size() < 1)
 | 
			
		||||
    {
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // You can only copy one image to the clipboard. In the case of multiple selected files, only the first one gets copied.
 | 
			
		||||
    auto item = selection[0];
 | 
			
		||||
    auto info = m_model->fileInfo(item);
 | 
			
		||||
    QImage image(info.absoluteFilePath());
 | 
			
		||||
    Q_ASSERT(!image.isNull());
 | 
			
		||||
    QApplication::clipboard()->setImage(image, QClipboard::Clipboard);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void ScreenshotsPage::on_actionCopy_File_s_triggered()
 | 
			
		||||
{
 | 
			
		||||
    auto selection = ui->listView->selectionModel()->selectedRows();
 | 
			
		||||
    if(selection.size() < 1)
 | 
			
		||||
    {
 | 
			
		||||
        // Don't do anything so we don't empty the users clipboard
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    QString buf = "";
 | 
			
		||||
    for (auto item : selection)
 | 
			
		||||
    {
 | 
			
		||||
        auto info = m_model->fileInfo(item);
 | 
			
		||||
        buf += "file:///" + info.absoluteFilePath() + "\r\n";
 | 
			
		||||
    }
 | 
			
		||||
    QMimeData* mimeData = new QMimeData();
 | 
			
		||||
    mimeData->setData("text/uri-list", buf.toLocal8Bit());
 | 
			
		||||
    QApplication::clipboard()->setMimeData(mimeData);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void ScreenshotsPage::on_actionDelete_triggered()
 | 
			
		||||
{
 | 
			
		||||
    auto mbox = CustomMessageBox::selectable(
 | 
			
		||||
 
 | 
			
		||||
@@ -73,6 +73,8 @@ protected:
 | 
			
		||||
 | 
			
		||||
private slots:
 | 
			
		||||
    void on_actionUpload_triggered();
 | 
			
		||||
    void on_actionCopy_Image_triggered();
 | 
			
		||||
    void on_actionCopy_File_s_triggered();
 | 
			
		||||
    void on_actionDelete_triggered();
 | 
			
		||||
    void on_actionRename_triggered();
 | 
			
		||||
    void on_actionView_Folder_triggered();
 | 
			
		||||
 
 | 
			
		||||
@@ -50,6 +50,8 @@
 | 
			
		||||
    <bool>false</bool>
 | 
			
		||||
   </attribute>
 | 
			
		||||
   <addaction name="actionUpload"/>
 | 
			
		||||
   <addaction name="actionCopy_Image"/>
 | 
			
		||||
   <addaction name="actionCopy_File_s"/>
 | 
			
		||||
   <addaction name="actionDelete"/>
 | 
			
		||||
   <addaction name="actionRename"/>
 | 
			
		||||
   <addaction name="actionView_Folder"/>
 | 
			
		||||
@@ -74,6 +76,22 @@
 | 
			
		||||
    <string>View Folder</string>
 | 
			
		||||
   </property>
 | 
			
		||||
  </action>
 | 
			
		||||
  <action name="actionCopy_Image">
 | 
			
		||||
   <property name="text">
 | 
			
		||||
    <string>Copy Image</string>
 | 
			
		||||
   </property>
 | 
			
		||||
   <property name="toolTip">
 | 
			
		||||
    <string>Copy Image</string>
 | 
			
		||||
   </property>
 | 
			
		||||
  </action>
 | 
			
		||||
  <action name="actionCopy_File_s">
 | 
			
		||||
   <property name="text">
 | 
			
		||||
    <string>Copy File(s)</string>
 | 
			
		||||
   </property>
 | 
			
		||||
   <property name="toolTip">
 | 
			
		||||
    <string>Copy File(s)</string>
 | 
			
		||||
   </property>
 | 
			
		||||
  </action>
 | 
			
		||||
 </widget>
 | 
			
		||||
 <customwidgets>
 | 
			
		||||
  <customwidget>
 | 
			
		||||
 
 | 
			
		||||
@@ -1,10 +0,0 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
mkdir builddir
 | 
			
		||||
cd builddir
 | 
			
		||||
cmake -DLauncher_LAYOUT=lin-system -DCMAKE_INSTALL_PREFIX=../polymc/usr ../../../
 | 
			
		||||
make -j$(nproc) install
 | 
			
		||||
cd ..
 | 
			
		||||
VERSION_PLACEHOLDER=$(git describe --tags | sed 's/-.*//')
 | 
			
		||||
cp polymc/DEBIAN/control.template polymc/DEBIAN/control
 | 
			
		||||
sed -i "2s/.*/Version: $VERSION_PLACEHOLDER/" polymc/DEBIAN/control
 | 
			
		||||
dpkg-deb --build polymc
 | 
			
		||||
@@ -1,9 +0,0 @@
 | 
			
		||||
Package: polymc
 | 
			
		||||
Version:
 | 
			
		||||
Section: games
 | 
			
		||||
Priority: optional
 | 
			
		||||
Architecture: amd64
 | 
			
		||||
Depends: libqt5core5a, libqt5network5, libqt5gui5
 | 
			
		||||
Maintainer: PolyMC Team
 | 
			
		||||
Description: PolyMC
 | 
			
		||||
  A custom launcher for Minecraft that allows you to easily manage multiple installations of Minecraft at once
 | 
			
		||||
@@ -1,7 +1,6 @@
 | 
			
		||||
{ lib
 | 
			
		||||
, mkDerivation
 | 
			
		||||
, fetchFromGitHub
 | 
			
		||||
, makeDesktopItem
 | 
			
		||||
, cmake
 | 
			
		||||
, ninja
 | 
			
		||||
, jdk8
 | 
			
		||||
@@ -73,27 +72,11 @@ mkDerivation rec {
 | 
			
		||||
    "-DLauncher_LAYOUT=lin-system"
 | 
			
		||||
  ];
 | 
			
		||||
 | 
			
		||||
  desktopItem = makeDesktopItem {
 | 
			
		||||
    name = "polymc";
 | 
			
		||||
    exec = "polymc";
 | 
			
		||||
    icon = "polymc";
 | 
			
		||||
    desktopName = "PolyMC";
 | 
			
		||||
    genericName = "Minecraft Launcher";
 | 
			
		||||
    comment = "A custom launcher for Minecraft";
 | 
			
		||||
    categories = "Game;";
 | 
			
		||||
    extraEntries = ''
 | 
			
		||||
      Keywords=game;Minecraft;
 | 
			
		||||
    '';
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  postInstall = ''
 | 
			
		||||
    install -Dm644 ../launcher/resources/multimc/scalable/launcher.svg $out/share/pixmaps/polymc.svg
 | 
			
		||||
    install -Dm644 ${desktopItem}/share/applications/polymc.desktop $out/share/applications/org.polymc.polymc.desktop
 | 
			
		||||
 | 
			
		||||
    # xorg.xrandr needed for LWJGL [2.9.2, 3) https://github.com/LWJGL/lwjgl/issues/128
 | 
			
		||||
    wrapProgram $out/bin/polymc \
 | 
			
		||||
      "''${qtWrapperArgs[@]}" \
 | 
			
		||||
      --set GAME_LIBRARY_PATH ${gameLibraryPath} \
 | 
			
		||||
      --prefix PATH : ${lib.makeBinPath [ xorg.xrandr jdk ]}
 | 
			
		||||
      --prefix PATH : ${lib.makeBinPath [ xorg.xrandr ]}
 | 
			
		||||
  '';
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,142 +0,0 @@
 | 
			
		||||
 | 
			
		||||
%global libnbtplusplus_commit       dc72a20b7efd304d12af2025223fad07b4b78464
 | 
			
		||||
%global libnbtplusplus_shortcommit  %(c=%{libnbtplusplus_commit}; echo ${c:0:7})
 | 
			
		||||
%global quazip_commit               c9ef32de19bceb58d236f5c22382698deaec69fd
 | 
			
		||||
%global quazip_shortcommit          %(c=%{quazip_commit}; echo ${c:0:7})
 | 
			
		||||
 | 
			
		||||
Name:           polymc
 | 
			
		||||
Version:        1.0.5
 | 
			
		||||
Release:        2%{?dist}
 | 
			
		||||
Summary:        Minecraft launcher with ability to manage multiple instances
 | 
			
		||||
 | 
			
		||||
#
 | 
			
		||||
# CC-BY-SA
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# launcher/resources/multimc/
 | 
			
		||||
#
 | 
			
		||||
# BSD 3-clause "New" or "Revised" License
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# application/
 | 
			
		||||
# libraries/LocalPeer/
 | 
			
		||||
# libraries/ganalytics/
 | 
			
		||||
#
 | 
			
		||||
# Boost Software License (v1.0)
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# cmake/
 | 
			
		||||
#
 | 
			
		||||
# Expat License
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# libraries/systeminfo/
 | 
			
		||||
#
 | 
			
		||||
# GNU Lesser General Public License (v2 or later)
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# libraries/rainbow
 | 
			
		||||
#
 | 
			
		||||
# GNU Lesser General Public License (v2.1 or later)
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# libraries/iconfix/
 | 
			
		||||
# libraries/quazip/
 | 
			
		||||
#
 | 
			
		||||
# GNU Lesser General Public License (v3 or later)
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# libraries/libnbtplusplus/
 | 
			
		||||
#
 | 
			
		||||
# GPL (v2)
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# libraries/pack200/
 | 
			
		||||
#
 | 
			
		||||
# ISC License
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# libraries/hoedown/
 | 
			
		||||
#
 | 
			
		||||
# zlib/libpng license
 | 
			
		||||
# ---------------------------------------
 | 
			
		||||
# libraries/quazip/quazip/unzip.h
 | 
			
		||||
# libraries/quazip/quazip/zip.h
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
License:        CC-BY-SA and ASL 2.0 and BSD and Boost and LGPLv2 and LGPLv2+ and LGPLv3+ and GPLv2 and GPLv2+ and GPLv3 and ISC and zlib
 | 
			
		||||
URL:            https://polymc.org
 | 
			
		||||
Source0:        https://github.com/PolyMC/PolyMC/archive/%{version}/%{name}-%{version}.tar.gz
 | 
			
		||||
Source1:        https://github.com/MultiMC/libnbtplusplus/archive/%{libnbtplusplus_commit}/libnbtplusplus-%{libnbtplusplus_shortcommit}.tar.gz
 | 
			
		||||
Source2:        https://github.com/PolyMC/quazip/archive/%{quazip_commit}/quazip-%{quazip_shortcommit}.tar.gz
 | 
			
		||||
 | 
			
		||||
BuildRequires:  cmake
 | 
			
		||||
BuildRequires:  desktop-file-utils
 | 
			
		||||
BuildRequires:  gcc-c++
 | 
			
		||||
 | 
			
		||||
BuildRequires:  java-devel
 | 
			
		||||
BuildRequires:  %{?suse_version:lib}qt5-qtbase-devel
 | 
			
		||||
BuildRequires:  zlib-devel
 | 
			
		||||
 | 
			
		||||
# Minecraft <  1.17
 | 
			
		||||
Recommends:     java-1.8.0-openjdk-headless
 | 
			
		||||
# Minecraft >= 1.17
 | 
			
		||||
Recommends:     java-17-openjdk-headless
 | 
			
		||||
 | 
			
		||||
%description
 | 
			
		||||
PolyMC is a free, open source launcher for Minecraft. It allows you to have
 | 
			
		||||
multiple, separate instances of Minecraft (each with their own mods, texture
 | 
			
		||||
packs, saves, etc) and helps you manage them and their associated options with
 | 
			
		||||
a simple interface.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
%prep
 | 
			
		||||
%autosetup -p1 -n PolyMC-%{version}
 | 
			
		||||
 | 
			
		||||
tar -xvf %{SOURCE1} -C libraries
 | 
			
		||||
tar -xvf %{SOURCE2} -C libraries
 | 
			
		||||
rmdir libraries/libnbtplusplus libraries/quazip
 | 
			
		||||
mv -f libraries/quazip-%{quazip_commit} libraries/quazip
 | 
			
		||||
mv -f libraries/libnbtplusplus-%{libnbtplusplus_commit} libraries/libnbtplusplus
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
%build
 | 
			
		||||
%cmake \
 | 
			
		||||
    -DCMAKE_BUILD_TYPE:STRING="RelWithDebInfo" \
 | 
			
		||||
    -DLauncher_LAYOUT:STRING="lin-system" \
 | 
			
		||||
    -DLauncher_LIBRARY_DEST_DIR:STRING="%{_libdir}/%{name}" \
 | 
			
		||||
    -DLauncher_UPDATER_BASE:STRING=""
 | 
			
		||||
 | 
			
		||||
%cmake_build
 | 
			
		||||
 | 
			
		||||
%install
 | 
			
		||||
%cmake_install
 | 
			
		||||
 | 
			
		||||
# Proper library linking
 | 
			
		||||
mkdir -p %{buildroot}%{_sysconfdir}/ld.so.conf.d/
 | 
			
		||||
echo "%{_libdir}/%{name}" > "%{buildroot}%{_sysconfdir}/ld.so.conf.d/%{name}-%{_arch}.conf"
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
%check
 | 
			
		||||
# skip tests on systems that aren't officially supported
 | 
			
		||||
%if ! 0%{?suse_version}
 | 
			
		||||
%ctest
 | 
			
		||||
desktop-file-validate %{buildroot}%{_datadir}/applications/org.polymc.polymc.desktop
 | 
			
		||||
%endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
%files
 | 
			
		||||
%license COPYING.md
 | 
			
		||||
%doc README.md changelog.md
 | 
			
		||||
%{_bindir}/%{name}
 | 
			
		||||
%{_libdir}/%{name}/*
 | 
			
		||||
%{_datadir}/%{name}/*
 | 
			
		||||
%{_datadir}/metainfo/org.polymc.PolyMC.metainfo.xml
 | 
			
		||||
%{_datadir}/icons/hicolor/scalable/apps/org.polymc.PolyMC.svg
 | 
			
		||||
%{_datadir}/applications/org.polymc.polymc.desktop
 | 
			
		||||
%config %{_sysconfdir}/ld.so.conf.d/*
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
%changelog
 | 
			
		||||
* Mon Jan 24 2022 Jan Drögehoff <sentrycraft123@gmail.com> - 1.0.5-2
 | 
			
		||||
- remove explicit dependencies, correct dependencies to work on OpenSuse
 | 
			
		||||
 | 
			
		||||
* Sun Jan 09 2022 Jan Drögehoff <sentrycraft123@gmail.com> - 1.0.5-1
 | 
			
		||||
- Update to 1.0.5
 | 
			
		||||
 | 
			
		||||
* Sun Jan 09 2022 Jan Drögehoff <sentrycraft123@gmail.com> - 1.0.4-2
 | 
			
		||||
- rework spec
 | 
			
		||||
 | 
			
		||||
* Fri Jan 7 2022 getchoo <getchoo at tuta dot io> - 1.0.4-1
 | 
			
		||||
- Initial polymc spec
 | 
			
		||||
@@ -1,6 +1,6 @@
 | 
			
		||||
set(Launcher_CommonName "PolyMC")
 | 
			
		||||
 | 
			
		||||
set(Launcher_Copyright "PolyMC Contributors" PARENT_SCOPE)
 | 
			
		||||
set(Launcher_Copyright "PolyMC Contributors\\n© 2012-2021 MultiMC Contributors" PARENT_SCOPE)
 | 
			
		||||
set(Launcher_Domain "polymc.org" PARENT_SCOPE)
 | 
			
		||||
set(Launcher_Name "${Launcher_CommonName}" PARENT_SCOPE)
 | 
			
		||||
set(Launcher_DisplayName "${Launcher_CommonName}" PARENT_SCOPE)
 | 
			
		||||
 
 | 
			
		||||
@@ -1,6 +1,6 @@
 | 
			
		||||
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
 | 
			
		||||
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0" xmlns:asmv3="urn:schemas-microsoft-com:asm.v3">
 | 
			
		||||
  <assemblyIdentity name="PolyMC.Application.5" type="win32" version="5.0.0.0" />
 | 
			
		||||
  <assemblyIdentity name="PolyMC.Application.1" type="win32" version="1.0.0.0" />
 | 
			
		||||
  <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
 | 
			
		||||
    <security>
 | 
			
		||||
      <requestedPrivileges>
 | 
			
		||||
 
 | 
			
		||||
@@ -16,10 +16,10 @@ BEGIN
 | 
			
		||||
                BLOCK "000004b0"
 | 
			
		||||
                BEGIN
 | 
			
		||||
                        VALUE "CompanyName", "MultiMC & PolyMC Contributors"
 | 
			
		||||
                        VALUE "FileDescription", "A Minecraft Launcher"
 | 
			
		||||
                        VALUE "FileDescription", "PolyMC"
 | 
			
		||||
                        VALUE "FileVersion", "1.0.0.0"
 | 
			
		||||
                        VALUE "ProductName", "PolyMC"
 | 
			
		||||
                        VALUE "ProductVersion", "5"
 | 
			
		||||
                        VALUE "ProductVersion", "1"
 | 
			
		||||
                END
 | 
			
		||||
        END
 | 
			
		||||
        BLOCK "VarFileInfo"
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user