Skip to content

3. Configuration files

Florian Daloze edited this page Sep 8, 2025 · 6 revisions

OdooLS is using (since 0.8.0) configuration files to detect your odoo setup and use right configuration variables according to your needs. This allow us way more flexibility than settings.json files from VsCode, and make them valid for any IDE, so they are sharable too. We wanted something that can be highly customizable, but easy to use. So depending to your needs, you'll find here 3 ways to use OdooLS configuration files:

No configuration file

That's right! OdooLS can now work without any configuration files. By default, when you open a workspace, it will try to search for an Odoo directory, and check if addons directories exist at root workspace folder. If yes, a 'default' setup is used, using this odoo and these addons paths.

Basic configuration file

The first option has of course some limitations: what if you only open an addons directory? Or if you want to change python environment? If the default behaviour do not fit your needs, you can create a configuration file, named odools.toml in your filesystem. Let's create it at the root folder of your current workspace for now. We will discuss configuration file locations later The content of the configuration file is following the TOML syntax. Here is a valid content of a configuration file:

[[config]]
name = "My Config"
odoo_path = "/home/odoo/community"

This configuration file, if found at the root of your workspace, will indicate to OdooLS that it should use the Odoo sources located at /home/odoo/community, even if another odoo is opened in vscode.

We can add addons paths too:

addons_paths = ["/home/odoo/enterprise"]

or even use dynamic paths:

addons_paths = ["${workspaceFolder}"]

Important: Having multiple workspace folders with the same name is not allowed, and the server will refuse to start in this case. Make sure your workspace folders have unique names through your client

Auto detection of Odoo and Addons paths

  • OdooLS attempts to auto detect the Odoo path from one of your workspace folders, provided that odoo_path is not set in your configuration.
  • For Addons paths, this is also the case if addons_paths. However, if addons_paths to any value, even if [], OdooLS does not try to auto detect. To ensure the auto detection of the addon paths from workspace folder, you can add $autoDetectAddons to your list of addons_paths. Example: addons_paths = ["/path/to/addons/path", ..., "$autoDetectAddons"].

In the odools.toml file, you can setup any setting of OdooLS. Here is a list of valid values:

Key Type / Values Description Default
name string Name of the configuration profile "default"
extends string (optional) Name of another profile in the same file to extend from
odoo_path string (optional) Path to the Odoo source code
addons_paths array of string List of addon directories to include
addons_merge "merge" | "override" How to combine addons_paths with parent profile "merge"
python_path string (optional) Path to the Python interpreter "python3"
additional_stubs array of string Additional stub directories
additional_stubs_merge "merge" | "override" How to combine additional_stubs with parent profile "merge"
refresh_mode "onSave" | "adaptive" | "off" When to refresh the server data:
  • onSave: when a file is saved
  • adaptive: depending of the cost of a rebuild, it could be instantly or delayed until a period of inactivity (see auto_refresh_delay)
  • off: never rebuild
"adaptive"
file_cache bool Enable file caching for workspace files true
diag_missing_imports "all" | "only_odoo" | "none" Diagnostics for missing imports "all"
ac_filter_model_names bool Only show model names from module dependencies in autocompletion true
auto_refresh_delay integer (min: 1000, max: 15000) Delay in ms before refreshing after an update (values outside this range will be clamped) 1000

When setting paths, you can use dynamic variables too: ${userHome}, ${workspaceFolder} or more specifically ${workspaceFolder:FOLDERNAME}

Advanced usage: multiple configuration files and profiles

This section will explain how to create and combine multiple configuration files and profiles.

Configuration files priority

To load configuration files, OdooLS will follow this sequence for each workspace folder:

  • load configuration file in the folder
  • search for another configuration file one folder above and load not already set variables

This allow you to create generic configuration file at a top level, like /home directory, and change various settings in some projects. But you can go further by using profiles:

Using profiles

When you write your configuration file, you can give a name to your set of variables. This will create a 'profile' that can be used in OdooLS. When opening your workspaces, if OdooLS find multiple profiles, you will be able to easily switch from one to another (see LINK on how to change your current profile according to your IDE) You can extend a profile too by using the keyword 'extends' followed by the name of a profile to indicate your are using this profile as a base for yours.

A complete example

Now that most of the features of configuration files has been explained, let's demonstrate the usage through an example.

File structure

The filesystem is filled with these files:

📁home/user/
├── 📄odools.toml
├── 📁community/
│   └── 📁other_odoo_files
└── 📁my_addons/
    ├── 📄odools.toml
    ├── 📁project_a
    |   └── 📁custom_module_1
    └── 📁project_b
        └── 📁custom_module_2

/home/user/odools.toml

[[config]]
name = "base_setup"
file_cache = false
odoo_path = "./community"

/home/user/my_addons/odools.toml

[[config]]
name = "project A"
extends = "base_setup"
addons_paths = ["./project_a"]

[[config]]
name = "project B"
extends = "base_setup"
addons_paths = ["./project_b"]

With this setup, when you open a directory like 'project_a', you can choose between the "project A" and "project B" profiles. You don't have to open the community folder anymore to get language server features.

