# 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](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: ```lua { "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: ```bash export GEMINI_API_KEY="your-api-key-here" ``` 2. Neovim configuration: ```lua -- 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: ```lua 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 = '', -- 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: ```lua -- 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: - `gc`: Open chat window for a new query - `gs`: Open chat window with current buffer as context - `gq`: Clear chat history You can override these by adding your own mappings after setup: ```lua -- Example of custom keymaps vim.keymap.set("n", "m", function() require("gemini").prompt_query() end, { desc = "Chat with Gemini AI" }) vim.keymap.set("n", "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: ```lua 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 } ``` 2. **Fixed Dimensions**: You can use fixed numbers instead of functions: ```lua window = { width = 80, -- Fixed width of 80 columns height = 40, -- Fixed height of 40 lines } ``` 3. **Custom Border Style**: Choose from available border styles: ```lua window = { border = "double", -- Options: "none", "single", "double", "rounded" } ``` ## Usage The plugin provides several ways to interact with Gemini: 1. Command Mode: ```vim :Gemini What is SOLID in software engineering? ``` 2. Simple Query: - Press `gc` to open an input prompt (mnemonic: 'gemini chat') - Type your query and press Enter 3. Context-Aware Query: - Press `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 4. Clear Chat History: - Press `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 `gs`), subsequent queries will maintain that context - If started without context (using `gc`), queries will be context-free - `q`: Close the chat window (history is preserved) - ``: Return focus to previous buffer - Normal mode scrolling commands (`j`, `k`, ``, ``, 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 `: 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 :lua print(vim.g.gemini_api_key) ``` 2. Check if curl is installed: ```bash curl --version ``` 3. Ensure you have billing set up in your Google Cloud project ## License This project is licensed under the ISC License. See the [LICENSE](LICENSE) file for details. ## Contributing Contributions are welcome! Please feel free to submit a Pull Request.