commit:     ea4099d6f7701f83ab412dde3022c272b404cf67
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Mon Sep 18 03:31:45 2023 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Mon Sep 18 03:32:47 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ea4099d6

x11-terms/kitty: add 0.30.0

Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>

 x11-terms/kitty/Manifest            |   3 +
 x11-terms/kitty/kitty-0.30.0.ebuild | 170 ++++++++++++++++++++++++++++++++++++
 2 files changed, 173 insertions(+)

diff --git a/x11-terms/kitty/Manifest b/x11-terms/kitty/Manifest
index 351678a4db0f..d0caf5e430be 100644
--- a/x11-terms/kitty/Manifest
+++ b/x11-terms/kitty/Manifest
@@ -1,3 +1,6 @@
 DIST kitty-0.29.2-vendor.tar.xz 1377044 BLAKE2B 
f342c7be9bec556b9b16b0e2032ac1ec80296f791a0c55d8b0831d8e148f05e2a7e1ae7c30090c70e7da7e6ca489e5b9b013f59d35af708eff073899f345b7ac
 SHA512 
c0e2c55b0c7ca6ad435092c1267ed1164e042cc61ebf80b298477703607ac7611170cac1918d3703669e2363756e2d805d490018e66cc5b97efecbd0e516298e
 DIST kitty-0.29.2.tar.xz 7809388 BLAKE2B 
6928d79a6cc0eaac4d92ce3babbeb0a42bf1dbc92b775386b521c8399352ba77ab9828f8cfd9f40c3e4f29ae98852b6f3cb9ee1f412474ba2ef655c18d2c294d
 SHA512 
a34d8b5bc817dd9d27f1afa190856d916576f52458ede2253655b294358b6b89b1f103acb90d8d66a494b346420ddedc9fcf1a3399f561268ded82e7b1954b06
 DIST kitty-0.29.2.tar.xz.sig 566 BLAKE2B 
52fe246f3c4a74dfb62ed34b12b639858eb91aef02c872e472e1a1272268f6da2027b325dc29e260346c76bfbaa206486c6ce2f44f259d33f1ca3a0fd82150ff
 SHA512 
ffcc63904a09148ddbf2eb761686942d1de3ce2c8c7c93b8a1c59ef704e0886bce972dd162e88de65912682233b21398970685cebbda785f7c4215f02ddbf9fd
+DIST kitty-0.30.0-vendor.tar.xz 1412860 BLAKE2B 
71ca2f2981bab51af5d6baa85485b8c5f91d721f19039c129ec1b10d52b50667a7ee593798db5bc85c0b7e835ce2c1a1eb53d6b9a0b0413b7e7dc77ac4a0713b
 SHA512 
a1649f626cd52472e87d1e4570331f21db6875c61c991e6535e6e81404dc069e52e8ba438ed956da8f1a51bcc9bdb71a541c8e0a6b8cb7678e4bb839bda85402
+DIST kitty-0.30.0.tar.xz 7842724 BLAKE2B 
a656fbb74a92a6b834fe8d06a89eaa1240044b132d64d7ad9eb429c71fd60e564ed963638bb9ba4e99d3e31c2ac594543e702b298a0b53aea1050e3b2e19ae9a
 SHA512 
05438de8752057d7c419da41621b4d8fcfa6e7189530efc32c7c8a0bf2e6dae0332dd1b661206f9dea5bf374713e86ea5e69f640b0e73fe617f528bc963a8792
+DIST kitty-0.30.0.tar.xz.sig 566 BLAKE2B 
bb11c31561fb97ae229cd4eaae787a91cc9937f85bf98a4413476c9540334ff85a94e67a7699d04e326a6e067645e2c831761722d8780ab67c3cc66745bdabca
 SHA512 
117c83e2b2190d6095a4e19386e897c03776ebb11509a23564db7f746dfd31e5ad9865bf88111b3bacf21547385ab08e33d7234027c50ab366f8a69105df8bb4

