{ lib, stdenv, fetchFromGitHub, removeReferencesTo, cmake, gettext, msgpack-c, libuv, lua, pkg-config, unibilium, libvterm-neovim, tree-sitter, fetchurl, buildPackages, treesitter-parsers ? import ./treesitter-parsers.nix { inherit fetchurl; }, fixDarwinDylibNames, glibcLocales ? null, procps ? null, # now defaults to false because some tests can be flaky (clipboard etc), see # also: https://github.com/neovim/neovim/issues/16233 nodejs ? null, fish ? null, python3 ? null, }: stdenv.mkDerivation ( finalAttrs: let nvim-lpeg-dylib = luapkgs: if stdenv.hostPlatform.isDarwin then let luaLibDir = "$out/lib/lua/${lib.versions.majorMinor luapkgs.lua.luaversion}"; in (luapkgs.lpeg.overrideAttrs (oa: { preConfigure = '' # neovim wants clang .dylib substituteInPlace Makefile \ --replace-fail "CC = gcc" "CC = clang" \ --replace-fail "-bundle" "-dynamiclib" \ --replace-fail "lpeg.so" "lpeg.dylib" ''; preBuild = '' # there seems to be implicit calls to Makefile from luarocks, we need to # add a stage to build our dylib make macosx mkdir -p ${luaLibDir} mv lpeg.dylib ${luaLibDir}/lpeg.dylib ''; postInstall = '' rm -f ${luaLibDir}/lpeg.so ''; nativeBuildInputs = oa.nativeBuildInputs ++ (lib.optional stdenv.hostPlatform.isDarwin fixDarwinDylibNames); })) else luapkgs.lpeg; requiredLuaPkgs = ps: ( with ps; [ (nvim-lpeg-dylib ps) luabitop mpack ] ++ lib.optionals finalAttrs.finalPackage.doCheck [ luv coxpcall busted luafilesystem penlight inspect ] ); neovimLuaEnv = lua.withPackages requiredLuaPkgs; neovimLuaEnvOnBuild = lua.luaOnBuild.withPackages requiredLuaPkgs; codegenLua = if lua.luaOnBuild.pkgs.isLuaJIT then let deterministicLuajit = lua.luaOnBuild.override { deterministicStringIds = true; self = deterministicLuajit; }; in deterministicLuajit.withPackages (ps: [ ps.mpack (nvim-lpeg-dylib ps) ]) else lua.luaOnBuild; in { pname = "neovim-unwrapped"; version = "0.10.2"; __structuredAttrs = true; src = fetchFromGitHub { owner = "neovim"; repo = "neovim"; rev = "refs/tags/v${finalAttrs.version}"; hash = "sha256-+qjjelYMB3MyjaESfCaGoeBURUzSVh/50uxUqStxIfY="; }; patches = [ # introduce a system-wide rplugin.vim in addition to the user one # necessary so that nix can handle `UpdateRemotePlugins` for the plugins # it installs. See https://github.com/neovim/neovim/issues/9413. ./system_rplugin_manifest.patch ]; dontFixCmake = true; inherit lua; treesitter-parsers = treesitter-parsers // { markdown = treesitter-parsers.markdown // { location = "tree-sitter-markdown"; }; } // { markdown_inline = treesitter-parsers.markdown // { language = "markdown_inline"; location = "tree-sitter-markdown-inline"; }; }; buildInputs = [ libuv libvterm-neovim # This is actually a c library, hence it's not included in neovimLuaEnv, # see: # https://github.com/luarocks/luarocks/issues/1402#issuecomment-1080616570 # and it's definition at: pkgs/development/lua-modules/overrides.nix lua.pkgs.libluv msgpack-c neovimLuaEnv tree-sitter unibilium ] ++ lib.optionals finalAttrs.finalPackage.doCheck [ glibcLocales procps ]; doCheck = false; # to be exhaustive, one could run # make oldtests too checkPhase = '' runHook preCheck make functionaltest runHook postCheck ''; nativeBuildInputs = [ cmake gettext pkg-config removeReferencesTo ]; # extra programs test via `make functionaltest` nativeCheckInputs = let pyEnv = python3.withPackages ( ps: with ps; [ pynvim msgpack ] ); in [ fish nodejs pyEnv # for src/clint.py ]; # nvim --version output retains compilation flags and references to build tools postPatch = lib.optionalString (!stdenv.buildPlatform.canExecute stdenv.hostPlatform) '' sed -i runtime/CMakeLists.txt \ -e "s|\".*/bin/nvim|\${stdenv.hostPlatform.emulator buildPackages} &|g" sed -i src/nvim/po/CMakeLists.txt \ -e "s|\$