
Commit Sage is a VSCode extension that automatically generates commit messages using various AI providers:
- Gemini (default, requires API key, free)
- OpenAI (requires API key or compatible provider)
- Codestral (requires API key, free)
- Ollama (local, free)

Features
- 🤖 AI-powered commit message generation
- 🔄 Auto model selection for Gemini (tries available models until success)
- 🌍 Multiple language support (English, Russian, Chinese, Japanese, Korean, German, French, Spanish, Portuguese)
- 📝 Various commit formats (Conventional, Angular, Karma, Semantic, Emoji, EmojiKarma, Google, Atom)
- 🔄 Smart handling of staged/unstaged changes
- 🚀 Auto-commit and auto-push capabilities
- 🎯 Custom instructions support
- ⚡ Fast and efficient processing
Configuration
Get your API key:
AI Provider Settings
Commit Settings
Language (commitSage.commit.commitLanguage):
- Options:
english, russian, chinese, japanese, korean, german, french, spanish, portuguese
- Default:
english
Format (commitSage.commit.commitFormat):
- Options:
conventional, angular, karma, semantic, emoji, emojiKarma, google, atom
- Default:
conventional
Staged Changes (commitSage.commit.onlyStagedChanges):
- When enabled: Only analyzes staged changes
- When disabled:
- Uses staged changes if present
- Uses all changes if no staged changes
- Default:
false
Auto Commit (commitSage.commit.autoCommit):
- Automatically commits after message generation
- Default:
false
Auto Push (commitSage.commit.autoPush):
- Automatically pushes after auto-commit
- Requires Auto Commit to be enabled
- Default:
false
References (commitSage.commit.promptForRefs):
- Prompts for issue/PR references
- Default:
false
Custom Instructions
Telemetry
- Enable (
commitSage.telemetry.enabled):
- Collects anonymous usage data
- Default:
true
Project Configuration (.commitsage/config.json)
You can override extension settings for individual projects by creating a .commitsage/config.json file in your project root. This allows different projects to have different AI providers, commit formats, or other settings.
Legacy single-file .commitsage configurations are still loaded and are automatically migrated to .commitsage/config.json on next activation.
Creating Project Configuration
- Open Command Palette (
Ctrl+Shift+P / Cmd+Shift+P)
- Run "Commit Sage: Create Project Config (.commitsage)"
- Edit the generated
.commitsage/config.json with your project-specific settings
Example .commitsage/config.json:
{
"provider": {
"type": "gemini"
},
"commit": {
"commitLanguage": "russian",
"commitFormat": "conventional",
"autoCommit": false,
"autoPush": false
},
"gemini": {
"model": "auto"
},
"telemetry": {
"enabled": false
}
}
Settings Priority
Settings are loaded in the following order (higher priority overrides lower):
- Project settings (
.commitsage/config.json) - Highest priority
- VS Code workspace settings - Medium priority
- VS Code global settings - Lowest priority
Notes
- The
.commitsage/config.json file is automatically watched for changes
- Invalid JSON syntax will show an error notification
- API keys are still managed through VS Code's secure storage (not stored in project files)
- You can override any setting available in the extension configuration
Usage
- Stage your changes in Git
- Open the Source Control view (Ctrl+Shift+G / Cmd+Shift+G), then press
Ctrl+G (Windows/Linux) / Cmd+G (Mac) — the keybinding is scoped to the SCM view to avoid clashing with editor shortcuts
- Or click the Commit Sage icon in the Source Control view
- Or run "Commit Sage: Generate Commit Message" from the Command Palette (works from anywhere)
- Wait for the AI to analyze changes and generate a message
- Review and edit the message if needed
- Commit as usual
Requirements
- VSCode 1.93.0 or higher
- Git installed and configured
- Internet connection (except for Ollama)
- API key for OpenAI/Codestral (if using those providers)
Documentation
Detailed guides are available in the docs/ directory:
Privacy & Security
- API keys are stored in VS Code's secure storage (OS keychain), never in plain text files
- Code changes are sent to the selected AI provider for analysis — do not use cloud providers on repositories containing secrets
- Ollama runs locally — no data leaves your machine
- Telemetry collects anonymous usage events (provider type, errors) to help improve the extension; disable via
commitSage.telemetry.enabled: false
License
MIT
Support
If you encounter any issues or have suggestions, please open an issue.
For troubleshooting common problems, see docs/troubleshooting.md.
Commit Sage (на русском)
Commit Sage - расширение VSCode для автоматической генерации сообщений коммитов с использованием Gemini AI от Google, Codestral API или OpenAI API (OpenAI, Ollama, LocalAI и другие).
Установка
- Установите из VS Code Marketplace
- Получите API ключ:
- Настройте ключ в VS Code:
- Откройте палитру команд (Ctrl+Shift+P / Cmd+Shift+P)
- Введите "Commit Sage: Set Gemini API Key", "Commit Sage: Set Codestral API Key" или "Commit Sage: Set Custom API Key"
- Введите ваш API ключ
Использование
- Добавьте изменения в Git (git add)
- Откройте палитру команд (Ctrl+Shift+P / Cmd+Shift+P)
- Введите "Commit Sage: Generate Commit Message"
- Проверьте и подтвердите сгенерированное сообщение
Настройка
Все настройки доступны через:
- Палитра команд → "Preferences: Open Settings (UI)"
- Поиск "Commit Sage"
Конфигурация проекта (.commitsage/config.json)
Вы можете переопределить настройки расширения для отдельных проектов, создав файл .commitsage/config.json в корне проекта. Это позволяет разным проектам иметь разные провайдеры ИИ, форматы коммитов или другие настройки.
Старый одиночный файл .commitsage всё ещё поддерживается и автоматически мигрируется в .commitsage/config.json при следующей активации расширения.
Создание конфигурации проекта
- Откройте палитру команд (
Ctrl+Shift+P / Cmd+Shift+P)
- Выполните "Commit Sage: Create Project Config (.commitsage)"
- Отредактируйте созданный
.commitsage/config.json с настройками для вашего проекта
Пример .commitsage/config.json:
{
"provider": {
"type": "gemini"
},
"commit": {
"commitLanguage": "russian",
"commitFormat": "conventional",
"autoCommit": false,
"autoPush": false
},
"gemini": {
"model": "auto"
},
"telemetry": {
"enabled": false
}
}
Приоритет настроек
Настройки загружаются в следующем порядке (более высокий приоритет переопределяет низкий):
- Настройки проекта (файл
.commitsage/config.json) - Наивысший приоритет
- Настройки рабочей области VS Code - Средний приоритет
- Глобальные настройки VS Code - Низший приоритет
Примечания
- Файл
.commitsage/config.json автоматически отслеживается на изменения
- Неверный JSON синтаксис покажет уведомление об ошибке
- API ключи по-прежнему управляются через защищенное хранилище VS Code (не хранятся в файлах проекта)
- Вы можете переопределить любую настройку, доступную в конфигурации расширения
Поддержка
| |