Povilas Kanapickas 61196cae90 chore: Run clang-format over the codebase (#82)
This commit is a result of the following commands:

clang-format-19 --style=file -i $(git ls-files | fgrep .cpp)
clang-format-19 --style=file -i $(git ls-files | fgrep .hpp)
2025-03-02 22:44:20 +01:00
2024-10-14 00:10:24 +02:00
2024-08-27 11:58:55 +02:00
2024-08-27 11:36:28 +02:00
2024-12-17 00:47:15 +01:00
2024-12-17 00:47:15 +01:00
2024-08-27 11:58:55 +02:00
2024-08-27 11:58:55 +02:00
2024-08-27 11:58:55 +02:00

QodeAssist - AI-powered coding assistant plugin for Qt Creator

Build plugin GitHub Downloads (all assets, all releases) GitHub Tag Static Badge

qodeassist-icon QodeAssist is an AI-powered coding assistant plugin for Qt Creator. It provides intelligent code completion and suggestions for C++ and QML, leveraging large language models through local providers like Ollama. Enhance your coding productivity with context-aware AI assistance directly in your Qt development environment.

⚠️ Important Notice About Paid Providers

When using paid providers like Claude, OpenRouter or OpenAI-compatible services:

  • These services will consume API tokens which may result in charges to your account
  • The QodeAssist developer bears no responsibility for any charges incurred
  • Please carefully review the provider's pricing and your account settings before use

⚠️ Commercial Support and Custom Development

The QodeAssist developer offers commercial services for:

  • Adapting the plugin for specific Qt Creator versions
  • Custom development for particular operating systems
  • Integration with specific language models
  • Implementing custom features and modifications

For commercial inquiries, please contact: qodeassist.dev@pm.me

Table of Contents

  1. Overview
  2. Install plugin to QtCreator
  3. Configure for Anthropic Claude
  4. Configure for OpenAI
  5. Configure for Mistral AI
  6. Configure for Google AI
  7. Configure for Ollama
  8. System Prompt Configuration
  9. File Context Features
  10. QtCreator Version Compatibility
  11. Development Progress
  12. Hotkeys
  13. Troubleshooting
  14. Support the Development
  15. How to Build

Overview

  • AI-powered code completion
  • Chat functionality:
    • Side and Bottom panels
    • Chat history autosave and restore
    • Token usage monitoring and management
    • Attach files for one-time code analysis
    • Link files for persistent context with auto update in conversations
    • Automatic syncing with open editor files (optional)
  • Support for multiple LLM providers:
    • Ollama
    • OpenAI
    • Anthropic Claude
    • LM Studio
    • Mistral AI
    • Google AI
    • OpenAI-compatible providers(eg. llama.cpp, https://openrouter.ai)
  • Extensive library of model-specific templates
  • Custom template support
  • Easy configuration and model selection

Join our Discord Community: Have questions or want to discuss QodeAssist? Join our Discord server to connect with other users and get support!

Code completion: (click to expand) QodeAssistPreview
Multiline Code completion: (click to expand) QodeAssistPreview
Chat with LLM models in side panels: (click to expand) QodeAssistChat
Chat with LLM models in bottom panel: (click to expand) QodeAssistBottomPanel
Automatic syncing with open editor files: (click to expand) OpenedDocumentsSync

Install plugin to QtCreator

  1. Install Latest Qt Creator
  2. Download the QodeAssist plugin for your Qt Creator
    • Remove old version plugin if already was installed
  3. Launch Qt Creator and install the plugin:
    • Go to:
      • MacOS: Qt Creator -> About Plugins...
      • Windows\Linux: Help -> About Plugins...
    • Click on "Install Plugin..."
    • Select the downloaded QodeAssist plugin archive file

Configure for Anthropic Claude

  1. Open Qt Creator settings and navigate to the QodeAssist section
  2. Go to Provider Settings tab and configure Claude api key
  3. Return to General tab and configure:
    • Set "Claude" as the provider for code completion or/and chat assistant
    • Set the Claude URL (https://api.anthropic.com)
    • Select your preferred model (e.g., claude-3-5-sonnet-20241022)
    • Choose the Claude template for code completion or/and chat
Example of Claude settings: (click to expand) Claude Settings

Configure for OpenAI

  1. Open Qt Creator settings and navigate to the QodeAssist section
  2. Go to Provider Settings tab and configure OpenAI api key
  3. Return to General tab and configure:
    • Set "OpenAI" as the provider for code completion or/and chat assistant
    • Set the OpenAI URL (https://api.openai.com)
    • Select your preferred model (e.g., gpt-4o)
    • Choose the OpenAI template for code completion or/and chat
Example of OpenAI settings: (click to expand) OpenAI Settings

Configure for Mistral AI

  1. Open Qt Creator settings and navigate to the QodeAssist section
  2. Go to Provider Settings tab and configure Mistral AI api key
  3. Return to General tab and configure:
    • Set "Mistral AI" as the provider for code completion or/and chat assistant
    • Set the OpenAI URL (https://api.mistral.ai)
    • Select your preferred model (e.g., mistral-large-latest)
    • Choose the Mistral AI template for code completion or/and chat
Example of Mistral AI settings: (click to expand) Mistral AI Settings

Configure for Google AI

  1. Open Qt Creator settings and navigate to the QodeAssist section
  2. Go to Provider Settings tab and configure Google AI api key
  3. Return to General tab and configure:
Example of Google AI settings: (click to expand) Google AI Settings

Configure for Ollama

  1. Install Ollama. Make sure to review the system requirements before installation.
  2. Install a language models in Ollama via terminal. For example, you can run:

For standard computers (minimum 8GB RAM):

ollama run qwen2.5-coder:7b

For better performance (16GB+ RAM):

ollama run qwen2.5-coder:14b

For high-end systems (32GB+ RAM):

ollama run qwen2.5-coder:32b
  1. Open Qt Creator settings (Edit > Preferences on Linux/Windows, Qt Creator > Preferences on macOS)
  2. Navigate to the "Qode Assist" tab
  3. On the "General" page, verify:
    • Ollama is selected as your LLM provider
    • The URL is set to http://localhost:11434
    • Your installed model appears in the model selection
    • The prompt template is Ollama Auto FIM or Ollama Auto Chat for chat assistance. You can specify template if it is not work correct
  4. Click Apply if you made any changes

You're all set! QodeAssist is now ready to use in Qt Creator.

Example of Ollama settings: (click to expand) Ollama Settings

System Prompt Configuration

The plugin comes with default system prompts optimized for chat and instruct models, as these currently provide better results for code assistance. If you prefer using FIM (Fill-in-Middle) models, you can easily customize the system prompt in the settings.

File Context Features

QodeAssist provides two powerful ways to include source code files in your chat conversations: Attachments and Linked Files. Each serves a distinct purpose and helps provide better context for the AI assistant.

Attached Files

Attachments are designed for one-time code analysis and specific queries:

  • Files are included only in the current message
  • Content is discarded after the message is processed
  • Ideal for:
    • Getting specific feedback on code changes
    • Code review requests
    • Analyzing isolated code segments
    • Quick implementation questions
  • Files can be attached using the paperclip icon in the chat interface
  • Multiple files can be attached to a single message

Linked Files

Linked files provide persistent context throughout the conversation:

  • Files remain accessible for the entire chat session
  • Content is included in every message exchange
  • Files are automatically refreshed - always using latest content from disk
  • Perfect for:
    • Long-term refactoring discussions
    • Complex architectural changes
    • Multi-file implementations
    • Maintaining context across related questions
  • Can be managed using the link icon in the chat interface
  • Supports automatic syncing with open editor files (can be enabled in settings)
  • Files can be added/removed at any time during the conversation

QtCreator Version Compatibility

  • QtCreator 15.0.1 - 0.4.8 - 0.5.x
  • QtCreator 15.0.0 - 0.4.0 - 0.4.7
  • QtCreator 14.0.2 - 0.2.3 - 0.3.x
  • QtCreator 14.0.1 - 0.2.2 plugin version and below

Development Progress

  • Basic plugin with code autocomplete functionality
  • Improve and automate settings
  • Add chat functionality
  • Sharing diff with model
  • Sharing project source with model
  • Support for more providers and models

Hotkeys

  • To call manual request to suggestion, you can use or change it in settings
    • on Mac: Option + Command + Q
    • on Windows: Ctrl + Alt + Q
  • To insert the full suggestion, you can use the TAB key
  • To insert word of suggistion, you can use Alt + Right Arrow for Win/Lin, or Option + Right Arrow for Mac

Troubleshooting

If QodeAssist is having problems connecting to the LLM provider, please check the following:

  1. Verify the IP address and port:

  2. Check the endpoint:

Make sure the endpoint in the settings matches the one required by your provider - For Ollama, it should be /api/generate - For LM Studio and OpenAI compatible providers, it's usually /v1/chat/completions

  1. Confirm that the selected model and template are compatible:

Ensure you've chosen the correct model in the "Select Models" option Verify that the selected prompt template matches the model you're using

If you're still experiencing issues with QodeAssist, you can try resetting the settings to their default values:

  1. Open Qt Creator settings
  2. Navigate to the "Qode Assist" tab
  3. Pick settings page for reset
  4. Click on the "Reset Page to Defaults" button
    • The API key will not reset
    • Select model after reset

Support the development of QodeAssist

If you find QodeAssist helpful, there are several ways you can support the project:

  1. Report Issues: If you encounter any bugs or have suggestions for improvements, please open an issue on our GitHub repository.

  2. Contribute: Feel free to submit pull requests with bug fixes or new features.

  3. Spread the Word: Star our GitHub repository and share QodeAssist with your fellow developers.

  4. Financial Support: If you'd like to support the development financially, you can make a donation using one of the following:

    • Bitcoin (BTC): bc1qndq7f0mpnlya48vk7kugvyqj5w89xrg4wzg68t
    • Ethereum (ETH): 0xA5e8c37c94b24e25F9f1f292a01AF55F03099D8D
    • Litecoin (LTC): ltc1qlrxnk30s2pcjchzx4qrxvdjt5gzuervy5mv0vy
    • USDT (TRC20): THdZrE7d6epW6ry98GA3MLXRjha1DjKtUx

Every contribution, no matter how small, is greatly appreciated and helps keep the project alive!

How to Build

Create a build directory and run

cmake -DCMAKE_PREFIX_PATH=<path_to_qtcreator> -DCMAKE_BUILD_TYPE=RelWithDebInfo <path_to_plugin_source>
cmake --build .

where <path_to_qtcreator> is the relative or absolute path to a Qt Creator build directory, or to a combined binary and development package (Windows / Linux), or to the Qt Creator.app/Contents/Resources/ directory of a combined binary and development package (macOS), and <path_to_plugin_source> is the relative or absolute path to this plugin directory.

For Contributors

QML code style: Preferably follow the following guidelines https://github.com/Furkanzmc/QML-Coding-Guide, thank you @Furkanzmc for collect them C++ code style: check use .clang-fortmat in project

qodeassist-icon qodeassist-icon-small

Description
No description provided
Readme GPL-3.0 4.6 MiB
Languages
C++ 90.7%
QML 8%
CMake 1.3%