DVT SystemVerilog IDE User Guide
Rev. 24.2.25, 31 October 2024

4.14 DVT Auto-Linked

Some of the files that DVT compiles for a project may be located outside the project directory (see What is a Project). In order to benefit from DVTs advanced functionalities on such files, they are automatically linked as if inside the project, under the <project_root>/DVT Auto-Linked virtual folder. A virtual folder is a logical container - it has no physical representation on the disk.

For example, a file physically located in:

/path/to/my/base/classes/file.ext

will be Auto-Linked under the following virtual folder hierarchy:

<project_root>
 `DVT Auto-Linked
   `path
     `to
       `my
         `base
           `classes
             `file.ext

You can create new files or open existing ones anywhere in the DVT Auto-Linked hierarchy.

For creating new files, you can use the New File Wizard. The files thus created will have a representation on the disk.

For opening existing files, you can right click on any folder in the DVT Auto-Linked hierarchy and select Open from the context menu. A File Chooser will appear that will help you find the file that you want.

In the case of very deep hierarchies, you can define "aliases" for paths using the +dvt_auto_link_root+<alias>=<root_path> directive. These aliases are called DVT Auto-Linked Roots.

For example by adding this line in the project's default.build:

+dvt_auto_link_root+base_classes=/path/to/my/base/classes/

the following virtual folder hierarchy is created:

<project_root>
 `DVT Auto-Linked
   `base_classes
     `file.ext

The specified <root_paths> and <aliases> must be unique, and therefore only the first occurrence is considered.

Aliases may not be names of directories located directly under the filesystem root (like for example /etc or /bin).

Environment variables may be used when specifying root paths, for example:

+dvt_auto_link_root+src=$HOME/a/b/c

Notes

  • An environment variable may only be used at the beginning of a root path (that is, the following will not work: +dvt_auto_link_root+src=/path/$VAR/a/b/c)

  • Only environment variables inherited from the console where DVT was started may be used. Variables defined using +dvt_setenv+ are not allowed.

  • The +dvt_auto_link_root+ directive may only be used in the first invocation

More examples:

+dvt_auto_link_root+hdl=/a/b/c

All auto-linked files with a path that starts with /a/b/c will be presented in DVT Auto Linked/hdl

+dvt_auto_link_root+hdl=/a/b/c
+dvt_auto_link_root+hdl/d/e/f

The second directive will be ignored because the same "hdl" alias was used.

+dvt_auto_link_root+hdl=/a/b/c
+dvt_auto_link_root+src=/a/b/c

The second directive will be ignored because the same "/a/b/c" path was used.

+dvt_auto_link_root+hdl=/a/b
+dvt_auto_link_root+src=/a/b/c

All files under /a/b/c will be presented under src and the rest from /a/b under hdl.