diff --git a/x11-terms/kitty/kitty-0.30.0.ebuild 
b/x11-terms/kitty/kitty-0.30.0.ebuild
new file mode 100644
index 000000000000..99e44b505ebd
--- /dev/null
+++ b/x11-terms/kitty/kitty-0.30.0.ebuild
@@ -0,0 +1,170 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{10..12} )
+inherit edo optfeature multiprocessing python-single-r1 toolchain-funcs xdg
+
+if [[ ${PV} == 9999 ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/kovidgoyal/kitty.git";
+else
+       inherit verify-sig
+       SRC_URI="
+               
https://github.com/kovidgoyal/kitty/releases/download/v${PV}/${P}.tar.xz
+               https://dev.gentoo.org/~ionen/distfiles/${P}-vendor.tar.xz
+               verify-sig? ( 
https://github.com/kovidgoyal/kitty/releases/download/v${PV}/${P}.tar.xz.sig )
+       "
+       
VERIFY_SIG_OPENPGP_KEY_PATH="${BROOT}/usr/share/openpgp-keys/kovidgoyal.gpg"
+       KEYWORDS="~amd64 ~arm64 ~ppc64 ~riscv ~x86"
+fi
+
+DESCRIPTION="Fast, feature-rich, GPU-based terminal"
+HOMEPAGE="https://sw.kovidgoyal.net/kitty/";
+
+LICENSE="GPL-3 ZLIB"
+LICENSE+=" Apache-2.0 BSD BSD-2 MIT MPL-2.0 " # go
+SLOT="0"
+IUSE="+X test wayland"
+REQUIRED_USE="
+       ${PYTHON_REQUIRED_USE}
+       || ( X wayland )
+       test? ( X wayland )
+"
+RESTRICT="!test? ( test )"
+
+# dlopen: fontconfig,libglvnd
+RDEPEND="
+       ${PYTHON_DEPS}
+       dev-libs/openssl:=
+       dev-libs/xxhash
+       media-libs/fontconfig
+       media-libs/harfbuzz:=[truetype]
+       media-libs/lcms:2
+       media-libs/libglvnd[X?]
+       media-libs/libpng:=
+       sys-apps/dbus
+       sys-libs/zlib:=
+       x11-libs/libxkbcommon[X?]
+       x11-misc/xkeyboard-config
+       ~x11-terms/kitty-shell-integration-${PV}
+       ~x11-terms/kitty-terminfo-${PV}
+       X? ( x11-libs/libX11 )
+       wayland? ( dev-libs/wayland )
+       !sci-mathematics/kissat
+"
+DEPEND="
+       ${RDEPEND}
+       X? (
+               x11-base/xorg-proto
+               x11-libs/libXcursor
+               x11-libs/libXi
+               x11-libs/libXinerama
+               x11-libs/libXrandr
+       )
+       wayland? ( dev-libs/wayland-protocols )
+"
+BDEPEND="
+       ${PYTHON_DEPS}
+       >=dev-lang/go-1.21
+       sys-libs/ncurses
+       virtual/pkgconfig
+       test? ( $(python_gen_cond_dep 'dev-python/pillow[${PYTHON_USEDEP}]') )
+       wayland? ( dev-util/wayland-scanner )
+"
+[[ ${PV} == 9999 ]] || BDEPEND+=" verify-sig? ( 
sec-keys/openpgp-keys-kovidgoyal )"
+
+QA_FLAGS_IGNORED="usr/bin/kitten" # written in Go
+
+src_unpack() {
+       if [[ ${PV} == 9999 ]]; then
+               git-r3_src_unpack
+               cd "${S}" || die
+               edo go mod vendor
+       else
+               use verify-sig &&
+                       verify-sig_verify_detached 
"${DISTDIR}"/${P}.tar.xz{,.sig}
+               default
+       fi
+}
+
+src_prepare() {
+       default
+
+       # sed unfortunately feels easier on maintenance than patches here
+       local sedargs=(
+               -e "/num_workers =/s/=.*/= $(makeopts_jobs)/"
+               -e "s/cflags.append.*-O3.*/pass/" -e 's/-O3//'
+               -e "s/ld_flags.append('-[sw]')/pass/"
+       )
+
+       # kitty is often popular on wayland-only setups, try to allow this
+       use !X && sedargs+=( -e '/gl_libs =/s/=.*/= []/' ) #857918
+       use !X || use !wayland &&
+               sedargs+=( -e "s/'x11 wayland'/'$(usex X x11 wayland)'/" )
+
+       # skip docs for live version, missing dependencies
+       [[ ${PV} == 9999 ]] && sedargs+=( -e '/exists.*_build/,/docs(ddir)/d' )
+
+       sed -i setup.py "${sedargs[@]}" || die
+
+       local skiptests=(
+               # relies on 'who' command which doesn't detect users with 
pid-sandbox
+               kitty_tests/utmp.py
+               # may fail/hang depending on environment and shell 
initialization
+               kitty_tests/{shell_integration,ssh}.py
+               # relies on /proc/self/fd and gets confused when ran from here
+               tools/utils/tpmfile_test.go
+       )
+       use !test || rm "${skiptests[@]}" || die
+}
+
+src_compile() {
+       tc-export CC
+       local -x GOFLAGS="-p=$(makeopts_jobs) -v -x"
+       use ppc64 && [[ $(tc-endian) == big ]] || GOFLAGS+=" -buildmode=pie"
+       local -x PKGCONFIG_EXE=$(tc-getPKG_CONFIG)
+
+       local conf=(
+               --disable-link-time-optimization
+               --ignore-compiler-warnings
+               --libdir-name=$(get_libdir)
+               --shell-integration="enabled no-rc"
+               --update-check-interval=0
+               --verbose
+       )
+
+       edo "${EPYTHON}" setup.py linux-package "${conf[@]}"
+       use test && edo "${EPYTHON}" setup.py build-launcher "${conf[@]}"
+
+       rm -r linux-package/share/terminfo || die # provided by kitty-terminfo
+
+       if [[ ${PV} == 9999 ]]; then
+               mkdir -p linux-package/share/doc/${PF} || die
+       else
+               mv linux-package/share/doc/{${PN},${PF}} || die
+       fi
+
+       # generate default config as reference, command taken from docs/conf.rst
+       if ! tc-is-cross-compiler; then
+               linux-package/bin/kitty +runpy \
+                       'from kitty.config import *; 
print(commented_out_default_config())' \
+                       > linux-package/share/doc/${PF}/kitty.conf || die
+       fi
+}
+
+src_test() {
+       KITTY_CONFIG_DIRECTORY=${T} ./test.py || die # shebang is kitty
+}
+
+src_install() {
+       edo mv linux-package "${ED}"/usr
+}
+
+pkg_postinst() {
+       xdg_pkg_postinst
+
+       optfeature "audio-based terminal bell support" media-libs/libcanberra
+       optfeature "opening links from the terminal" x11-misc/xdg-utils
+}

Reply via email to