tabby/clients/vim
Meng Zhang 7184304bf9
fix(docs): update join slack link (#1113)
* fix(docs): update join slack link

* fix lint
2023-12-25 09:42:46 +08:00
..
autoload feat(vim): Update tabby-agent. Remove support for Tabby Cloud auth. (#1102) 2023-12-22 20:16:41 +08:00
doc fix(docs): update join slack link (#1113) 2023-12-25 09:42:46 +08:00
node_scripts feat(vim): Update tabby-agent. Remove support for Tabby Cloud auth. (#1102) 2023-12-22 20:16:41 +08:00
plugin feat(vim): update vim plugin. (#604) 2023-10-21 23:32:17 -07:00
.gitattributes feat(vim): update tabby-agent. (#824) 2023-11-17 23:59:12 -08:00
.gitignore
CHANGELOG.md fix(agent): Hotfix 1.1.1. Fix agent completion stats initialization error. (#844) 2023-11-19 20:11:03 -08:00
LICENSE chore(vim): bump vim plugin version to 1.0.0. (#610) 2023-10-22 00:28:21 -07:00
package.json feat(agent): support read clipboard as prompt (#885) 2023-11-24 14:56:31 +08:00
README.md fix(docs): update join slack link (#1113) 2023-12-25 09:42:46 +08:00

Tabby Plugin for Vim and NeoVim

Tabby is a self-hosted AI coding assistant that can suggest multi-line code or full functions in real-time. For more information, please check out our website and github.
If you encounter any problem or have any suggestion, please open an issue or join our Slack community for support.

Table of Contents

Requirements

Tabby plugin requires the following dependencies:

  • Vim 9.0+ with +job and +textprop features enabled, or NeoVim 0.6.0+.

  • Tabby server. You can install Tabby server locally or have it hosted on a remote server. For Tabby server installation, please refer to this documentation.

  • Node.js version v18.0+.

    • If you need have multiple Node.js versions installed, you can use Node.js version manager such as nvm.
  • Vim filetype plugin enabled. You can add following lines in vim config file (~/.vimrc). For NeoVim, filetype plugin is enabled by default, you don't need to add these lines.

    filetype plugin on
    

Installation

You can install Tabby plugin using your favorite plugin manager. Here are some examples using popular plugin managers, you can choose one to follow.

🔌 Vim-plug

Vim-plug is a minimalist Vim plugin manager that you can use to install Tabby plugin. You can install Vim-plug by following these instructions.

Once Vim-plug is installed, you can install Tabby plugin by adding the following line to your vim config file (~/.vimrc for Vim and ~/.config/nvim/init.vim for NeoVim), between the plug#begin() and plug#end() lines.

" ...your vim configs...

" Section for plugins managed by vim-plug
plug#begin()

" ...other plugins...

" Add Tabby plugin
Plug 'TabbyML/vim-tabby'
plug#end()

Then, run the following command in your vim command line:

:PlugInstall

📦 Packer.nvim

Packer.nvim is a plugin manager for NeoVim that is written in Lua. You can install Packer.nvim by following these instructions.

Once Packer is installed, you can install Tabby plugin by adding the following line to your plugin specification, e.g. (in ~/.config/nvim/lua/plugins.lua).

--- Packer plugin specification
return require('packer').startup(function(use)
  --- ...other plugins...

  --- Add Tabby plugin
  use 'TabbyML/vim-tabby'
end)

Then, run the following command in your NeoVim command line:

:PackerSync

💤 Lazy.nvim

Lazy.nvim is an alternative plugin manager for NeoVim. You can install Lazy.nvim by following these instructions.

Once Lazy is installed, you can install Tabby plugin by adding the following line to your plugin specification in ~/.config/nvim/init.lua.

--- ...your NeoVim configs...

--- Lazy plugin specification
require("lazy").setup({
  --- ...other plugins...

  --- Add Tabby plugin
  "TabbyML/vim-tabby",
})

Usage

After installation, please exit and restart Vim or NeoVim. Then you can check the Tabby plugin status by running :Tabby in your vim command line. If you see any message reported by Tabby, it means the plugin is installed successfully. If you see Not an editor command: Tabby or any other error message, please check the installation steps.

In insert mode, Tabby plugin will show inline completion automatically when you stop typing. You can simply press <Tab> to accept the completion. If you want to dismiss the completion manually, you can press <C-\> to dismiss, and press <C-\> again to show the completion again.

Configuration

Tabby Server

You need to start the Tabby server before using the plugin. For Tabby server installation, please refer to this documentation.

If your Tabby server endpoint is different from the default http://localhost:8080, please set the endpoint in ~/.tabby-client/agent/config.toml.

If your Tabby server requires an authentication token, remember to set it here.

# Server
# You can set the server endpoint here.
[server]
endpoint = "http://localhost:8080" # http or https URL
token = "your-auth-token"

Node.js Binary Path

Normally, this config is not required as the Tabby plugin will try to find the Node.js binary in your PATH environment variable.
But if you have installed Node.js in a non-standard location, or you are using a Node.js version manager such as nvm, you can set the Node.js binary path in your vim config file (~/.vimrc for Vim and ~/.config/nvim/init.vim or ~/.config/nvim/init.lua for NeoVim).

let g:tabby_node_binary = '/path/to/node'
--- lua
vim.g.tabby_node_binary = '/path/to/node'

Completion Trigger Mode

Completion trigger mode is set to auto by default, Tabby plugin will show inline completion automatically when you stop typing.
If you prefer to trigger code completion manually, add this config in your vim config file. Tabby plugin will not show inline completion automatically, you can trigger the completion manually by pressing <C-\>.

let g:tabby_trigger_mode = 'manual'
--- lua
vim.g.tabby_trigger_mode = 'manual'

KeyBindings

The default key bindings for accept completion(<Tab>), manual trigger/dismiss(<C-\>) can be customized with the following global settings.

let g:tabby_keybinding_accept = '<Tab>'
let g:tabby_keybinding_trigger_or_dismiss = '<C-\>'
--- lua
vim.g.tabby_keybinding_accept = '<Tab>'
vim.g.tabby_keybinding_trigger_or_dismiss = '<C-\\>'

Contributing

Repository TabbyML/vim-tabby is for releasing Tabby plugin for Vim and NeoVim. If you want to contribute to Tabby plugin, please check our main repository TabbyML/tabby.

License

Apache-2.0