diff options
author | Mx Kookie <kookie@spacekookie.de> | 2020-12-09 18:55:19 +0000 |
---|---|---|
committer | Mx Kookie <kookie@spacekookie.de> | 2020-12-09 18:55:19 +0000 |
commit | 80d90d9b204f7c17912740f9f414fe5d59f293ba (patch) | |
tree | 5f2065a06e724270610760d59d01c6888b375a46 /infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty | |
parent | 3a31a84c7d3e589035ad08499206aac44a81f424 (diff) | |
parent | 83cbad92d73216bb0d9187c56cce0b91f9121d5a (diff) |
Merge commit '83cbad92d73216bb0d9187c56cce0b91f9121d5a' into main
Diffstat (limited to 'infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty')
-rw-r--r-- | infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/default.nix | 143 | ||||
-rw-r--r-- | infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/fix-paths.patch | 16 |
2 files changed, 159 insertions, 0 deletions
diff --git a/infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/default.nix b/infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/default.nix new file mode 100644 index 000000000000..b6a93aefb594 --- /dev/null +++ b/infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/default.nix @@ -0,0 +1,143 @@ +{ stdenv, substituteAll, fetchFromGitHub, python3Packages, libunistring, + harfbuzz, fontconfig, pkgconfig, ncurses, imagemagick, xsel, + libstartup_notification, libGL, libX11, libXrandr, libXinerama, libXcursor, + libxkbcommon, libXi, libXext, wayland-protocols, wayland, + lcms2, + installShellFiles, + dbus, + Cocoa, + CoreGraphics, + Foundation, + IOKit, + Kernel, + OpenGL, + libcanberra, + libicns, + libpng, + python3, + zlib, +}: + +with python3Packages; +buildPythonApplication rec { + pname = "kitty"; + version = "0.19.2"; + format = "other"; + + src = fetchFromGitHub { + owner = "kovidgoyal"; + repo = "kitty"; + rev = "v${version}"; + sha256 = "06mlrc283k5f75y36fmmaxnj29jfc1s8vaykjph6a86m1gcl5wgi"; + }; + + buildInputs = [ + harfbuzz + ncurses + lcms2 + ] ++ stdenv.lib.optionals stdenv.isDarwin [ + Cocoa + CoreGraphics + Foundation + IOKit + Kernel + OpenGL + libpng + python3 + zlib + ] ++ stdenv.lib.optionals stdenv.isLinux [ + fontconfig libunistring libcanberra libX11 + libXrandr libXinerama libXcursor libxkbcommon libXi libXext + wayland-protocols wayland dbus + ]; + + nativeBuildInputs = [ + pkgconfig sphinx ncurses + installShellFiles + ] ++ stdenv.lib.optionals stdenv.isDarwin [ + imagemagick + libicns # For the png2icns tool. + ]; + + propagatedBuildInputs = stdenv.lib.optional stdenv.isLinux libGL; + + outputs = [ "out" "terminfo" ]; + + patches = [ + ./fix-paths.patch + ]; + + # Causes build failure due to warning + hardeningDisable = stdenv.lib.optional stdenv.cc.isClang "strictoverflow"; + + dontConfigure = true; + + buildPhase = if stdenv.isDarwin then '' + ${python.interpreter} setup.py kitty.app \ + --update-check-interval=0 \ + --disable-link-time-optimization + make man + '' else '' + ${python.interpreter} setup.py linux-package \ + --update-check-interval=0 \ + --egl-library='${stdenv.lib.getLib libGL}/lib/libEGL.so.1' \ + --startup-notification-library='${libstartup_notification}/lib/libstartup-notification-1.so' \ + --canberra-library='${libcanberra}/lib/libcanberra.so' + ''; + + checkInputs = [ pillow ]; + + checkPhase = + let buildBinPath = + if stdenv.isDarwin + then "kitty.app/Contents/MacOS" + else "linux-package/bin"; + in + '' + env PATH="${buildBinPath}:$PATH" ${python.interpreter} test.py + ''; + + installPhase = '' + runHook preInstall + mkdir -p $out + ${if stdenv.isDarwin then '' + mkdir "$out/bin" + ln -s ../Applications/kitty.app/Contents/MacOS/kitty "$out/bin/kitty" + mkdir "$out/Applications" + cp -r kitty.app "$out/Applications/kitty.app" + + installManPage 'docs/_build/man/kitty.1' + '' else '' + cp -r linux-package/{bin,share,lib} $out + ''} + wrapProgram "$out/bin/kitty" --prefix PATH : "$out/bin:${stdenv.lib.makeBinPath [ imagemagick xsel ncurses.dev ]}" + runHook postInstall + + installShellCompletion --cmd kitty \ + --bash <("$out/bin/kitty" + complete setup bash) \ + --fish <("$out/bin/kitty" + complete setup fish) \ + --zsh <("$out/bin/kitty" + complete setup zsh) + ''; + + postInstall = '' + terminfo_src=${if stdenv.isDarwin then + ''"$out/Applications/kitty.app/Contents/Resources/terminfo"'' + else + "$out/share/terminfo"} + + mkdir -p $terminfo/share + mv "$terminfo_src" $terminfo/share/terminfo + + mkdir -p $out/nix-support + echo "$terminfo" >> $out/nix-support/propagated-user-env-packages + ''; + + meta = with stdenv.lib; { + homepage = "https://github.com/kovidgoyal/kitty"; + description = "A modern, hackable, featureful, OpenGL based terminal emulator"; + license = licenses.gpl3; + changelog = "https://sw.kovidgoyal.net/kitty/changelog.html"; + platforms = platforms.darwin ++ platforms.linux; + maintainers = with maintainers; [ tex rvolosatovs Luflosi ]; + }; +} diff --git a/infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/fix-paths.patch b/infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/fix-paths.patch new file mode 100644 index 000000000000..380f6d749146 --- /dev/null +++ b/infra/libkookie/nixpkgs/pkgs/applications/terminal-emulators/kitty/fix-paths.patch @@ -0,0 +1,16 @@ +--- a/docs/Makefile ++++ b/docs/Makefile +@@ -3,7 +3,7 @@ +# Patching is needed here for the following reason: +# * importing the `constants` package from Kitty has a side effect that it +# creates the user configuration directory. This package gets imported +# while sphinx scans the code for documentation strings. +# + + # You can set these variables from the command line. + SPHINXOPTS = -j auto -T $(FAIL_WARN) +-SPHINXBUILD = sphinx-build ++SPHINXBUILD = PYTHONPATH=${PYTHONPATH}:.. HOME=${TMPDIR}/kitty-build-home sphinx-build + SPHINXPROJ = kitty + SOURCEDIR = . + BUILDDIR = _build |