Skip to content

Intellisense

Jerome Lelong edited this page Sep 13, 2021 · 84 revisions

Intellisense

This extension provides a variety of intellisense completions for different LaTeX features; notably for citations, labels, and file names. Intellisense suggestions are updated on file save but a more aggressive updating strategy can be used by setting intellisense.update.aggressive.enabled to true, which triggers update after no key has been stroked for the delay defined by latex-workshop.intellisense.update.delay.

Citations

Every file of a LaTeX project is parsed to look for bibliography resources, either directly in a thebibliography environment or given by the bibliography or addbibresource commands or variants of them. If some of these resources are located outside the project directly, you need to list the directories where to look for them in latex-workshop.latex.bibDirs. You can also rely on the kpsewhich command to resolve bibliography files by setting latex-workshop.kpsewhich.enabled to true.

Then, when citation commands like \cite and its derivatives are automatically completed with bibliography entries found in the various resources.

If you use very large bibtex files, you may experience temporary freezing. Hence, files larger than 5MB are ignored (see latex-workshop.intellisense.citation.maxfilesizeMB).

Setting key Description Default Type
latex-workshop.intellisense.citation.label Citation property used as suggestion "bibtex key" string: "bibtex key" | "title" | "authors"
latex-workshop.intellisense.citation.format List of fields to display array of strings
latex-workshop.intellisense.citation.maxfilesizeMB Maximum bibtex file size (in MB) 5 float
latex-workshop.intellisense.citation.type Type of vs code suggestion to use "inline" string: "inline" | "browser" (dropdown menu)
latex-workshop.intellisense.package.enabled Enabling of auto-completion for commands and environments from loaded packages false boolean
latex-workshop.latex.bibDirs List of paths to look for .bib files. [] array of strings
latex-workshop.kpsewhich.enabled Use kpsewhich to resolve .bib files. false boolean
latex-workshop.kpsewhich.path location of the kpsewhich executable file. "kpsewhich" string

References

Similarly as for the citation mechanism, all files of a LaTeX project are search for labels. We scan labels defined as \label{...} or label={...}. If you do prefer to ignore label={...}, set latex-workshop.intellisense.label.keyval to false.

Any \ref related command is automatically completed with label keys.

intellisense demo

Commands

The key \ automatically triggers completion of LaTeX commands. You can define additional triggers. Several mechanisms play together to build the list of available commands.

  • A set of standard LaTeX commands is provided in the file data/commands.json. You may overwrite some of these commands by using the latex-workshop.intellisense.commandsJSON.replace configuration variable.

  • The files of a LaTeX project are searched for any already used commands in the form mycommand followed by several {} groups. Then, a snippet is dynamically built for each of them and they are added to the command completion list.

  • When latex-workshop.intellisense.package.enabled is true, the command completion list is also populated with the commands provided by all the standard packages used in the project (through \usepackage). The list of commands provided by every package is described here. Note that homemade packages are ignored in this mechanism because they do not come with a .cwl file.

  • If you use personal macro files and want them to be taken into account by intellisense but store them in some texmf structure or dedicated directory. Just add the directory containing the file to latex-workshop.latex.texDirs. The file must be loaded in the LaTeX project through the \input macro.

  • If you write your own package along with the corresponding .cwl file, you can use the Python script pkgcommand.py

    python pkgcommand.py -i mypackage.cwl -o destdir
    

    You will find two files mypackage_cmd.json and mypackage_env.json in destdir containing intellisense data for command respectively environment completion. To enable the extension to load these files, add destdir to latex-workshop.intellisense.package.dirs. Note it only works when latex-workshop.intellisense.package.enabled is set to true.

  • The completion list can use either placeholders or tabstops. The default is to use tabstops, but it can be changed using latex-workshop.intellisense.useTabStops.enabled.

    • placeholders: they provide meaningful information on the arguments but prevent any autocompletion trigger.
    • tabstops: they enable us to directly trigger autocompletion again for citations and references.
  • We provide one entry in the intellisense completion list per LaTeX command signature. If you feel, it makes the completion list too long, set latex-workshop.intellisense.optionalArgsEntries.enabled to false.

