2025-03-16 20:20:40 +01:00
2025-03-16 20:15:43 +01:00
2025-03-16 14:09:26 +01:00
2025-03-16 08:40:31 +00:00
2025-03-16 20:20:40 +01:00

neovim-gemini

A Neovim plugin for interacting with the Google AI API (formerly Gemini). Get AI-powered assistance directly within your Neovim editor.

Requirements

  • Neovim 0.8 or higher
  • A Google AI API key (obtainable from https://makersuite.google.com/app/apikey)
  • curl installed on your system
  • Treesitter installed with the markdown parser (automatically installed during setup)

Installation

Use your favorite Neovim package manager. Here's how to install with Lazy.nvim:

{
  "your_username/neovim-gemini",
  config = function()
    require("gemini").setup()
  end,
}

Configuration

API Key Setup

Set your API key using one of these methods:

  1. Environment variable:
export GEMINI_API_KEY="your-api-key-here"
  1. Neovim configuration:
-- In your init.lua
vim.g.gemini_api_key = "your-api-key-here"

Plugin Configuration

The plugin can be configured during setup. Here's an example with all available options and their defaults:

require("gemini").setup({
    -- Model configuration
    model = "gemini-2.0-flash", -- The Gemini model to use

    -- Window appearance
    window = {
        -- Window width (can be number or function)
        width = function() 
            return math.floor(vim.o.columns / 3)
        end,
        -- Window height (can be number or function)
        height = function()
            return vim.o.lines - 2
        end,
        border = "rounded",     -- Border style: "none", "single", "double", "rounded"
        title = "Gemini Chat Session",
        title_pos = "center",   -- Title position: "left", "center", "right"
    },

    -- Keymaps in chat window
    mappings = {
        close = 'q',           -- Close chat window
        return_focus = '<Esc>', -- Return to previous window
        new_query = 'i',       -- Start new query
    },

    -- Highlight groups for chat messages
    highlights = {
        user = "GeminiUser",         -- Highlight group for user messages
        separator = "GeminiSeparator", -- Highlight group for message separators
    },
})

Customizing Highlights

The plugin defines two highlight groups that you can customize:

-- In your init.lua or colorscheme
vim.api.nvim_set_hl(0, "GeminiUser", { fg = "#EBCB8B", bold = true })
vim.api.nvim_set_hl(0, "GeminiSeparator", { fg = "#616E88", bold = true })

Default Keymaps

The plugin sets up the following default keymaps:

  • <leader>gc: Open chat window for a new query
  • <leader>gs: Open chat window with current buffer as context
  • <leader>gq: Clear chat history

You can override these by adding your own mappings after setup:

-- Example of custom keymaps
vim.keymap.set("n", "<leader>m", function()
    require("gemini").prompt_query()
end, { desc = "Chat with Gemini AI" })

vim.keymap.set("n", "<leader>M", function()
    require("gemini").prompt_query(vim.api.nvim_buf_get_lines(0, 0, -1, false))
end, { desc = "Chat with Gemini AI (with buffer context)" })

Configuration Tips

  1. Window Size: The window size functions can be customized to your needs:
window = {
    width = function()
        -- Use 40% of screen width
        return math.floor(vim.o.columns * 0.4)
    end,
    height = function()
        -- Use 80% of screen height
        return math.floor(vim.o.lines * 0.8)
    end
}
  1. Fixed Dimensions: You can use fixed numbers instead of functions:
window = {
    width = 80,   -- Fixed width of 80 columns
    height = 40,  -- Fixed height of 40 lines
}
  1. Custom Border Style: Choose from available border styles:
window = {
    border = "double",  -- Options: "none", "single", "double", "rounded"
}

Usage

The plugin provides several ways to interact with Gemini:

  1. Command Mode:
:Gemini What is SOLID in software engineering?
  1. Simple Query:
  • Press <leader>gc to open an input prompt (mnemonic: 'gemini chat')
  • Type your query and press Enter
  1. Context-Aware Query:
  • Press <leader>gs to open an input prompt (mnemonic: 'gemini sync')
  • This will send your current buffer's content as context along with your query
  • Useful for code-related questions about the file you're working on
  1. Clear Chat History:
  • Press <leader>gq to clear the chat history (mnemonic: 'gemini quit')
  • This will clear both the chat window and conversation history
  • You can also use the :GeminiClearChat command

Chat Window Controls

The chat window appears on the right side of your editor and provides the following controls:

  • i: Enter a new query
    • If the chat was started with buffer context (using <leader>gs), subsequent queries will maintain that context
    • If started without context (using <leader>gc), queries will be context-free
  • q: Close the chat window (history is preserved)
  • <Esc>: Return focus to previous buffer
  • Normal mode scrolling commands (j, k, <C-d>, <C-u>, etc.) work as expected

Chat Window Display:

  • Your latest query is automatically positioned at the top of the window
  • The AI's response appears directly below your query
  • Previous conversation history is accessible by scrolling up
  • Messages are clearly marked with "User:" and "Assistant:" prefixes
  • Messages are separated by horizontal lines for better readability

File operations in the chat window are intentionally disabled:

  • :w, :e, :sp, :vs and similar commands are blocked
  • The command-line mode (:) is disabled to prevent file operations
  • A warning message appears if you attempt these operations

Chat Commands

  • :GeminiClearChat: Clear the conversation history and chat window
  • :Gemini <query>: Send a query directly from command mode

Features

  • Floating window interface with persistent chat history
  • Non-blocking API calls
  • Error handling and notifications
  • Easy-to-use command and keymap interface
  • Support for the latest Gemini 2.0 Flash model
  • Markdown syntax highlighting for responses
  • Context-aware queries using current buffer content
  • Smart conversation display with latest query at the top
  • Protected chat window to prevent accidental modifications

Troubleshooting

If you encounter issues:

  1. Verify your API key is correctly set:
:lua print(vim.g.gemini_api_key)
  1. Check if curl is installed:
curl --version
  1. Ensure you have billing set up in your Google Cloud project

License

This project is licensed under the ISC License. See the LICENSE file for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Description
A Neovim plugin for interacting with the Google AI API (formerly Gemini).
Readme 0BSD 422 KiB
Languages
Lua 100%