diff options
author | Azamat H. Hackimov <azamat.hackimov@gmail.com> | 2021-01-05 00:39:52 +0300 |
---|---|---|
committer | Joonas Niilola <juippis@gentoo.org> | 2021-01-05 10:14:04 +0200 |
commit | eae76af34331d120f789cac36d5dc8e912e2f016 (patch) | |
tree | 1b700357d474c06b1a048d89846908c96d99acc9 /dev-util/clion | |
parent | x11-misc/urxvt-tabbedex: clean old 20.09 (diff) | |
download | gentoo-eae76af34331d120f789cac36d5dc8e912e2f016.tar.gz gentoo-eae76af34331d120f789cac36d5dc8e912e2f016.tar.bz2 gentoo-eae76af34331d120f789cac36d5dc8e912e2f016.zip |
dev-util/clion: fix #763531 and #763582
Added missed dependencies and fixed crash on opening Markdown files.
Closes: https://bugs.gentoo.org/763531
Closes: https://bugs.gentoo.org/763582
Package-Manager: Portage-3.0.12, Repoman-3.0.2
Signed-off-by: Azamat H. Hackimov <azamat.hackimov@gmail.com>
Signed-off-by: Joonas Niilola <juippis@gentoo.org>
Diffstat (limited to 'dev-util/clion')
-rw-r--r-- | dev-util/clion/clion-2020.3.1-r1.ebuild | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/dev-util/clion/clion-2020.3.1-r1.ebuild b/dev-util/clion/clion-2020.3.1-r1.ebuild new file mode 100644 index 000000000000..a78766675052 --- /dev/null +++ b/dev-util/clion/clion-2020.3.1-r1.ebuild @@ -0,0 +1,105 @@ +# Copyright 1999-2021 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit desktop wrapper + +DESCRIPTION="A complete toolset for C and C++ development" +HOMEPAGE="https://www.jetbrains.com/clion" +SRC_URI="https://download.jetbrains.com/cpp/CLion-${PV}.tar.gz" + +LICENSE="|| ( IDEA IDEA_Academic IDEA_Classroom IDEA_OpenSource IDEA_Personal ) + Apache-1.1 Apache-2.0 BSD BSD-2 CC0-1.0 CDDL-1.1 CPL-0.5 CPL-1.0 + EPL-1.0 EPL-2.0 GPL-2 GPL-2-with-classpath-exception GPL-3 ISC JDOM + LGPL-2.1+ LGPL-3 MIT MPL-1.0 MPL-1.1 OFL public-domain PSF-2 UoI-NCSA ZLIB" +SLOT="0" +KEYWORDS="~amd64 ~x86" +RESTRICT="bindist mirror splitdebug" + +BDEPEND="dev-util/patchelf" + +# RDEPENDS may cause false positives in repoman. +# clion requires cmake and gdb at runtime to build and debug C/C++ projects +RDEPEND=" + app-accessibility/at-spi2-atk + app-accessibility/at-spi2-core + dev-libs/atk + dev-libs/libdbusmenu + dev-libs/nss + dev-util/cmake + media-libs/alsa-lib + media-libs/freetype + media-libs/mesa + net-print/cups + sys-devel/gdb + x11-libs/libdrm + x11-libs/libXcomposite + x11-libs/libXcursor + x11-libs/libXdamage + x11-libs/libXi + x11-libs/libXScrnSaver + x11-libs/libXrandr + x11-libs/libXtst + x11-libs/libXxf86vm + x11-libs/pango" + +QA_PREBUILT="opt/${P}/*" + +src_prepare() { + default + + local remove_me=( + bin/gdb/linux + bin/lldb/linux + bin/cmake + license/CMake* + lib/pty4j-native/linux/aarch64 + lib/pty4j-native/linux/mips64el + lib/pty4j-native/linux/ppc64le + ) + + use amd64 || remove_me+=( bin/fsnotifier64 lib/pty4j-native/linux/x86_64) + use x86 || remove_me+=( bin/fsnotifier lib/pty4j-native/linux/x86) + + rm -rv "${remove_me[@]}" || die + + for file in "jbr/lib/"/{libjcef.so,jcef_helper} + do + if [[ -f "${file}" ]]; then + patchelf --set-rpath '$ORIGIN' ${file} || die + fi + done +} + +src_install() { + local dir="/opt/${P}" + + insinto "${dir}" + doins -r * + fperms 755 "${dir}"/bin/{clion.sh,clang/linux/clang{d,-tidy}} + + if use amd64; then + fperms 755 "${dir}"/bin/fsnotifier64 + fi + if use arm; then + fperms 755 "${dir}"/bin/fsnotifier-arm + fi + if use x86; then + fperms 755 "${dir}"/bin/fsnotifier + fi + + if [[ -d jbr ]]; then + fperms 755 "${dir}"/jbr/bin/{jaotc,java,javac,jdb,jjs,jrunscript,keytool,pack200,rmid,rmiregistry,serialver,unpack200} + # Fix #763582 + fperms 755 "${dir}"/jbr/lib/{chrome-sandbox,jcef_helper,jexec,jspawnhelper} + fi + + make_wrapper "${PN}" "${dir}/bin/${PN}.sh" + newicon "bin/${PN}.svg" "${PN}.svg" + make_desktop_entry "${PN}" "clion" "${PN}" "Development;IDE;" + + # recommended by: https://confluence.jetbrains.com/display/IDEADEV/Inotify+Watches+Limit + dodir /usr/lib/sysctl.d/ + echo "fs.inotify.max_user_watches = 524288" > "${D}/usr/lib/sysctl.d/30-clion-inotify-watches.conf" || die +} |