Setting key Description Default Type
latex-workshop.intellisense.triggers.latex Additional trigger characters for intellisense of LaTeX documents. ["{"] array of strings
latex-workshop.intellisense.package.enabled Enabling of auto-completion for commands and environments from loaded packages true boolean
latex-workshop.intellisense.package.env.enabled Enable \envname snippets true boolean
latex-workshop.intellisense.package.extra Extra packages to load for intellisense [] array of strings
latex-workshop.intellisense.package.dirs Extra directories where to look for intellisense data [] array of strings
latex-workshop.intellisense.unimathsymbols.enabled Show unimath symbols as suggestions when \ pressed false boolean
latex-workshop.intellisense.useTabStops.enabled Use tabstops in intellisense completion true boolean
latex-workshop.intellisense.optionalArgsEntries.enabled Add one completion item per command signature true boolean
latex-workshop.latex.texDirs List of paths to look for input .tex files. [] array of strings

Environments

There are three different ways to insert a new environment

_ The \begin / \end snippet. Type \begin and autocomplete with Insert \begin / \end. It will leave you with a multi-cursor inside the braces of \begin{} and \end{} and a list of environments will pop up.

begin/end with multi-cursor demo
  • The \begin only approach. Type \begin and directly choose the environment name from the list. It will automatically add the closing command. Note that this approach enables us to take into account extra arguments. For instance, the alignat* environment takes the number of "equation columns" {n} as a mandatory argument. Note that dealing with extra arguments is not possible with the \begin / \end snippet.

    begin with options demo
  • The \envname approach. Standard environments can be inserted by typing \ followed by the environment name. This approach can deal with extra arguments

    \envname demo

Completion for environments is based on a set of predefined environments enriched with those defined by the included packages when latex-workshop.intellisense.package.enabled is true. Moreover, when latex-workshop.intellisense.package.env.enabled is also true, environments provided by used packages can be inserted by using the \envname approach. On top of this, any custom environment is added to the completion list after being used once.

Files

We support intellisense for file completion inside the following commands : include, includegraphics, input, and all the commands from the import package. For the includegraphics command, when some paths are defined by the \graphicspath command, only the files located under these directories are liste.

Note that any file matching one of the patterns listed in the following variables is removed from the list: files.exclude, latex-wokrshop.intellisense.file.exclude.

When latex-workshop.intellisense.includegraphics.preview.enabled is set to true, triggering graphics file completion shows a preview of the file. The preview of PDF files can be deactivated by setting latex-workshop.intellisense.includegraphics.preview.pdf.enabled to false.

Related settings

Configuration variables

latex-workshop.intellisense.includegraphics.preview.enabled

Enable preview for \includegraphics completion.

type default value
boolean true

latex-workshop.intellisense.includegraphics.preview.pdf.enabled

Enable preview for \includegraphics of PDF files.

type default value
boolean true

latex-workshop.intellisense.citation.label

Defines what to show as suggestion labels when intellisense provides citation suggestions.

  • bibtex key: Show bibtex keys in the inline intellisense.
  • title: Show publication titles in the inline intellisense.
  • authors: Show publication authors in the inline intellisense.
type default value
string "bibtex key"

latex-workshop.intellisense.citation.format

List of fields to display for citation preview and intellisense. You must reload VSCode to take into account a change in this configuration.

type default value
array of strings ["author", "title", "journal", "publisher", "booktitle", "year"]

latex-workshop.intellisense.citation.maxfilesizeMB

Define the maximum bibtex file size for the extension to parse in MB.

type default value
float 5

latex-workshop.intellisense.citation.type

Define which type of hint to show when intellisense provides citation suggestions.

  • inline: Use the inline intellisense to provide citation completion items.
  • browser: Use a dropdown menu to provide citation completion items.
type default value
string "inline"

latex-workshop.intellisense.triggers.latex

Additional trigger characters for intellisense of LaTeX documents. You must reload VSCode to take into account a change in this configuration.

type default value
array of strings ["{"]

latex-workshop.intellisense.package.enabled

Auto-complete commands and environments from used packages.

type default value
boolean true

latex-workshop.intellisense.package.extra

List of extra packages to always add to the auto-completion mechanism.

When latex-workshop.intellisense.package.enabled is set to true, the commands and environments defined in these extra packages will be added to the intellisense suggestions

type default value
array of strings []

latex-workshop.intellisense.package.dirs

List of extra directories to look for package completion files in addition to those provided by the extension.

See the section on Commands intellisense to learn how to generate these files. Files found in these directories have a higher priority over the default ones. This setting is only relevant when latex-workshop.intellisense.package.env.enabled is true.

