Go to file
2024-09-03 10:29:27 +02:00
.github/workflows Initial commit 2024-08-27 11:58:55 +02:00
providers Move to get models by request to provider 2024-09-01 18:19:37 +02:00
resources/images Initial commit 2024-08-27 11:58:55 +02:00
templates Move instractoins out from FIM request 2024-09-01 12:06:55 +02:00
utils Add multiline insert support 2024-09-02 10:54:14 +02:00
.gitignore Initial commit 2024-08-27 11:58:55 +02:00
CMakeLists.txt Add multiline insert support 2024-09-02 10:54:14 +02:00
DocumentContextReader.cpp Move instractoins out from FIM request 2024-09-01 12:06:55 +02:00
DocumentContextReader.hpp Fix remove comments from request 2024-08-29 22:26:40 +02:00
LICENSE Initial commit 2024-08-27 11:36:28 +02:00
LLMClientInterface.cpp Move instractoins out from FIM request 2024-09-01 12:06:55 +02:00
LLMClientInterface.hpp Move instractoins out from FIM request 2024-09-01 12:06:55 +02:00
LLMProvidersManager.cpp Initial commit 2024-08-27 11:58:55 +02:00
LLMProvidersManager.hpp Initial commit 2024-08-27 11:58:55 +02:00
LLMSuggestion.cpp Add multiline insert support 2024-09-02 10:54:14 +02:00
LLMSuggestion.hpp Add multiline insert support 2024-09-02 10:54:14 +02:00
LSPCompletion.hpp Add multiline insert support 2024-09-02 10:54:14 +02:00
PromptTemplateManager.cpp Initial commit 2024-08-27 11:58:55 +02:00
PromptTemplateManager.hpp Initial commit 2024-08-27 11:58:55 +02:00
QodeAssist_en_001.ts Initial commit 2024-08-27 11:58:55 +02:00
qodeassist.cpp Add DeepSeekCoderV2 template 2024-08-31 23:20:23 +02:00
QodeAssist.json.in Move to get models by request to provider 2024-09-01 18:19:37 +02:00
QodeAssist.qrc Initial commit 2024-08-27 11:58:55 +02:00
QodeAssistClient.cpp Add multiline insert support 2024-09-02 10:54:14 +02:00
QodeAssistClient.hpp Add multiline insert support 2024-09-02 10:54:14 +02:00
QodeAssistConstants.hpp Move instractoins out from FIM request 2024-09-01 12:06:55 +02:00
QodeAssistData.hpp Move instractoins out from FIM request 2024-09-01 12:06:55 +02:00
QodeAssistSettings.cpp Move to get models by request to provider 2024-09-01 18:19:37 +02:00
QodeAssistSettings.hpp Move to get models by request to provider 2024-09-01 18:19:37 +02:00
QodeAssisttr.h Initial commit 2024-08-27 11:58:55 +02:00
QodeAssistUtils.hpp Fix typo in logs and settings 2024-08-29 09:27:50 +02:00
README.md Add troubleshooing chapter 2024-09-03 10:29:27 +02:00

QodeAssist

Build plugin

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.

Supported LLM Providers

QodeAssist currently supports the following LLM (Large Language Model) providers:

Supported Models

QodeAssist has been tested with the following language models, all trained for Fill-in-theMiddle:

Ollama:

LM studio:

Please note that while these models have been specifically tested and confirmed to work well with QodeAssist, other models compatible with the supported providers may also work. We encourage users to experiment with different models and report their experiences. If you've successfully used a model that's not listed here, please let us know by opening an issue or submitting a pull request to update this list.

Development Progress

  • Basic plugin with code autocomplete functionality
  • Improve and automate settings
  • Add chat functionality
  • Support for more providers and models

Plugin installation using Ollama as an example

  1. Install QtCreator 14.0
  2. Install Ollama. Make sure to review the system requirements before installation.
  3. Install a language model in Ollama. For example, you can run:
ollama run starcoder2:7b
  1. Download the QodeAssist plugin.
  2. 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 Plugin

  1. Open Qt Creator settings
  2. Navigate to the "Qode Assist" tab
  3. Choose your LLM provider (e.g., Ollama)
  4. Select the installed model by the "Select Model" button
    • For LM Studio you will see current load model
  5. Choose the prompt template that corresponds to your model
  6. Apply the settings

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

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 line by line, you can use the "Move cursor word right" shortcut:
    • On Mac: Option + Right Arrow
    • On Windows: Alt + Right Arrow

Troubleshooting

If you're 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. Click on the "Reset 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 cryptocurrency addresses:

    • 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.