commit:     4b3e0246ce71b8e29fbf73f6280d5cff860d258f
Author:     Thiago Donato Ferreira <flowlnlnln <AT> gmail <DOT> com>
AuthorDate: Wed Apr 20 20:28:01 2022 +0000
Commit:     Andrew Ammerlaan <andrewammerlaan <AT> gentoo <DOT> org>
CommitDate: Fri Apr 22 17:23:26 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=4b3e0246

games-action/polymc: adds version 1.2.1

Package-Manager: Portage-3.0.30, Repoman-3.0.3
Signed-off-by: Thiago Donato Ferreira <flowlnlnln <AT> gmail.com>
Signed-off-by: Andrew Ammerlaan <andrewammerlaan <AT> gentoo.org>

 games-action/polymc/Manifest                       |  1 +
 games-action/polymc/files/polymc-iconfix.patch     | 29 +++++++++++++
 games-action/polymc/metadata.xml                   |  3 ++
 .../{polymc-9999.ebuild => polymc-1.2.1.ebuild}    | 47 ++++++++++++----------
 games-action/polymc/polymc-9999.ebuild             | 47 ++++++++++++----------
 5 files changed, 85 insertions(+), 42 deletions(-)

diff --git a/games-action/polymc/Manifest b/games-action/polymc/Manifest
index b44203e704b5..98093b7fbfd2 100644
--- a/games-action/polymc/Manifest
+++ b/games-action/polymc/Manifest
@@ -1 +1,2 @@
 DIST polymc-1.1.1.tar.gz 5116164 BLAKE2B 
ca251cac3c8ea21de8a59297a0e637dac078d751476fec5fe86696df270c63ff079779056f016fa656506ea205bb7ace50ab6e0df190ffca14e43297b92292af
 SHA512 
db32479e9e8a92ec61292c97281673b3084e1085d29b764214834de872d9eddf2ed1d2e383bcd79197e0c9321eec025af652b12c863596ff6abb0f5fba9a7af5
+DIST polymc-1.2.1.tar.gz 5157547 BLAKE2B 
92a65cd1303b4f2dce299d2a40824de54babd47bd21a894827e7a0e94276551fc747873ba44e63ac13b3ca46649c3d5280ec9eecd92eb63678f8cbc3c27e4f69
 SHA512 
193415b552dbc3f540f481c22e36c2b9d0604757cb12283ec0fc2979246757937648b76821818f0742b3f5201ed7af8e535dff9ef3d5efcb22f7a1ddf9ee67d2

diff --git a/games-action/polymc/files/polymc-iconfix.patch 
b/games-action/polymc/files/polymc-iconfix.patch
new file mode 100644
index 000000000000..01477e559ff6
--- /dev/null
+++ b/games-action/polymc/files/polymc-iconfix.patch
@@ -0,0 +1,29 @@
+From 8f494636afb9a9b9c0619b256252d3a9dcdbab72 Mon Sep 17 00:00:00 2001
+From: flow <[email protected]>
+Date: Thu, 21 Apr 2022 06:38:18 -0300
+Subject: [PATCH] fix: Build iconfix as static library
+
+Otherwise the launcher is unable to find the iconfix .so, and so the
+launcher doesn't run.
+
+Signed-off-by: Thiago Donato Ferreira <[email protected]>
+---
+ libraries/iconfix/CMakeLists.txt | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/libraries/iconfix/CMakeLists.txt 
b/libraries/iconfix/CMakeLists.txt
+index 08441203..97a59129 100644
+--- a/libraries/iconfix/CMakeLists.txt
++++ b/libraries/iconfix/CMakeLists.txt
+@@ -12,7 +12,7 @@ internal/qiconloader.cpp
+ internal/qiconloader_p.h
+ )
+ 
+-add_library(Launcher_iconfix ${ICONFIX_SOURCES})
++add_library(Launcher_iconfix STATIC ${ICONFIX_SOURCES})
+ target_include_directories(Launcher_iconfix PUBLIC 
${CMAKE_CURRENT_SOURCE_DIR} "${CMAKE_CURRENT_BINARY_DIR}" )
+ 
+ target_link_libraries(Launcher_iconfix Qt5::Core Qt5::Widgets)
+-- 
+2.35.1
+