type default value
array of strings []

latex-workshop.intellisense.package.env.enabled

If true, every environment provided by an included package is available by a snippet \envname. Only applies when latex-workshop.intellisense.package.enabled is true.

type default value
boolean true

latex-workshop.intellisense.optionalArgsEntries.enabled

Many LaTeX commands can have several signatures, each with different arguments. If set to True, the intellisense completion list will have one entry for each form of a given command.

type default value
boolean true

latex-workshop.intellisense.useTabStops.enabled

Use tabstops instead of placeholders in intellisense. Tabstops enable us to directly trigger autocompletion again (particularly useful for citations and references). On the contrary, placeholders prevent any direct call to autocompletion but they provide more information on the arguments meaning.

type default value
boolean true

Reload vscode after change.

latex-workshop.intellisense.label.keyval

Scan for labels defined as label={some tex} to add to the reference intellisense menu. The braces are mandatory.

type default value
boolean true

latex-workshop.intellisense.unimathsymbols.enabled

When \ is typed, show unimath symbols in the dropdown selector.

type default value
boolean false

latex-workshop.intellisense.commandsJSON.replace

Dictionary of "snippet name": "snippet action" to replace the default snippets in data/commands.json. Snippet actions should not begin with a \. See data/commands.json for the list of snippet names. An empty action removes the snippet. E.g. { "[": "[ ${1} \\]", "figure": "" }. Reload vscode to make any change in this configuration effective

type default value
dictionary of string: string {}

latex-workshop.latex.bibDirs

List of directories where to look for .bib files.

Absolute paths are required. This setting is only used by the intellisense feature, you may also need to set the environment variable BIBINPUTS properly for the LaTeX compiler to find the .bib files.

type default value
array of strings []

latex-workshop.kpsewhich.path

Define the location of the kpsewhich executable file.

type default value
string "kpsewhich"

latex-workshop.kpsewhich.enabled

Use kpsewhich -format=.bib to resolve bibliography files in addition to looking into the directories listed in latex-workshop.latex.bibDirs.

The ksepwhich executable is defined by latex-workshop.kpsewhich.path.

type default value
boolean false

latex-workshop.intellisense.file.exclude

Patterns to ignore in file completion

type default value
array of strings [ "**/*.aux", "**/*.bbl", "**/*.bcf", "**/*.blg", "**/*.idx", "**/*.ind", "**/*.lof", "**/*.lot", "**/*.out", "**/*.toc", "**/*.acn", "**/*.acr", "**/*.alg", "**/*.glg", "**/*.glo", "**/*.gls", "**/*.ist", "**/*.fls", "**/*.log", "**/*.fdb_latexmk", "**/*.synctex.gz", "**/*.run.xml" ]

latex-workshop.intellisense.file.base

Specify the base directory for file completion. The possible choices are

  • Completion from the root file directory
  • Completion from the current file directory
  • both
type default value
enum "root relative"|"file relative"|"both"

latex-workshop.intellisense.update.aggressive.enabled

Defines whether the extension aggressively parses the changed content after stopped typing.

Disable this config will let the extension only update intellisense after saving changed files.

type default value
boolean false

latex-workshop.intellisense.update.delay

Defines the delay in milliseconds for the extension to update current active file content for intellisense after stopped typing.

This config works only when intellisense.update.aggressive.enabled is enabled. Lower this value will let the extension to know newly defined commands/references/environments more quickly, at the cost of more frequent content parsing: more computation burden.

type default value
number 1000

BibTeX files

Two types of completion are available for BibTeX files

latex-workshop.intellisense.citation.backend

Backend to use for citation intellisense.

type default value possible values
enum "bibtex" "bibtex" | "biblatex"

latex-workshop.intellisense.biblatexJSON.replace

Dictionary of "entry name": ["array", "of", "fields"] to replace the default fields used in data/bibtex-entries.json.

This variable is used when latex-workshop.intellisense.citation.backend is set to biblatex. Reload vscode to make any change in this configuration effective.

type default value
dictionary of string: string {}

latex-workshop.intellisense.bibtexJSON.replace

Dictionary of "entry name": ["array", "of", "fields"] to replace the default fields used in data/bibtex-entries.json.

This variable is used when latex-workshop.intellisense.citation.backend is set to bibtex. Reload vscode to make any change in this configuration effective.

type default value
dictionary of string: string {}

Table of Contents

Clone this wiki locally