- 
                Notifications
    You must be signed in to change notification settings 
- Fork 22
3. Configuration files
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:
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.
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
- OdooLS attempts to auto detect the Odoo path from one of your workspace folders, provided that odoo_pathis not set in your configuration.
- For Addons paths, this is also the case if addons_paths. However, ifaddons_pathsto 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$autoDetectAddonsto your list ofaddons_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_pathswith 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_stubswith parent profile | "merge" | 
| refresh_mode | "onSave"|"adaptive"|"off" | When to refresh the server data: 
 | "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}
This section will explain how to create and combine multiple configuration files and profiles.
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:
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.
Now that most of the features of configuration files has been explained, let's demonstrate the usage through an example.
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
[[config]]
name = "base_setup"
file_cache = false
odoo_path = "./community"[[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 !
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:
[[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.
[[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.
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:
[[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
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
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, ...
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"
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