mirror of
				https://github.com/NotAShelf/nvf.git
				synced 2025-11-04 04:32:21 +00:00 
			
		
		
		
	Currently, regardless of whether nvim-cmp is enabled, nvim-cmp's sources are added as providers. If the nvim-cmp sources "buffer" or "path" are enabled they will override and break blink.cmp's default "path" and "buffer" sources. This fixes the issue by only configuring nvim-cmp sources and providers when nvim-cmp is enabled and, if nvim-cmp is enabled, only configuring nvim-cmp compat providers that are not in the blink.cmp default sources.
		
			
				
	
	
		
			149 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
	
		
			4.8 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{
 | 
						|
  lib,
 | 
						|
  config,
 | 
						|
  ...
 | 
						|
}: let
 | 
						|
  inherit (lib.modules) mkIf;
 | 
						|
  inherit (lib.strings) optionalString;
 | 
						|
  inherit (lib.attrsets) optionalAttrs;
 | 
						|
  inherit (lib.generators) mkLuaInline;
 | 
						|
  inherit (lib.attrsets) attrValues filterAttrs mapAttrsToList;
 | 
						|
  inherit (lib.lists) map optional optionals elem;
 | 
						|
  inherit (lib.nvim.lua) toLuaObject;
 | 
						|
  inherit (builtins) concatStringsSep typeOf tryEval attrNames mapAttrs removeAttrs;
 | 
						|
 | 
						|
  cfg = config.vim.autocomplete.blink-cmp;
 | 
						|
  cmpCfg = config.vim.autocomplete.nvim-cmp;
 | 
						|
  inherit (cfg) mappings;
 | 
						|
 | 
						|
  getPluginName = plugin:
 | 
						|
    if typeOf plugin == "string"
 | 
						|
    then plugin
 | 
						|
    else if (plugin ? pname && (tryEval plugin.pname).success)
 | 
						|
    then plugin.pname
 | 
						|
    else plugin.name;
 | 
						|
 | 
						|
  enabledBlinkSources = filterAttrs (_source: definition: definition.enable) cfg.sourcePlugins;
 | 
						|
  blinkSourcePlugins = map (definition: definition.package) (attrValues enabledBlinkSources);
 | 
						|
 | 
						|
  blinkBuiltins = [
 | 
						|
    "path"
 | 
						|
    "lsp"
 | 
						|
    "snippets"
 | 
						|
    "buffer"
 | 
						|
    "omni"
 | 
						|
  ];
 | 
						|
