Boost LaTeX typesetting efficiency with preview, compile, autocomplete, colorize, and more.
Go to file
2022-02-16 13:43:36 +09:00
.devcontainer Install pygments and minted [skip ci] 2022-02-16 13:43:36 +09:00
.github Use actions/cache v2 2022-01-09 10:27:29 +09:00
.vscode Rename sample to samples [skip ci] 2022-02-16 11:39:57 +09:00
data Add a third-party license notice. [skip ci] 2022-02-01 08:39:46 +09:00
demo_media Add demo for surrounding text with autocompletion 2020-11-26 12:21:16 +01:00
dev Use https://github.com/jlelong/LaTeX-cwl 2022-01-03 22:04:19 +01:00
icons Icon by @trevorgunn 2019-11-04 23:03:12 +08:00
resources [skip ci] edit resources/snippetview/README.md 2021-12-23 10:57:58 +09:00
samples Install pygments and minted [skip ci] 2022-02-16 13:43:36 +09:00
scripts Do not echo commands in .bat scripts 2019-12-28 22:09:31 +01:00
snippets Fix #3024. Add MSF snippet for mathsf 2021-12-29 07:19:05 +01:00
src Log platform and arch 2022-02-15 12:37:59 +09:00
syntax Update grammar files to jlelong/vscode-latex-basics@b98c2d491 2022-01-19 17:12:55 +01:00
test Merge pull request #3008 from tamuratak/improve_pdfviewer_6 2021-12-25 21:19:44 +09:00
types/mathjax-full - Migrate to MathJax v3.2 2021-11-16 07:17:59 +09:00
viewer Update a link [skip ci] 2022-02-01 10:01:44 +09:00
.eslintignore Use vscode-extend-language to update grammars and language configurations 2021-12-24 12:20:29 +01:00
.eslintrc.json Stop using eslint-plugin-import 2021-11-20 08:24:30 +09:00
.gitignore Ignore *.vsix files. 2021-11-29 09:37:22 +09:00
.vscodeignore - Migrate to MathJax v3.2 2021-11-16 07:17:59 +09:00
CHANGELOG.md minor edit [skip ci] 2022-01-24 12:09:16 +09:00
CONTRIBUTING.md Use npm v8 2022-01-09 08:40:58 +09:00
LICENSE.txt Compose a README 2016-12-26 16:22:34 +08:00
package-lock.json Update packages: 2022-02-03 13:58:59 +09:00
package.json Update packages: 2022-02-03 13:58:59 +09:00
README.md Add a link to LaTeX tools [skip ci] 2022-01-19 09:36:06 +09:00
tsconfig.eslint.json Define a mixed latex markdown language 2021-09-21 09:26:55 +02:00
tsconfig.eslint.viewer.json Fix tsconfig.eslint.viewer.json. 2021-04-12 15:07:45 +09:00
tsconfig.json Set es2019 as target 2022-01-09 10:42:12 +09:00

Visual Studio Code LaTeX Workshop Extension

version downloads installs rating license

TeX Live on Windows TeX Live on macOS TeX Live on Linux

LaTeX Workshop is an extension for Visual Studio Code, aiming to provide core features for LaTeX typesetting with Visual Studio Code.

This project won't be successful without contributions from the community, especially from the current and past key contributors:

Thank you so much!

Note that the latest version of LaTeX-Workshop requires at least VSCode 1.62.0.

Manual

The manual of the extension is maintained as a wiki

Table of Contents

Features (Taster)

This is not a complete list but rather a preview of some of the coolest features.

  • Build LaTeX (including BibTeX) to PDF automatically on save.

    build process gif
  • View PDF on-the-fly (in VS Code or browser).

    demo of preview feature
  • Direct and reverse SyncTeX. Click to jump between location in .tex source and PDF and vice versa.

    demo of SyncTeX
  • Intellisense, including completions for bibliography keys (\cite{}) and labels (\ref{}).

    intellisense demo
  • LaTeX log parser, with errors and warnings in LaTeX build automatically reported in VS Code.

    error reporting demo
    • Linting
    auto \item demo
  • Snippets

    • A lot of LaTeX commands can be typed using snippets starting in \, then type part of the command to narrow the search.

      auto \item demo
    • Surround some selected text with a LaTeX command using ctrl+l, ctrl+w (+l, +w on Mac). A new menu pops up to select the command. This works with multi selections. The former approach using \ has been deprecated.

      wrap demo
    • We also provide a few other snippets mechanisms

      • Greek letters are obtained as @ + letter. Some letters have variants, which are available as @v + letter. See here.

        greek letters demo
      • Common environments can be obtained by BXY where XY are the first two letters of the environment name, eg. BEQ gives the equation environment. If you want the star version of the environment, use BSXX, eg. BSEQ gives the equation* environment. See here.

        BSAL demo
      • Common font commands can be obtained by FXY where XY are the last two letters of the font command name, eg. FIT gives \textit{}. See here.

        FBF demo
      • Many other maths symbols can be obtained with the @ prefix. See here.

        \frac shortcut demo \int shortcut demo
  • Shortcuts

    • In addition to snippets, there are shortcuts provided by the extension that allow you to easily format text (and one or two other things).

      \emph{} demo
  • When the current line starts with \item or \item[], hitting Enter automatically adds a newline starting in the same way. For a better handling of the last item, hitting Enter on a line only containing \item or \item[] actually deletes the content of the line. The alt+Enter is bind to the standard newline command. This automatic insertion of \item can be deactivated by setting latex-workshop.bind.enter.key to false.

    auto \item demo
  • Preview on hover. Hovering over the start tag of a math environment causes a mathjax preview to pop up.

    equation hover demo

GitHub

The code for this extension is available on github at: https://github.com/James-Yu/LaTeX-Workshop

Like this work?

License

MIT