diff options
author | Marek Szuba <marecki@gentoo.org> | 2020-11-29 20:20:59 +0100 |
---|---|---|
committer | Marek Szuba <marecki@gentoo.org> | 2020-11-29 20:41:58 +0100 |
commit | 1e16f00ebe854302532ed3d504e33062bd17afe8 (patch) | |
tree | 6aa80c7e83937ed965ec52306eb853fb81b147b7 /sci-astronomy | |
parent | sci-libs/plplot: migrate to lua-single.eclass (diff) | |
download | gentoo-1e16f00ebe854302532ed3d504e33062bd17afe8.tar.gz gentoo-1e16f00ebe854302532ed3d504e33062bd17afe8.tar.bz2 gentoo-1e16f00ebe854302532ed3d504e33062bd17afe8.zip |
sci-astronomy/celestia: migrate to lua-single.eclass
Both the release and the live ebuild.
Closes: https://bugs.gentoo.org/752828
Signed-off-by: Marek Szuba <marecki@gentoo.org>
Diffstat (limited to 'sci-astronomy')
3 files changed, 146 insertions, 3 deletions
diff --git a/sci-astronomy/celestia/celestia-1.7.0_pre20200316-r100.ebuild b/sci-astronomy/celestia/celestia-1.7.0_pre20200316-r100.ebuild new file mode 100644 index 000000000000..dd539877e827 --- /dev/null +++ b/sci-astronomy/celestia/celestia-1.7.0_pre20200316-r100.ebuild @@ -0,0 +1,119 @@ +# Copyright 1999-2020 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +LUA_COMPAT=( lua5-{1..3} luajit ) + +inherit desktop flag-o-matic lua-single xdg cmake + +if [[ ${PV} == *9999 ]] ; then + EGIT_REPO_URI="https://github.com/CelestiaProject/Celestia.git" + inherit git-r3 +else + if [[ ${PV} == *_p* ]] ; then + COMMIT_ID="df508a0c597a3d96c1c039fa4a973e294021cfba" + SRC_URI="https://github.com/${PN^}Project/${PN^}/archive/${COMMIT_ID}.tar.gz -> ${P}.tar.gz" + S="${WORKDIR}/${PN^}-${COMMIT_ID}" + KEYWORDS="~amd64 ~x86" + else + SRC_URI="https://github.com/${PN^}Project/${PN^}/archive/${PV/_/-}.tar.gz -> ${P}.tar.gz" + KEYWORDS="~amd64 ~ppc ~ppc64 ~x86 ~amd64-linux ~x86-linux" + fi +fi + +DESCRIPTION="OpenGL 3D space simulator" +HOMEPAGE="https://celestia.space" + +LICENSE="GPL-2+" +SLOT="0" +IUSE="glut lua nls +qt5 theora" +REQUIRED_USE="|| ( glut qt5 ) + lua? ( ${LUA_REQUIRED_USE} )" + +BDEPEND=" + dev-cpp/eigen + virtual/pkgconfig + nls? ( sys-devel/gettext ) +" +DEPEND=" + dev-libs/libfmt:= + media-libs/glew:0= + media-libs/libpng:0= + sys-libs/zlib:= + virtual/glu + virtual/jpeg:0 + virtual/opengl + glut? ( media-libs/freeglut ) + lua? ( ${LUA_DEPS} ) + qt5? ( + dev-qt/qtcore:5 + dev-qt/qtgui:5 + dev-qt/qtwidgets:5 + ) + theora? ( + media-libs/libogg + media-libs/libtheora + ) +" +RDEPEND="${DEPEND}" + +PATCHES=( + # make better desktop files + "${FILESDIR}"/${PN}-1.5.0-desktop.patch + # add a ~/.celestia for extra directories + "${FILESDIR}"/${PN}-1.6.99-cfg.patch + # allow forcing CMake to look for a specific Lua version instead of the newest branch installed + "${FILESDIR}"/${PN}-1.7.0-cmake_lua_version.patch +) + +src_prepare() { + cmake_src_prepare + + ### This version of Celestia has a bug in the font rendering and + ### requires -fsigned-char. We should be able to force this flag + ### on all architectures. See bug #316573. + append-flags "-fsigned-char" +} + +src_configure() { + local mycmakeargs=( + -DENABLE_CELX="$(usex lua)" + -DENABLE_NLS="$(usex nls)" + -DENABLE_GLUT="$(usex glut)" + -DENABLE_GTK=OFF + -DENABLE_QT="$(usex qt5)" + -DENABLE_WIN=OFF + -DENABLE_THEORA="$(usex theora)" + ) + # Upstream always looks for LuaJIT first unless stopped, and we only need + # the version specification when linking against PUC Lua + if use lua && ! use lua_single_target_luajit; then + mycmakeargs+=( + -DCMAKE_DISABLE_FIND_PACKAGE_LuaJIT=ON + -DLUA_VERSION=$(lua_get_version) + ) + fi + cmake_src_configure +} + +src_install() { + cmake_src_install + + local size + for size in 16 22 32 48 ; do + newicon -s ${size} "${S}"/src/celestia/kde/data/hi${size}-app-${PN}.png ${PN}.png + done + newicon -s 128 "${S}"/src/celestia/gtk/data/${PN}-logo.png ${PN}.png + doicon -s scalable "${S}"/src/celestia/gtk/data/${PN}.svg + + use glut && domenu ${PN}.desktop + if use qt5 ; then + sed \ + -e "/^Name/s@\$@ (qt5 interface)@" \ + -e "/^Exec/s@${PN}@${PN}-qt@" \ + ${PN}.desktop > "${T}"/${PN}-qt5.desktop || die + domenu "${T}"/${PN}-qt5.desktop + fi + dodoc AUTHORS README TRANSLATORS *.txt +} diff --git a/sci-astronomy/celestia/celestia-9999.ebuild b/sci-astronomy/celestia/celestia-9999.ebuild index c38a6c82ab31..dd539877e827 100644 --- a/sci-astronomy/celestia/celestia-9999.ebuild +++ b/sci-astronomy/celestia/celestia-9999.ebuild @@ -3,7 +3,9 @@ EAPI=7 -inherit desktop flag-o-matic xdg cmake +LUA_COMPAT=( lua5-{1..3} luajit ) + +inherit desktop flag-o-matic lua-single xdg cmake if [[ ${PV} == *9999 ]] ; then EGIT_REPO_URI="https://github.com/CelestiaProject/Celestia.git" @@ -26,7 +28,8 @@ HOMEPAGE="https://celestia.space" LICENSE="GPL-2+" SLOT="0" IUSE="glut lua nls +qt5 theora" -REQUIRED_USE="|| ( glut qt5 )" +REQUIRED_USE="|| ( glut qt5 ) + lua? ( ${LUA_REQUIRED_USE} )" BDEPEND=" dev-cpp/eigen @@ -42,7 +45,7 @@ DEPEND=" virtual/jpeg:0 virtual/opengl glut? ( media-libs/freeglut ) - lua? ( dev-lang/lua:* ) + lua? ( ${LUA_DEPS} ) qt5? ( dev-qt/qtcore:5 dev-qt/qtgui:5 @@ -60,6 +63,8 @@ PATCHES=( "${FILESDIR}"/${PN}-1.5.0-desktop.patch # add a ~/.celestia for extra directories "${FILESDIR}"/${PN}-1.6.99-cfg.patch + # allow forcing CMake to look for a specific Lua version instead of the newest branch installed + "${FILESDIR}"/${PN}-1.7.0-cmake_lua_version.patch ) src_prepare() { @@ -81,6 +86,14 @@ src_configure() { -DENABLE_WIN=OFF -DENABLE_THEORA="$(usex theora)" ) + # Upstream always looks for LuaJIT first unless stopped, and we only need + # the version specification when linking against PUC Lua + if use lua && ! use lua_single_target_luajit; then + mycmakeargs+=( + -DCMAKE_DISABLE_FIND_PACKAGE_LuaJIT=ON + -DLUA_VERSION=$(lua_get_version) + ) + fi cmake_src_configure } diff --git a/sci-astronomy/celestia/files/celestia-1.7.0-cmake_lua_version.patch b/sci-astronomy/celestia/files/celestia-1.7.0-cmake_lua_version.patch new file mode 100644 index 000000000000..80fba5d447a4 --- /dev/null +++ b/sci-astronomy/celestia/files/celestia-1.7.0-cmake_lua_version.patch @@ -0,0 +1,11 @@ +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -179,7 +179,7 @@ + + find_package(LuaJIT) + if(NOT LUAJIT_FOUND) +- find_package(Lua REQUIRED) ++ find_package(Lua ${LUA_VERSION} EXACT REQUIRED) + endif() + include_directories(${LUA_INCLUDE_DIR}) + link_libraries(${LUA_LIBRARIES}) |