neovim

Neovim text editor
git clone https://git.dasho.dev/neovim.git
Log | Files | Refs | README

commit 4bbdffe8298e8bf6e0590684092a25f5effc0f14
parent 1c12073db6c64eb365748f153f96be9b0fe61070
Author: Justin M. Keyes <justinkz@gmail.com>
Date:   Sat, 22 Nov 2025 13:26:04 -0800

Merge #36663 from justinmk/offlinebuild

build: drop BUNDLED_CMAKE_FLAG, BUNDLED_LUA_CMAKE_FLAG
Diffstat:
M.github/workflows/build.yml | 2+-
M.github/workflows/test.yml | 2+-
MBUILD.md | 6++++--
MMakefile | 15++++++++++++---
Mruntime/doc/news.txt | 2+-
Msrc/nvim/eval/funcs.c | 3+++
Mtest/functional/vimscript/has_spec.lua | 11+++++++++++
7 files changed, 33 insertions(+), 8 deletions(-)

diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml @@ -55,7 +55,7 @@ jobs: run: make install use-existing-src: - name: Test USE_EXISTING_SRC_DIR=ON builds with no network access + name: Test offline build (USE_EXISTING_SRC_DIR=ON builds with no network access) runs-on: ubuntu-latest steps: - uses: actions/checkout@v6 diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml @@ -176,7 +176,7 @@ jobs: - name: Install run: | cmake --install build - "$INSTALL_PREFIX/bin/nvim" --version + "$INSTALL_PREFIX/bin/nvim" -V1 --version if ! "$INSTALL_PREFIX/bin/nvim" -u NONE -e -c ':help' -c ':qall'; then echo "Running ':help' in the installed nvim failed." echo "Maybe the helptags have not been generated properly." diff --git a/BUILD.md b/BUILD.md @@ -297,9 +297,11 @@ are good enough. To avoid this dependency, build with support for loading custom terminfo at runtime, use ```sh -make CMAKE_EXTRA_FLAGS="-DENABLE_UNIBILIUM=0" BUNDLED_CMAKE_FLAG="-DUSE_BUNDLED_UNIBILIUM=0" +make CMAKE_EXTRA_FLAGS="-DENABLE_UNIBILIUM=0" DEPS_CMAKE_FLAGS="-DUSE_BUNDLED_UNIBILIUM=0" ``` +To confirm at runtime that unibilium was not included, check `has('terminfo') == 1`. + ### How to build static binary (on Linux) 1. Use a linux distribution which uses musl C. We will use Alpine Linux but any distro with musl should work. (glibc does not support static linking) @@ -341,7 +343,7 @@ cmake --build build ``` - Example of using a package with some dependencies: ``` - make BUNDLED_CMAKE_FLAG="-DUSE_BUNDLED=OFF -DUSE_BUNDLED_LUV=ON -DUSE_BUNDLED_TS=ON -DUSE_BUNDLED_LIBUV=ON" + make DEPS_CMAKE_FLAGS="-DUSE_BUNDLED=OFF -DUSE_BUNDLED_LUV=ON -DUSE_BUNDLED_TS=ON -DUSE_BUNDLED_LIBUV=ON" ``` ## Build prerequisites diff --git a/Makefile b/Makefile @@ -76,12 +76,21 @@ endif DEPS_CMAKE_FLAGS ?= USE_BUNDLED ?= +ifdef BUNDLED_CMAKE_FLAG + $(error BUNDLED_CMAKE_FLAG was removed. Use DEPS_CMAKE_FLAGS instead) +endif + +ifdef BUNDLED_LUA_CMAKE_FLAG + $(error BUNDLED_LUA_CMAKE_FLAG was removed. Use DEPS_CMAKE_FLAGS instead) +endif + +# If USE_BUNDLED is non-empty, prepend the flag to DEPS_CMAKE_FLAGS ifneq (,$(USE_BUNDLED)) - BUNDLED_CMAKE_FLAG := -DUSE_BUNDLED=$(USE_BUNDLED) + DEPS_CMAKE_FLAGS := -DUSE_BUNDLED=$(USE_BUNDLED) $(DEPS_CMAKE_FLAGS) endif ifneq (,$(findstring functionaltest-lua,$(MAKECMDGOALS))) - BUNDLED_LUA_CMAKE_FLAG := -DUSE_BUNDLED_LUA=ON + DEPS_CMAKE_FLAGS := -DUSE_BUNDLED_LUA=ON $(DEPS_CMAKE_FLAGS) $(shell [ -x $(DEPS_BUILD_DIR)/usr/bin/lua ] || $(RM) build/.ran-*) endif @@ -112,7 +121,7 @@ ifeq ($(call filter-true,$(USE_BUNDLED)),) $(DEPS_BUILD_DIR): $(MKDIR) $@ build/.ran-deps-cmake:: $(DEPS_BUILD_DIR) - $(CMAKE) -S $(MAKEFILE_DIR)/cmake.deps -B $(DEPS_BUILD_DIR) -G $(CMAKE_GENERATOR) $(BUNDLED_CMAKE_FLAG) $(BUNDLED_LUA_CMAKE_FLAG) $(DEPS_CMAKE_FLAGS) + $(CMAKE) -S $(MAKEFILE_DIR)/cmake.deps -B $(DEPS_BUILD_DIR) -G $(CMAKE_GENERATOR) $(DEPS_CMAKE_FLAGS) endif build/.ran-deps-cmake:: $(MKDIR) build diff --git a/runtime/doc/news.txt b/runtime/doc/news.txt @@ -159,7 +159,7 @@ BUILD the user's terminfo database won't be loaded and only internal definitions for the most common terminals are used. > - make distclean && make CMAKE_EXTRA_FLAGS="-DENABLE_UNIBILIUM=0" BUNDLED_CMAKE_FLAG="-DUSE_BUNDLED_UNIBILIUM=0" + make distclean && make CMAKE_EXTRA_FLAGS="-DENABLE_UNIBILIUM=0" DEPS_CMAKE_FLAGS"-DUSE_BUNDLED_UNIBILIUM=0" < DEFAULTS diff --git a/src/nvim/eval/funcs.c b/src/nvim/eval/funcs.c @@ -2757,6 +2757,9 @@ static void f_has(typval_T *argvars, typval_T *rettv, EvalFuncData fptr) "tablineat", "tag_binary", "termguicolors", +#ifdef HAVE_UNIBILIUM + "terminfo", +#endif "termresponse", "textobjects", "timers", diff --git a/test/functional/vimscript/has_spec.lua b/test/functional/vimscript/has_spec.lua @@ -64,6 +64,17 @@ describe('has()', function() end end) + it('"terminfo"', function() + -- Looks like "HAVE_UNIBILIUM ", "HAVE_UNIBILIUM=1", "HAVE_UNIBILIUM off", …. + -- Capture group returns the "1"/"off"/…. + local build_flag = + vim.trim((n.exec_capture('verbose version'):match('HAVE_UNIBILIUM([^-]+)') or ''):lower()) + -- XXX: the match() above fails in CI so currently we assume CI always builds with unibilium. + local is_enabled = t.is_ci() + or not (build_flag == '' or build_flag == 'false' or build_flag == '0' or build_flag == 'off') + eq(is_enabled and 1 or 0, fn.has('terminfo')) + end) + it('"wsl"', function() local is_wsl = vim.uv.os_uname()['release']:lower():match('microsoft') and true or false if is_wsl then