Skip to content

ROCKTAKEY/lsp-latex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

https://img.shields.io/github/tag/ROCKTAKEY/lsp-latex.svg?style=flat-square https://img.shields.io/github/license/ROCKTAKEY/lsp-latex.svg?style=flat-square https://img.shields.io/github/actions/workflow/status/ROCKTAKEY/lsp-latex/CI.yml.svg?style=flat-square https://melpa.org/packages/lsp-latex-badge.svg

lsp-mode client for Texlab.

While lsp-tex.el, included by lsp-mode, provides minimal setting for Texlab, lsp-latex.el provides full features of Texlab v5.21.0.

How to Use?

  • First, you have to install Texlab. Please install this here.
  • Next, you should make lsp-mode available. See lsp-mode.
  • Now, you can use Language Server Protocol (LSP) on (la)tex-mode or yatex-mode just to evaluate this:
(add-to-list 'load-path "/path/to/lsp-latex")
(require 'lsp-latex)
;; "texlab" executable must be located at a directory contained in `exec-path'.
;; If you want to put "texlab" somewhere else,
;; you can specify the path to "texlab" as follows:
;; (setq lsp-latex-texlab-executable "/path/to/texlab")

(with-eval-after-load "tex-mode"
 (add-hook 'tex-mode-hook 'lsp)
 (add-hook 'latex-mode-hook 'lsp))

;; For YaTeX
(with-eval-after-load "yatex"
 (add-hook 'yatex-mode-hook 'lsp))

;; For bibtex
(with-eval-after-load "bibtex"
 (add-hook 'bibtex-mode-hook 'lsp))

Variables

lsp-latex-texlab-executable

Where Texlab server executable located.

lsp-latex-texlab-executable-argument-list

Argument list passed to Texlab server.

Others, provided by texlab server

These variables are connected to Texlab configuration variables. See also Texlab official wiki.

Custom variable in EmacsConfiguration provided by Texlab
lsp-latex-build-executabletexlab.build.executable
lsp-latex-build-argstexlab.build.args
lsp-latex-build-forward-search-aftertexlab.build.forwardSearchAfter
lsp-latex-build-on-savetexlab.build.onSave
lsp-latex-build-use-file-listtexlab.build.useFileList
lsp-latex-build-aux-directorytexlab.build.auxDirectory
lsp-latex-build-log-directorytexlab.build.logDirectory
lsp-latex-build-pdf-directorytexlab.build.pdfDirectory
lsp-latex-forward-search-executabletexlab.forwardSearch.executable
lsp-latex-forward-search-argstexlab.forwardSearch.args
lsp-latex-chktex-additional-argstexlab.chktex.additionalArgs
lsp-latex-chktex-on-open-and-savetexlab.chktex.onOpenAndSave
lsp-latex-chktex-on-edittexlab.chktex.onEdit
lsp-latex-diagnostics-delaytexlab.diagnosticsDelay
lsp-latex-diagnostics-allowed-patternstexlab.diagnostics.allowedPatterns
lsp-latex-diagnostics-ignored-patternstexlab.diagnostics.ignoredPatterns
lsp-latex-symbol-allowed-patternstexlab.symbol.allowedPatterns
lsp-latex-symbol-ignored-patternstexlab.symbol.ignoredPatterns
lsp-latex-bibtex-formatter-line-lengthtexlab.formatterLineLength
lsp-latex-bibtex-formattertexlab.bibtexFormatter
lsp-latex-latex-formattertexlab.latexFormatter
lsp-latex-latexindent-localtexlab.latexindent.local
lsp-latex-latexindent-modify-line-breakstexlab.latexindent.modifyLineBreaks
lsp-latex-latexindent-replacementtexlab.latexindent.replacement
lsp-latex-completion-matchertexlab.completion.matcher
lsp-latex-inlay-hints-label-definitionstexlab.inlayHints.labelDefinitions
lsp-latex-inlay-hints-label-referencestexlab.inlayHints.labelReferences
lsp-latex-inlay-hints-max-lengthtexlab.inlayHints.maxLength
lsp-latex-experimental-math-environmentstexlab.experimental.mathEnvironments
lsp-latex-experimental-enum-environmentstexlab.experimental.enumEnvironments
lsp-latex-experimental-verbatim-environmentstexlab.experimental.verbatimEnvironments
lsp-latex-experimental-citation-commandstexlab.experimental.citationCommands
lsp-latex-experimental-label-reference-commandstexlab.experimental.labelReferenceCommands
lsp-latex-experimental-label-definition-commandstexlab.experimental.labelDefinitionCommands
lsp-latex-experimental-label-reference-prefixestexlab.experimental.labelReferencePrefixes
lsp-latex-experimental-label-definition-prefixestexlab.experimental.labelDefinitionPrefixes

Build

lsp-latex-build

Request texlab to build .tex files. It use =latexmk= by default, so add .latexmkrc if you want to customize latex commands or options. You can change build command and option to other such as make, by changing lsp-latex-build-executable and lsp-latex-build-args.

This command build asynchronously by default, while it build synchronously with prefix argument(C-u).

Workspace commands

These commands are connected to Texlab Workspace commands. See also Texlab official wiki.

Custom variable in EmacsConfiguration provided by Texlab
lsp-latex-clean-auxiliarytexlab.cleanAuxiliary
lsp-latex-clean-artifactstexlab.cleanArtifacts
lsp-latex-change-environmenttexlab.changeEnvironment
lsp-latex-find-environmentstexlab.findEnvironments
lsp-latex-show-dependency-graphtexlab.showDependencyGraph
lsp-latex-cancel-buildtexlab.cancelBuild

lsp-latex-clean-auxiliary

This command removes LaTeX auxiliary files. It will run latexmk -c in the project.

lsp-latex-clean-artifacts

This command removes LaTeX auxiliary files and artifacts It will run latexmk -C in the project.

lsp-latex-change-environment

This command replaces enviroment name to NEW-NAME in current position. This edits most-inner environment containing the current position.

lsp-latex-find-environments

This function get list of environments containing the current point. Each element of the list is lsp-latex-environment-location instance. See the docstring of lsp-latex-environment-location.

lsp-latex-complete-environment

This function reads environment name from minibuffer and returns lsp-latex-environment-location instance.

It takes three arguments, BUFFER, POINT, PROMPT. PROMPT is used as prompt for consult--read, which is wrapper of completing-read. BUFFER and POINT specify basis to find environments.

lsp-latex-show-dependency-graph

Show dependency graph written by DOT format. =graphviz-dot-mode= is needed if you needs syntax highlights or a graphical image.

lsp-latex-cancel-build

This command request Texlab to cancel the proceeding build.

Commands with lsp-latex-complete-environment

lsp-latex-find-environments, which is interface for texlab.FindEnvironments, does nothing but returns list of environments. So this package provide some additional commands to utilize it.

lsp-latex-goto-environment

Go to selected environment containing the current point.

lsp-latex-select-and-change-environment

Change name of selected environment to NEW-NAME.

Forward/inverse search

Forward search and inverse search are available. See also Texlab official wiki.

Forward search

You can move from Emacs to current position on pdf viewer by the function lsp-latex-forward-search. To use, you should set lsp-latex-forward-search-executable and lsp-latex-forward-search-args according to your pdf viewer.

You can see Texlab official wiki, but you should replace some VSCode words with Emacs words. latex.forwardSearch.executable should be replaced with lsp-latex-forward-search-executable, and latex.forwardSearch.args with lsp-latex-forward-search-args. You should setq each variable instead of writing like json, and vector in json is replaced to list in Emacs Lisp. So the json:

{
       "texlab.forwardSearch.executable": "FavoriteViewer",
       "texlab.forwardSearch.args": [ "%p", "%f", "%l" ]
}

should be replaced with the Emacs Lisp code:

(setq lsp-latex-forward-search-executable "FavoriteViewer")
(setq lsp-latex-forward-search-args '("%p" "%f" "%l"))

In lsp-latex-forward-search-args, the string “%f” is replaced with “The path of the current TeX file”, “%p” with “The path of the current PDF file”, “%l” with “The current line number”, by Texlab (see Forward search arg section in Texlab official wiki).

For example of SumatraPDF, write in init.el:

(setq lsp-latex-forward-search-executable "C:/Users/{User}/AppData/Local/SumatraPDF/SumatraPDF.exe")
(setq lsp-latex-forward-search-args '("-reuse-instance" "%p" "-forward-search" "%f" "%l"))

while VSCode config with json (see Texlab official wiki) is:

{
  "texlab.forwardSearch.executable": "C:/Users/{User}/AppData/Local/SumatraPDF/SumatraPDF.exe",
  "texlab.forwardSearch.args": [
    "-reuse-instance",
    "%p",
    "-forward-search",
    "%f",
    "%l"
  ]
}

Then, you can jump to the current position on pdf viewer by command lsp-latex-forward-search.

Inverse search

You can go to the current position on Emacs from pdf viewer. Whatever pdf viewer you use, you should start Emacs server by writing in init.el:

(server-start)

Then, you can jump to line {{LINE-NUMBER}} in file named {{FILENAME}} with the command:

emacsclient +{{LINE-NUMBER}} {{FILENAME}}

{{LINE-NUMBER}} and {{FILENAME}} should be replaced with line number and filename you want to jump to. Each pdf viewer can provide some syntax to replace.

For example of SmatraPDF (see Texlab official wiki), “Add the following line to your SumatraPDF settings file (Menu -> Settings -> Advanced Options):”

InverseSearchCmdLine = C:\path\to\emacsclient.exe +%l %f

Then, “You can execute the search by pressing Alt+DoubleClick in the PDF document”.

Examples

These examples are according to Texlab official wiki. Especially, quoted or double-quoted sentences are citation from Texlab official wiki.

SumatraPDF

We highly recommend SumatraPDF on Windows because Adobe Reader locks the opened PDF file and will therefore prevent further builds.

Forward search

Write to init.el:

(setq lsp-latex-forward-search-executable "C:/Users/{User}/AppData/Local/SumatraPDF/SumatraPDF.exe")
(setq lsp-latex-forward-search-args '("-reuse-instance" "%p" "-forward-search" "%f" "%l"))

Inverse Search

Add the following line to your SumatraPDF settings file (Menu -> Settings -> Advanced Options):

InverseSearchCmdLine = C:\path\to\emacsclient.exe +%l "%f"

You can execute the search by pressing Alt+DoubleClick in the PDF document.

Evince

The SyncTeX feature of Evince requires communication via D-Bus. In order to use it from the command line, install the evince-synctex script.

Forward search

Write to init.el:

(setq lsp-latex-forward-search-executable "evince-synctex")
(setq lsp-latex-forward-search-args '("-f" "%l" "%p" "\"emacsclient +%l %f\""))

Inverse search

The inverse search feature is already configured if you use evince-synctex. You can execute the search by pressing Ctrl+Click in the PDF document.

Okular

Forward search

Write to init.el:

(setq lsp-latex-forward-search-executable "okular")
(setq lsp-latex-forward-search-args '("--unique" "file:%p#src:%l%f"))

Inverse search

Change the editor of Okular (Settings -> Configure Okular… -> Editor) to “Custom Text Editor” and set the following command:

emacsclient +%l "%f"

You can execute the search by pressing Shift+Click in the PDF document.

Zathura

Forward search

Write to init.el:

(setq lsp-latex-forward-search-executable "zathura")
(setq lsp-latex-forward-search-args '("--synctex-forward" "%l:1:%f" "%p"))

Inverse search

Add the following lines to your ~/.config/zathura/zathurarc file:

set synctex true
set synctex-editor-command "emacsclient +%{line} %{input}"

You can execute the search by pressing Alt+Click in the PDF document.

qpdfview

Forward search

Write to init.el:

(setq lsp-latex-forward-search-executable "qpdfview")
(setq lsp-latex-forward-search-args '("--unique" "%p#src:%f:%l:1"))

Inverse search

Change the source editor setting (Edit -> Settings… -> Behavior -> Source editor) to:

emacsclient +%2 "%1"

and select a mouse button modifier (Edit -> Settings… -> Behavior -> Modifiers -> Mouse button modifiers -> Open in Source Editor)of choice. You can execute the search by pressing Modifier+Click in the PDF document.

Skim

We recommend Skim on macOS since it is the only native viewer that supports SyncTeX. Additionally, enable the “Reload automatically” setting in the Skim preferences (Skim -> Preferences -> Sync -> Check for file changes).

Forward search

Write to init.el:

(setq lsp-latex-forward-search-executable "/Applications/Skim.app/Contents/SharedSupport/displayline")
(setq lsp-latex-forward-search-args '("%l" "%p" "%f"))

“If you want Skim to stay in the background after executing the forward search, you can add the -g option to” lsp-latex-forward-search-args.

Inverse search

Select Emacs preset “in the Skim preferences (Skim -> Preferences -> Sync -> PDF-TeX Sync support). You can execute the search by pressing Shift+⌘+Click in the PDF document.”

pdf-tools integration

If you want to use forward search with pdf-tools, follow the setting:

;; Start Emacs server
(server-start)
;; Turn on SyncTeX on the build.
;; If you use `lsp-latex-build', it is on by default.
;; If not (for example, YaTeX or LaTeX-mode building system),
;; put to init.el like this:
(setq tex-command "platex --synctex=1")

;; Setting for pdf-tools
(setq lsp-latex-forward-search-executable "emacsclient")
(setq lsp-latex-forward-search-args
      '("--eval"
        "(lsp-latex-forward-search-with-pdf-tools \"%f\" \"%p\" \"%l\")"))

Inverse research is not provided by Texlab, so please use pdf-sync-backward-search-mouse.

License

This package is licensed by GPLv3. See LICENSE.