However it means you have to select the right profile matching your current workspace (project_a or _b). We can even automatize that with this configuration:

[[config]]
name = "Current project"
extends = "base_setup"
addons_paths = ["${workspaceFolder}"]

With this file, each time you'll open a directory under my_addons, it will be loaded as an addon path of your odoo community, regardless its name !

Automatic Versioning

Version splitting

Let's go a little bit further now. Let's imagine you are working with different odoo versions, and you want to automatically detect them.

Here is a new filesystem example:

📁home/user/
├── 📄odools.toml
├── 📁community/
|   ├── 📁17.0
│   └── 📁18.0
└── 📁my_addons/
    ├── 📄odools.toml
    ├── 📁project_a
    |   ├── 📁17.0
    |   └── 📁18.0
    └── 📁project_b
        └── 📁18.0

Here, when we open project_a directory, we want it to load the directory as an addon of odoo 17, but odoo 18 for the project_b

There is two ways to achieve that. First, if the version is a directory name, we can set the special variable '$version' and use it in paths:

/home/user/odools.toml

[[config]]
name = "base_setup"
file_cache = false
"$version" = 18.0
odoo_path = "./community/${version}"

Note: The key "$version" is quoted because TOML keys containing special characters (like $) must be quoted. This is valid TOML syntax and allows the use of variable-like keys.

/home/user/my_addons/odools.toml

[[config]]
"$version" = "${workspaceFolder}/${splitVersion}"
# Note: The variable ${splitVersion} is a special placeholder that OdooLS will automatically resolve to the detected version number
# based on the directory structure or naming conventions in your workspace.
addons_paths = ["${workspaceFolder}/${version}"]

then if you open 'project_a', you will have two available profiles: "Current Project-17.0" and "Current Project-18.0". Depending on your choice, the corresponding Odoo will be chosen.

Version Detection and Base path variable

We also provide the $base variable, which you can use later to avoid repeating the same path prefix. In addition to that it supports adding a token ${detectVersion} at the end of it to detect the version from the current path.
Furthermore, it works by comparing the workspace folder full path, it should correspond with the prefix of $base, and then the first component after the match is used as the version, which you can use later in the config to allow you to open the workspace folder at multiple levels and get the same behavior.

Example:

Filesystem:

📁home/user/
├── 📄odools.toml
├── 📁 17.0/
|   ├── 📁odoo
│   └── 📁enterprise
├── 📁 18.0/
|   ├── 📁odoo
│   └── 📁enterprise
└── 📁my_addons/
    ├── 📄odools.toml
    ├── 📁project_a
    |   ├── 📁17.0
    |   └── 📁18.0
    └── 📁project_b
        └── 📁18.0

Config:

/home/user/odools.toml

[[config]]
name = "default"
file_cache = false
"$base" = "/home/user/${detectVersion}"
odoo_path = "${base}/odoo"
addons_paths = [
"${base}/enterprise",
"/home/user/my_addons/project_a/${version}",
]

In this case, you can open the workspace folder at /home/user/17.0/** or /home/user/18.0/** and it should work as you expect, it should find odoo, entreprise and project_a using our handy base and version variables.

Having both the version splitting and version detection ensure OdooLS satisfies the most common file structures and should make you need the least number of configuration files possible. Note: Version splitting and version detection cannot be combined as the behaviors are contradictory, in this case version splitting will take the precedence

Extra config file

We provide the option to set an extra config file that is at another path. You can do that by passing --config_path to the server if you are running it manually. Or from the extension setting in the VSCode client using the setting "Odoo.serverConfigPath" through the settings file or the user interface

Diagnostic Filters and customizations

It is possible to completely customize how diagnostics are generated and on which files. You can restrict them to some folders only, change their severity, ...

Diagnostic Filters

To a configuration, you can add as many filter as you want like that:

[[config]]
name = "odoob"
odoo_path = "${userHome}/odoo"

[[config.diagnostic_filters]]
codes = ["OLS.*"]
paths = ["**/my_folder_1/*", "**/account*/*]
path_type = "not_in"

A Diagnostic filter can have 4 keys: codes (list), types (list of strings), paths (list of strings) and path_type: string

A Filter is applied or not on each file of the project depending on the paths provided on it. The Path is described with a Pattern. You can use multiple patterns, separated by a comma. You can choose if the filter is applied to all files that match one of the pattern or that match none of the patterns with the path_type. The path_type can be in (by default) or not_in In our example, the filter is applied on any file that is not in my_folder_1 or in any module that starts with account. It means that diagnostics will be displayed only in these directories (my_folder_1 and account*)

On each file that has the diagnostic filter applied, diagnostics are blocked if the code is matching any provided regex in codes or has a type listed in types

You can find any codes of OdooLS here: https://github.com/odoo/odoo-ls/blob/master/server/src/core/diagnostic_codes_list.rs Valid types are "Error", "Warning", "Info" and "Hint"

Diagnostic Customization

It is possible to adapt text message and severity level of each diagnostic by using Diagnostic Settings. For a given code, you can change the description or the type

Clone this wiki locally