in {
 | 
						|
  assertions =
 | 
						|
    mapAttrsToList (provider: definition: {
 | 
						|
      assertion = elem provider blinkBuiltins || definition.module != null;
 | 
						|
      message = "`config.vim.autocomplete.blink-cmp.setupOpts.sources.providers.${provider}.module` is `null`: non-builtin providers must set `module`.";
 | 
						|
    })
 | 
						|
    cfg.setupOpts.sources.providers;
 | 
						|
 | 
						|
  vim = mkIf cfg.enable {
 | 
						|
    startPlugins = ["blink-compat"] ++ blinkSourcePlugins ++ (optional cfg.friendly-snippets.enable "friendly-snippets");
 | 
						|
    lazy.plugins = {
 | 
						|
      blink-cmp = {
 | 
						|
        package = "blink-cmp";
 | 
						|
        setupModule = "blink.cmp";
 | 
						|
        inherit (cfg) setupOpts;
 | 
						|
 | 
						|
        # TODO: lazy disabled until lspconfig is lazy loaded
 | 
						|
        #
 | 
						|
        # event = ["InsertEnter" "CmdlineEnter"];
 | 
						|
 | 
						|
        after =
 | 
						|
          # lua
 | 
						|
          ''
 | 
						|
            ${optionalString (config.vim.lazy.enable && cmpCfg.enable)
 | 
						|
              (concatStringsSep "\n" (map
 | 
						|
                (package: "require('lz.n').trigger_load(${toLuaObject (getPluginName package)})")
 | 
						|
                cmpCfg.sourcePlugins))}
 | 
						|
          '';
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    autocomplete = {
 | 
						|
      enableSharedCmpSources = true;
 | 
						|
      blink-cmp.setupOpts = {
 | 
						|
        sources = let
 | 
						|
          # We do not want nvim-cmp compat sources overriding built-in blink sources
 | 
						|
          filteredCmpSources = removeAttrs cmpCfg.sources blinkBuiltins;
 | 
						|
        in {
 | 
						|
          default =
 | 
						|
            [
 | 
						|
              "lsp"
 | 
						|
              "path"
 | 
						|
              "snippets"
 | 
						|
              "buffer"
 | 
						|
            ]
 | 
						|
            ++ optionals cmpCfg.enable (attrNames filteredCmpSources)
 | 
						|
            ++ (attrNames enabledBlinkSources);
 | 
						|
          providers =
 | 
						|
            optionalAttrs cmpCfg.enable (
 | 
						|
              mapAttrs (name: _: {
 | 
						|
                inherit name;
 | 
						|
                module = "blink.compat.source";
 | 
						|
              })
 | 
						|
              filteredCmpSources
 | 
						|
            )
 | 
						|
            // (mapAttrs (name: definition: {
 | 
						|
                inherit name;
 | 
						|
                inherit (definition) module;
 | 
						|
              })
 | 
						|
              enabledBlinkSources);
 | 
						|
        };
 | 
						|
        snippets = mkIf config.vim.snippets.luasnip.enable {
 | 
						|
          preset = "luasnip";
 | 
						|
        };
 | 
						|
 | 
						|
        keymap = {
 | 
						|
          ${mappings.complete} = ["show" "fallback"];
 | 
						|
          ${mappings.close} = ["hide" "fallback"];
 | 
						|
          ${mappings.scrollDocsUp} = ["scroll_documentation_up" "fallback"];
 | 
						|
          ${mappings.scrollDocsDown} = ["scroll_documentation_down" "fallback"];
 | 
						|
          ${mappings.confirm} = ["accept" "fallback"];
 | 
						|
 | 
						|
          ${mappings.next} = [
 | 
						|
            "select_next"
 | 
						|
            "snippet_forward"
 | 
						|
            (mkLuaInline
 | 
						|
              # lua
 | 
						|
              ''
 | 
						|
                function(cmp)
 | 
						|
                  local line, col = unpack(vim.api.nvim_win_get_cursor(0))
 | 
						|
                  has_words_before = col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil
 | 
						|
 | 
						|
                  if has_words_before then
 | 
						|
                    return cmp.show()
 | 
						|
                  end
 | 
						|
                end
 | 
						|
              '')
 | 
						|
            "fallback"
 | 
						|
          ];
 | 
						|
          ${mappings.previous} = [
 | 
						|
            "select_prev"
 | 
						|
            "snippet_backward"
 | 
						|
            "fallback"
 | 
						|
          ];
 | 
						|
        };
 | 
						|
 | 
						|
        # cmdline is not enabled by default, we're just providing keymaps in
 | 
						|
        # case the user enables them
 | 
						|
        cmdline.keymap = {
 | 
						|
          ${mappings.complete} = ["show" "fallback"];
 | 
						|
          ${mappings.close} = ["hide" "fallback"];
 | 
						|
          ${mappings.scrollDocsUp} = ["scroll_documentation_up" "fallback"];
 | 
						|
          ${mappings.scrollDocsDown} = ["scroll_documentation_down" "fallback"];
 | 
						|
          # NOTE: mappings.confirm is skipped because our default, <CR> would
 | 
						|
          # lead to accidental triggers of blink.accept instead of executing
 | 
						|
          # the cmd
 | 
						|
 | 
						|
          ${mappings.next} = ["select_next" "show" "fallback"];
 | 
						|
          ${mappings.previous} = ["select_prev" "fallback"];
 | 
						|
        };
 | 
						|
      };
 | 
						|
    };
 | 
						|
  };
 | 
						|
}
 |