diff --git a/games-action/polymc/metadata.xml b/games-action/polymc/metadata.xml
index 78a705414ef3..f704149126f6 100644
--- a/games-action/polymc/metadata.xml
+++ b/games-action/polymc/metadata.xml
@@ -23,4 +23,7 @@
     <remote-id type="github">PolyMC/PolyMC</remote-id>
   </upstream>
   <longdescription>PolyMC is a multi-instance Minecraft launcher focused on 
user freedom, redistributability, and simplicity.</longdescription>
+  <use>
+    <flag name="lto">Enable link-time optimization</flag>
+  </use>
 </pkgmetadata>

diff --git a/games-action/polymc/polymc-9999.ebuild 
b/games-action/polymc/polymc-1.2.1.ebuild
similarity index 80%
copy from games-action/polymc/polymc-9999.ebuild
copy to games-action/polymc/polymc-1.2.1.ebuild
index d036cb15c635..d488a775fb9a 100644
--- a/games-action/polymc/polymc-9999.ebuild
+++ b/games-action/polymc/polymc-1.2.1.ebuild
@@ -13,12 +13,10 @@ if [[ ${PV} == 9999 ]]; then
 
        EGIT_REPO_URI="
                https://github.com/PolyMC/PolyMC
-               https://github.com/MultiMC/libnbtplusplus
-               https://github.com/stachenov/quazip
+               https://github.com/PolyMC/libnbtplusplus
        "
 
-       # Include all submodules
-       EGIT_SUBMODULES=( '*' )
+       EGIT_SUBMODULES=( 'depends/libnbtplusplus' )
 else
        MY_PN="PolyMC"
 
@@ -36,13 +34,15 @@ fi
 # Apache-2.0 for MultiMC (PolyMC is forked from it)
 # GPL-3 for PolyMC
 # LGPL-3 for libnbtplusplus
-# LGPL-2.1 with linking exception for Quazip
 # See the rest of PolyMC's libraries at 
https://github.com/PolyMC/PolyMC/tree/develop/libraries
-LICENSE="Apache-2.0 Boost-1.0 BSD BSD-2 GPL-2+ GPL-3 LGPL-3 
LGPL-2.1-with-linking-exception OFL-1.1 MIT"
+LICENSE="Apache-2.0 Boost-1.0 BSD BSD-2 GPL-2+ GPL-3 LGPL-3 OFL-1.1 MIT"
 
 SLOT="0"
 
-IUSE="debug"
+IUSE="debug lto"
+REQUIRED_USE="
+       lto? ( !debug )
+"
 
 MIN_QT="5.6.0"
 
@@ -56,43 +56,48 @@ QT_DEPS="
        >=dev-qt/qtxml-${MIN_QT}:5
 "
 
-DEPEND="
+# Required at both build-time and run-time
+COMMON_DEPENDS="
        ${QT_DEPS}
-       media-libs/libglvnd
+       >=dev-libs/quazip-1.3:=
        sys-libs/zlib
+"
+
+DEPEND="
+       ${COMMON_DEPENDS}
+       media-libs/libglvnd
        >=virtual/jdk-1.8.0:*
 "
 
 # At run-time we don't depend on JDK, only JRE
 # And we need more than just the GL headers
 RDEPEND="
-       ${QT_DEPS}
-       sys-libs/zlib
+       ${COMMON_DEPENDS}
        >=virtual/jre-1.8.0:*
        virtual/opengl
 "
 
+PATCHES=( "${FILESDIR}/${PN}-iconfix.patch" )
+
 src_prepare() {
        cmake_src_prepare
 }
 
 src_configure(){
-       if use debug; then
-               CMAKE_BUILD_TYPE=Debug
-       else
-               # Prepare for LTO in 1.2.0 (?)
-               # See https://github.com/PolyMC/PolyMC/pull/333
-               CMAKE_BUILD_TYPE=Release
-       fi
-
        local mycmakeargs=(
-               # Do a system install
-               -DLauncher_PORTABLE=0
                -DCMAKE_INSTALL_PREFIX="/usr"
                # Resulting binary is named polymc
                -DLauncher_APP_BINARY_NAME="${PN}"
+
+               -DENABLE_LTO=$(usex lto)
        )
 
+       if use debug; then
+               CMAKE_BUILD_TYPE=Debug
+       else
+               CMAKE_BUILD_TYPE=Release
+       fi
+
        cmake_src_configure
 }
 

