Local code completion with Ollama and Cody

Ado Kukic

Using AI coding assistants is a great way to improve your development workflows. But they typically require access to the Internet. This is a problem for developers who work in air-gapped environments or places with limited Internet access. We are building Cody, an AI coding assistant that has a deep understanding of your entire codebase to help you write and understand code faster.

A few months ago we added an experimental feature to Cody for Visual Studio Code that allows you to have local inference for code completion. This feature uses Ollama to run a local LLM model of your choice. Our developer community has been very excited about this feature and we wanted to officially write about it and show you how to use it.

Ollama - run LLMs locally

Ollama is a tool for running large language models (LLMs) locally. Ollama bundles model weights, configurations, and datasets into a unified package managed by a Modelfile.

Ollama

Ollama supports many different models, including Code Llama, StarCoder, DeepSeek Coder, and more. Ollama supports both general and special purpose models. Check out the full list here.

Getting started with Ollama

Ollama is a CLI tool that you can download and install for MacOS, Linux, and Windows. Head over to the download page and download the appropriate package for your operating system. Once you have downloaded and installed Ollama, verify that it is working by running the following command:

ollama --help

This should output the following:

Ollama help

Downloading LLMs

Now you are ready to download and install a LLM. To download a model, you can use the following command:

ollama pull <model-name>

For example, to download the codellama model, you would run the following command:

ollama pull codellama

You can also download a model from a specific version by specifying the parameter size:

ollama pull codellama:7b

Important Note: Your ability to run a model is heavily dependent on your hardware. The larger the model, the more resources you will need to succesfully run it.

Running LLMs locally

Once you have downloaded a model, you can run it locally by specifying the model name. For example, to run the codellama model, you would run the following command:

ollama run codellama

By default, Ollama will run the model directly in your terminal. Once the model is running, you can interact with it by typing in your prompt and pressing enter. For example, once the model is running in your terminal, you can type in the following prompt:

Write a JavaScript function that takes a string and returns the number of vowels in the string.

And press enter. Ollama will respond with an output like this:

Ollama terminal output

Ollama REST API

Ollama also provides a REST API that you can use to interact with your downloaded models. By default the REST API to generate completions is available at http://localhost:11434/api/generate. The REST API exposes a number of additional endpoints for chat, managing models, and more. You can find more information about the REST API here.

To use the REST API, you make a POST request to the /api/generate endpoint with the following JSON payload:

{
  "prompt": "Your prompt",
  "model": "The model that you want to use",
  "stream": false
}

The prompt field is the text you want to generate a completion for. The model field is the name of the model you want to use. There are additional parameters you can pass in such as stream, context, format, and others, but the only required parameters are the prompt and model fields.

Let's try it out! Let's make a POST request to the /api/generate endpoint with the following JSON payload:

{
  "prompt": "Write a Python function that takes a string and returns the number of vowels in the string.",
  "model": "codellama",
}

You can use a tool like Postman to make the request. Once you have the request set up, you can send it to the /api/generate endpoint and see the response.

Ollama from Postman

Local code completion with Ollama and Cody

Now that you have Ollama installed and running locally, you can use it with Cody to get local code completion. By default, Cody uses a remotely hosted version of the StarCoder LLM for code completion.

To switch the local code completion, you first need to install the Cody VS Code extension. Once you have the extension installed, you can configure it to use Ollama by following these steps:

  1. Navigate to the Cody extension settings by opening the command palette (āŒ˜+shift+P) and typing Cody: Extension Settings.
  2. Scroll down to find the "Cody > Autocomplete > Advanced: Provider" section. From the dropdown menu, select "expermintal-ollama". Cody extension settings
  3. Finally, open up the settings.json file and find the cody.autocomplete.experimental.ollamaOptions property. Here, you can specify the URL of the Ollama instance if different from the default, as well as the model you want to use. For example:
"cody.autocomplete.experimental.ollamaOptions": {
  "url": "http://localhost:11434",
  "model": "codellama"
}

Once you have done this, Cody will now use Ollama to get local code completion for your VS Code files. To verify that it is working, open the Output tab and switch it to Cody by Sourcegraph. Next, open a file and start typing. You should see the following message in the Output tab when a completion is generated:

Cody with Ollama in action

The above image shows that we are sending the prompt and context to Ollama. The response from Ollama is then sent back to Cody and displayed in the Output tab as well as reflected in the editor.

Now you can also try out other models by changing the model value in the cody.autocomplete.experimental.ollamaOptions setting. As soon as the settings.json file is saved, Cody will automatically update to use the new model. Happy experimenting!

Conclusion

With Ollama and Cody, you can now have local code completion. This is a great way to improve your development workflow whether you're trying new LLMs or catching a flight and lacking Internet access. As mentioned in the intro to this post, Ollama for Cody is still experimental and we are working on improving the experience and bringing you more features.

If you have any questions or feedback, please let us know by opening an issue on our GitHub repository and if you haven't already, give Cody a try yourself!

Get Cody, the AI coding assistant

Cody makes it easy to write, fix, and maintain code.