Andersbakken/rtags@05117a9a29 -> Andersbakken/rtags@bd1c818a99 FStarLang/fstar-mode.el@7d353de892 -> FStarLang/fstar-mode.el@6e5d3ea858 JuliaEditorSupport/julia-emacs@2dfc869ff6 -> JuliaEditorSupport/julia-emacs@d360ad5285 ProofGeneral/PG@a38857a6a0 -> ProofGeneral/PG@99f91e873e Raku/raku-mode@977b14a7c1 -> Raku/raku-mode@14f9b9bba0 Wilfred/pip-requirements.el@216cd1690f -> Wilfred/pip-requirements.el@31e0dc62ab Wilfred/pyimport@c006a5fd0e -> Wilfred/pyimport@4398ce8dd6 ananthakumaran/exunit.el@e008c89e01 -> ananthakumaran/exunit.el@ee06b14b61 beancount/beancount-mode@546163fd2c -> beancount/beancount-mode@71c1622246 cybniv/poetry.el@ca2cffb0b1 -> cybniv/poetry.el@1dff0d4a51 davazp/graphql-mode@49a391b529 -> davazp/graphql-mode@ef4aecaead dgutov/robe@4ecd868da9 -> dgutov/robe@6bc8a07fc4 diml/utop@8cc5632825 -> diml/utop@384b3098c8 dominikh/go-mode.el@6f4ff9ef87 -> dominikh/go-mode.el@636d36e37a emacs-lsp/emacs-ccls@9b4a47e041 -> emacs-lsp/emacs-ccls@8648238a92 emacs-lsp/lsp-dart@f51c80f545 -> emacs-lsp/lsp-dart@1f52e81c93 emacs-lsp/lsp-haskell@89d1637043 -> emacs-lsp/lsp-haskell@18a7c7881f emacs-lsp/lsp-java@c962a3b3ac -> emacs-lsp/lsp-java@4909c14b90 emacs-lsp/lsp-metals@e55d544996 -> emacs-lsp/lsp-metals@fa4072cbe7 emacs-lsp/lsp-pyright@2f2631ae24 -> emacs-lsp/lsp-pyright@cc6df06aea emacs-lsp/lsp-sourcekit@1cd5e7d269 -> emacs-lsp/lsp-sourcekit@bb2b7e0278 emacs-lsp/lsp-treemacs@e54e74deb8 -> emacs-lsp/lsp-treemacs@1d43e9e030 emacs-php/composer.el@91945f1bdb -> emacs-php/composer.el@42cf9848d4 emacs-php/php-mode@a0bcafbe30 -> emacs-php/php-mode@4792988a12 emacs-php/phpactor.el@8733fef84b -> emacs-php/phpactor.el@6b5269ff82 emacs-php/psysh.el@c7dde979d9 -> emacs-php/psysh.el@ae15a36301 emacs-straight/adaptive-wrap@70005d2012 -> emacs-straight/adaptive-wrap@a3b179ea21 emacs-straight/auctex@86b2397abd -> emacs-straight/auctex@280cd4a0ca emacs-straight/csv-mode@81c1a9febd -> emacs-straight/csv-mode@cdb73a771b emacs-straight/sml-mode@e5354371f3 -> emacs-straight/sml-mode@d114e5a27f emacsorphanage/dart-mode@dffc0209a1 -> emacsorphanage/dart-mode@44beb628e5 erlang/otp@0ca7e064f5 -> erlang/otp@2a64588d4a factor/factor@12fc9d5071 -> factor/factor@d143007778 fosskers/sly-overlay@916b50297a -> fosskers/sly-overlay@4c6135c260 fsharp/emacs-fsharp-mode@b4d31c3da0 -> fsharp/emacs-fsharp-mode@677d78c4d6 gcv/julia-snail@a25ce84748 -> gcv/julia-snail@f7784c5007 godotengine/emacs-gdscript-mode@8a28276daa -> godotengine/emacs-gdscript-mode@32086df833 greghendershott/racket-mode@d3ab936af1 -> greghendershott/racket-mode@40ecb87f40 haskell/haskell-mode@43b4036bf0 -> haskell/haskell-mode@727f72a2a4 hhvm/hack-mode@278e4cc403 -> hhvm/hack-mode@ccf20511f0 idris-hackers/idris-mode@37c6b81990 -> idris-hackers/idris-mode@38dd2380dc joaotavora/sly@ed17d2c2bd -> joaotavora/sly@ba40c8f054 jrblevin/markdown-mode@e096bb97a9 -> jrblevin/markdown-mode@8aab017f47 json-emacs/json-mode@bfd1557aaa -> json-emacs/json-mode@77125b01c0 jwiegley/emacs-async@d040f72cb0 -> jwiegley/emacs-async@cff2bd0be3 ledger/ledger-mode@11e748d483 -> ledger/ledger-mode@b0e65f74a5 ljos/jq-mode@37028e1200 -> ljos/jq-mode@a0f79eba78 nonsequitur/inf-ruby@dac615c7fd -> nonsequitur/inf-ruby@0cfe8b2fb1 ocaml-ppx/ocamlformat@b8b0956690 -> ocaml-ppx/ocamlformat@c43f89bc0e ocaml/dune@64d19876ad -> ocaml/dune@aac3d84f1d ocaml/merlin@8404f96693 -> ocaml/merlin@b6ff2d4d56 pythonic-emacs/anaconda-mode@efd42aa873 -> pythonic-emacs/anaconda-mode@79fa9b4d2b pythonic-emacs/company-anaconda@dabc0adc9a -> pythonic-emacs/company-anaconda@1fe526163c pythonic-emacs/pyenv-mode@c93dc07e85 -> pythonic-emacs/pyenv-mode@de0d750b9c rust-lang/rust-mode@d8a09f218e -> rust-lang/rust-mode@d00d83d3a2 salmanebah/opencl-mode@15091eff92 -> salmanebah/opencl-mode@10ae7742d5 seagle0128/grip-mode@e145adb225 -> seagle0128/grip-mode@7c42b8f61d smihica/emmet-mode@63b6932603 -> smihica/emmet-mode@322d3bb112 swift-emacs/swift-mode@84059659de -> swift-emacs/swift-mode@b06c97b909 technomancy/fennel-mode@5965c8fc69 -> technomancy/fennel-mode@a4ddd1750f tpapp/julia-repl@4947319bc9 -> tpapp/julia-repl@801d0fc3d8 wbolster/emacs-python-pytest@bdfb3e81ee -> wbolster/emacs-python-pytest@9f850e22df yoshiki/yaml-mode@5b58248ab2 -> yoshiki/yaml-mode@7b5ce294fb
:lang latex
Description unfold
Provide a helping hand when working with LaTeX documents.
- Sane defaults
- Fontification of many popular commands
- Pretty indentation of wrapped lines using the doom-package:adaptive-wrap package
- Spell checking with doom-package:flycheck
- Change PDF viewer to Okular or doom-package:latex-preview-pane
- Bibtex editor
- Autocompletion using doom-package:company-mode
- Compile your
.tex
code only once using LatexMk
Maintainers
Module flags
- +cdlatex
- Enable doom-package:cdlatex for fast math insertion.
- +fold
- Use TeX-fold (from doom-package:auctex) to fold LaTeX macros to unicode, and make folding hook-based and less manual.
- +latexmk
- Use LatexMk instead of LaTeX to compile documents.
- +lsp
- Enable LSP support in latex buffers. Requires doom-module::tools lsp and a langserver (supports digestif and TexLab).
Packages
- doom-package:adaptive-wrap
- doom-package:auctex
- doom-package:auctex-latexmk if doom-module:+latexmk
- doom-package:cdlatex if doom-module:+cdlatex
- doom-package:evil-tex if doom-module::editor evil +everywhere
- doom-package:latex-preview-pane
-
if doom-module::completion company
TODO Hacks
This module's hacks haven't been documented yet. Document them?
TODO Changelog
This module does not have a changelog yet.
Installation
Enable this module in your doom!
block.
This module requires ghostscript and a latex compiler. These are provided by the
texlive
bundle, available through many OS package managers.
Ghostscript <= 9.27 is reportedly buggy and doesn't work with auctex's math previews. (You can check you ghostscript version with
$ gs --version
.) Most package managers already have newer versions, but if not you might have to build gs from source.
Ubuntu
apt-get install texlive
Arch Linux
pacman -S texlive-basic texlive-latexrecommended texlive-plaingeneric
TODO macOS
brew install --cask basictex
# If the above doesn't work, then
brew install --cask mactex # WARNING: large 4gb download!
This has not been verified.
NixOS
environment.systemPackages = [ pkgs.texlive.combined.scheme-medium ];
Formatter
Formatting is handled using the doom-module::editor format module via latexindent.
TODO Usage
This module has no usage documentation yet. Write some?
Configuration
Specifying the location of a bibtex file & corresponding PDFs
Reftex has a variable that allow you to specify where it should find your bibliography file(s):
;; in $DOOMDIR/config.el
(setq reftex-default-bibliography "/your/bib/file.bib")
Changing the PDFs viewer
This module provides integration for four supported pdf viewers. They are
- Skim.app (MacOS only)
- Evince
- Sumatra PDF
- Zathura
- Okular
- pdf-tools (requires doom-module::tools pdf module)
They are searched for in this order. See +latex-viewers
to change the order,
or remove tools from the search altogether. If you want to exclusively use one
tool, for instance:
;; in $DOOMDIR/config.el
(setq +latex-viewers '(zathura))
If none of these tools are found, latex-preview-pane
(uses DocView
in Emacs)
is used as a fallback. You can use this exclusively by setting +latex-viewers
to nil
.
Using cdlatex's snippets despite having yasnippet
doom-package:cdlatex has a snippet insertion capability which is disabled in favor of doom-package:yasnippet when using doom-module::editor snippets. If you still wanna use it, simply rebind the TAB key for cdlatex, which takes care of snippet-related stuff:
;; in $DOOMDIR/config.el
(map! :map cdlatex-mode-map
:i "TAB" #'cdlatex-tab)
This would favor yasnippet's expansion and cursor movement over cdlatex's expansion and movement, but that shouldn't matter if you're not using yasnippet in latex buffers.
Troubleshooting
There are no known problems with this module. Report one?
Frequently asked questions
This module has no FAQs yet. Ask one?
TODO Appendix
This module has no appendix yet. Write one?