diff --git a/games-action/polymc/polymc-9999.ebuild 
b/games-action/polymc/polymc-9999.ebuild
index d036cb15c635..d488a775fb9a 100644
--- a/games-action/polymc/polymc-9999.ebuild
+++ b/games-action/polymc/polymc-9999.ebuild
@@ -13,12 +13,10 @@ if [[ ${PV} == 9999 ]]; then
 
        EGIT_REPO_URI="
                https://github.com/PolyMC/PolyMC
-               https://github.com/MultiMC/libnbtplusplus
-               https://github.com/stachenov/quazip
+               https://github.com/PolyMC/libnbtplusplus
        "
 
-       # Include all submodules
-       EGIT_SUBMODULES=( '*' )
+       EGIT_SUBMODULES=( 'depends/libnbtplusplus' )
 else
        MY_PN="PolyMC"
 
@@ -36,13 +34,15 @@ fi
 # Apache-2.0 for MultiMC (PolyMC is forked from it)
 # GPL-3 for PolyMC
 # LGPL-3 for libnbtplusplus
-# LGPL-2.1 with linking exception for Quazip
 # See the rest of PolyMC's libraries at 
https://github.com/PolyMC/PolyMC/tree/develop/libraries
-LICENSE="Apache-2.0 Boost-1.0 BSD BSD-2 GPL-2+ GPL-3 LGPL-3 
LGPL-2.1-with-linking-exception OFL-1.1 MIT"
+LICENSE="Apache-2.0 Boost-1.0 BSD BSD-2 GPL-2+ GPL-3 LGPL-3 OFL-1.1 MIT"
 
 SLOT="0"
 
-IUSE="debug"
+IUSE="debug lto"
+REQUIRED_USE="
+       lto? ( !debug )
+"
 
 MIN_QT="5.6.0"
 
@@ -56,43 +56,48 @@ QT_DEPS="
        >=dev-qt/qtxml-${MIN_QT}:5
 "
 
-DEPEND="
+# Required at both build-time and run-time
+COMMON_DEPENDS="
        ${QT_DEPS}
-       media-libs/libglvnd
+       >=dev-libs/quazip-1.3:=
        sys-libs/zlib
+"
+
+DEPEND="
+       ${COMMON_DEPENDS}
+       media-libs/libglvnd
        >=virtual/jdk-1.8.0:*
 "
 
 # At run-time we don't depend on JDK, only JRE
 # And we need more than just the GL headers
 RDEPEND="
-       ${QT_DEPS}
-       sys-libs/zlib
+       ${COMMON_DEPENDS}
        >=virtual/jre-1.8.0:*
        virtual/opengl
 "
 
+PATCHES=( "${FILESDIR}/${PN}-iconfix.patch" )
+
 src_prepare() {
        cmake_src_prepare
 }
 
 src_configure(){
-       if use debug; then
-               CMAKE_BUILD_TYPE=Debug
-       else
-               # Prepare for LTO in 1.2.0 (?)
-               # See https://github.com/PolyMC/PolyMC/pull/333
-               CMAKE_BUILD_TYPE=Release
-       fi
-
        local mycmakeargs=(
-               # Do a system install
-               -DLauncher_PORTABLE=0
                -DCMAKE_INSTALL_PREFIX="/usr"
                # Resulting binary is named polymc
                -DLauncher_APP_BINARY_NAME="${PN}"
+
+               -DENABLE_LTO=$(usex lto)
        )
 
+       if use debug; then
+               CMAKE_BUILD_TYPE=Debug
+       else
+               CMAKE_BUILD_TYPE=Release
+       fi
+
        cmake_src_configure
 }
 

Reply via email to