-
Notifications
You must be signed in to change notification settings - Fork 536
FAQ
- Known incompatible extensions
- Using LaTeX Workshop with WSL
- Problems with Snap and Flatpak versions of VS Code
- The PDF viewer is blank or has graphical glitches
- Cygwin is not supported
- code-server is not supported
- Gitpod is not supported
- Eclipse Theia is not supported
- Onivim 2 is not supported
- GitHub Codespaces is not supported
- github.dev is not supported
- VSCodium is not officially supported
- Code OSS on Arch Linux and Manjaro is not officially supported
- Visual Studio Live Share is not supported
- The directory ~/node_modules/ may cause errors
- I cannot build from a subfile
- The Problem Pane displays wrong messages
- Encoding issues with file names in the Problem Pane
- I cannot use
ctrl
+alt
in a shortcut - Auto build does not work sometimes
- Saving a
.cls
file does not trigger auto build - Suggestions for BibTeX files are not updated
- The internal PDF viewer is not updated
- Disable automatic build on save
- I use build on save but I occasionally want to save without building
- Auto build LaTeX results in always twice or infinite loop
- Large bibtex files are ignored
- Path containing Chinese or
~
characters - IME doesn't work well with LaTeX Workshop
- The LaTeX sidebar keeps reopening
- Spell check
- I cannot nest snippets
- Some
@
snippets are notTAB
completed - How to pass
-shell-escape
tolatexmk
- LaTeX-Workshop shadows vscode's default keybindings
- Syntax Highlighting does not work for most elements
- Install an older version of LaTeX Workshop
- Donwgrade VS Code to an older version
- Customizing a Color Theme
- Move the structure view and others to other places
- Overriding snippets
- Where can I find the definitions of the placeholders
- Autocompletion for
\includegraphics
seems incomplete - Environment variables in
.bashrc
don't take effect with VS Code Remote - Environment variables in
.zshrc
don't take effect with VS Code Remote - You cannot use a tilde
~
inPATH
terminal.integrated.shellArgs.linux
doesn't take effect- What kinds of LaTeX commands does Hover Preview support?
The following extensions are known to cause issues when active at the same time as LaTeX-Workshop
- Spell Right: high CPU load, Enter key delay
- Brackets Pair Colorizer 2: high CPU load, Enter key delay
- Prettify Symbols Mode: high CPU load, Enter key delay
- Path Autocomplete: it may break autocompletion for bibliography citations.
- Path Intellisense: it may break autocompletion for bibliography citations.
- LaTeX Preview: Conflict with LaTeX Workshop.
- LaTeX language support: It does not work with some LaTeX Workshop's snippets.
Starting with 1.35.0, VS Code supports WSL through Remote - WSL. LaTeX Workshop works well with the extension.
Also, in WSL2 file watchers might not work. For now, you have to set latex-workshop.latex.watch.usePolling
to true
, and restart VS Code. See https://github.com/microsoft/WSL/issues/4739 for more information about the issue. Alternatively, you can set latex-workshop.saveWithoutBuilding: onSave
to only trigger a build upon saving a file as it does not require file watchers to work.
These versions are sandboxed and are known to cause problems (e.g. here). We strongly recommend not using the snap and flatpack versions of VS Code. We strongly recommend using other installation options, like the .deb package for Debian/Ubuntu based distributions.
If the PDF viewer is blank or has graphical glitches, please try restarting VS Code with the option --disable-gpu
. See the official document, realted issue, and another issue.
LaTeX Workshop does not support TeX Live installed through Cygwin. Please install TeX Live and other TeX distributions independently of Cygwin.
LaTeX Workshop does not support code-server.
LaTeX Workshop does not support Gitpod.
LaTeX Workshop does not support Eclipse Theia.
LaTeX Workshop does not support Onivim 2.
LaTeX Workshop does not support GitHub Codespaces.
LaTeX Workshop does not support github.dev.
VSCodium is not officially supported. We do not help to resolve issues related to VSCodium.
Open-source builds of Visual Studio Code on Arch Linux and Manjaro are not officially supported. We do not help to resolve issues related to those builds. Please use the official binary distribution.
Visual Studio Live Share is not supported.
The directory ~/node_modules/
in the home directory may cause errors on Mac and Linux. The modules in the directory might be unintentionally loaded by VSCode because of the default behavior of node.js, which would cause errors such as Extension host terminated unexpectedly. We recommend moving the directory ~/node_modules/
to ~/npm/node_modules/
.
If you cannot build a multi file LaTeX project from a subfile, it means that the root file is not detected properly. See the Multi file projects section for details on how the root file is discovered. Note that you must open the directory (or one of its antecedents) containing all the project files in vscode for this mechanism to work.
LaTeX compilers usually produce hard wrapped log messages, which makes them really hard to parse. To hopefully deal with complex log messages, we have decided to rely on non hard wrapped log messages. This can be achieved either
- by setting the environment variable
max_print_line
. This is automatically done within the extension and works for the TeXLive distribution. - by adding the
--max-print-line
option to the compilers. This is automatically done within the extension and works for the MiKTeX distribution. Unfortunately, some compilers such aslualatex
do not understand this option and may therefore fail. To disable the automatic addition of this option, setlatex-workshop.latex.option.maxPrintLine.enabled
tofalse
.
Note that when log messages are hard wrapped, the Problems Pane is likely to be messed up.
If you experience encoding issues with file names displayed in the Problem Pane, you can try to set latex-workshop.message.convertFilenameEncoding
to false
.
The default shortcuts for commands related to build and view use the modifiers ctrl+alt. On some keyboard layouts, ctrl+alt is used to emulate AltrGr, which makes these shortcuts unusable. Alternatively, you can use ctrl+l, alt+letter instead of ctrl+alt+letter by setting latex-workshop.bind.altKeymap.enabled
to true
.
Please try setting latex-workshop.latex.watch.usePolling
to true
or setting latex-workshop.latex.autoBuild.run
to onSave
.
You must reload VSCode to take into account a change in this configuration.
You have to compile your project with latexmk
or manually pass -recorder
to your LaTeX compiler to produce a .fls
file. Then, LaTeX Workshop will use it to compute the exact list of included files. See Compile.
Please try setting latex-workshop.latex.watch.usePolling
to true
.
You must reload VSCode to take into account a change in this configuration.
Please try setting latex-workshop.latex.watch.usePolling
to true
.
You must reload VSCode to take into account a change in this configuration.
Set the configuration variable latex-workshop.latex.autoBuild.run
to "never"
.
When latex-workshop.latex.autoBuild.run
is set to onSave
, building is triggered every time a file is saved inside VSCode. If you want to save a file without building it, you can use the Save without Building
command from the Command Palette. A keybinding can be associated to the internal command latex-workshop.saveWithoutBuilding
to access this feature more easily.
There is a possibility that LaTeX Workshop detects changes on files by build scripts during the build process and starts a new build process. That results in unintended multiple build processes. See #2237 and #2487. In that case, please change the setting latex-workshop.latex.autoBuild.run
to "onSave"
.
Bibtex files listed in a project are parsed for citation completion. This may induce significant slow down with large bibtex files. You can configure the maximum size of bibtex files parsed by the extension with latex-workshop.intellisense.citation.maxfilesizeMB
.
On some platforms, when the path of a TeX file contains Chinese characters or other non-ASCII characters,
the compilation does not work well. In such cases, please use %DOCFILE%
instead of %DOC%
in your recipes. See also LaTeX recipes. Note that using relative paths instead of absolute ones may lead to other issues, see the following issues for a discussion on this: 1070 and 1137.
On some platforms, synctex
does not work well with the path containing non-ASCII characters either. In such cases, please use a built-in synctex
functionality.
See Viewing & Synctex.
Please try setting latex-workshop.bind.enter.key
to false
.
If you like to work with no sidebar in Visual Studio Code and yet the LaTeX sidebar keeps showing up each time you switch focus from a non TeX file to a TeX file, you need to set latex-workshop.view.autoFocus.enabled
to false
.
Code Spellchecker did a great job. Users may also find other extensions better alternatives, e.g., LanguageTool credited for its multi-lingual support.
Nesting snippets requires to have intellisense automatically triggered inside snippets. This can be achieved by setting editor.suggest.snippetsPreventQuickSuggestions
to false
.
This is mostly related to the editor.quickSuggestions
setting. The following value works well
"editor.quickSuggestions": {
"other": true,
"comments": false,
"strings": false
}
It is known that setting "other": false
will prevent some @
snippets from being TAB
expanded.
Some packages such as minted
requires LaTeX
compilers to use the -shell-escape
flag. Passing this flag can be achieved in several different ways.
-
Modify the section of
latex-workshop.latex.tools
related tolatexmk
in the following way"name": "latexmk", "command": "latexmk", "args": [ "-shell-escape", "-synctex=1", "-interaction=nonstopmode", "-file-line-error", "-pdf", "-outdir=%OUTDIR%", "%DOC%" ]
-
Directly specify
-shell-escape
in the compiler flag oflatexmk
. Modify the section oflatex-workshop.latex.tools
related tolatexmk
in the following way"name": "latexmk", "command": "latexmk", "args": [ "-synctex=1", "-interaction=nonstopmode", "-file-line-error", "-pdf", "-pdflatex=pdflatex -shell-escape %O %S", "-outdir=%OUTDIR%", "%DOC%" ]
-
Create a
.latexmkrc
config file (in your home directory or in the working directory) containing at least$pdflatex='pdflatex -shell-escape';
Since vscode 1.32.0, Ctrl+L has been set to expandLineSelection
. We define a new keybinding for expandLineSelection
: Ctrl+L, Ctrl+L.
vscode sets Ctrl+M to editor.action.toggleTabFocusMode
. We define a new keybinding for editor.action.toggleTabFocusMode
: Ctrl+L, Ctrl+M.
Please change VS Code theme you are using. For example, Visual Studio Dark and Visual Studio Light do not work with LaTeX Workshop.
You can install older versions of LaTeX Workshop by right-clicking it in the extension panel of VS Code and selecting Install Another Version
.
You can downgrade VS Code to an older version with binaries in each release note.
To customize a color theme, you can refer to the official documentation. The following is an example to make fonts black in math environment. Writing it in your settings.json
, you can enable that. To find an appropriate scope for each element in a TeX document, you can use the scope inspector of VS Code. Please refer to this document.
"editor.tokenColorCustomizations": {
"textMateRules": [
{
"scope": [
"support.class.math.block.environment.latex",
],
"settings": {
"foreground": "#000000"
}
}
]
}
You can move the structure view and others with dragging and dropping. See the release note. You can also hide the views in your right-click context menu. See the document.
You can override some snippets provided by the extension by using the latex-workshop.intellisense.commandsJSON.replace
configuration variable. Since VS Code v1.52, you can hide snippets. See the release note.
Autocompletion for includegraphics
takes into account the paths listed by the \graphicspath
command if any. In such a case, we only list the files located under these directories. See also the configuration variables referenced here
Use .bash_profile
or .profile
instead of .bashrc
. See superuser and the reference manual.
After editing these files, you have to kill vscode-server
on the remote host and restart it. Select Remote-SSH: Kill VS Code Server on Host...
from the Command Palette (F1).
Use .zshenv
or .zprofile
instead of .zshrc
. See stackexchange.
After editing these files, you have to kill vscode-server
on the remote host and restart it. Select Remote-SSH: Kill VS Code Server on Host...
from the Command Palette (F1).
You can not use a tilde ~
in the environment variable PATH
as an abbreviation of your home directory.
The setting terminal.integrated.shellArgs.linux
is not related to the environment variable on the extension host. You cannot set PATH
for LaTeX Workshop through the setting.
We implement Hover Preview with MathJax. Please see the following for LaTeX commands supported by MathJax:
Notice that MathJax does not support LaTeX packages.