Liquid-LaTeX Jekyll Plugin

Another Jekyll plugin. This one renders and inserts arbitrary LaTeX content on your posts
jekyll
liquid tags
developing
ruby
plugin
latex
Autor/a

Fèlix

Publicat

10 de novembre de 2013

I’ve just finished my second Jekyll plugin: the jekyll-liquid-latex-plugin. This plugin for the Jekyll blogging software extends the rendering system allowing you to render \(\LaTeX\) pieces of code inside your post. The result will be an image placed instead of the block of \(\LaTeX\) code, so you don’t need to access any other software tool to compile \(\LaTeX\) inside your posts.

The plugin

You can access it’s source code, clone it and/or use it from Gitlab: https://gitlab.com/felix.galindo/jekyll-liquid-latex-plugin

This plugin is able to render \(\LaTeX\) block code as if you have a complete \(\LaTeX\) document. Instead of a full DVI, EPS, or PDF file, this plugin renders the \(\LaTeX\) block to PNG and inserts an <img> tag instead.

This, simply put, allows you to write this inside any of your posts:

{% latex %}
\begin{eqnarray*}
(A\cup B)-(C-A) &=& (A\cup B) \cap (C-A)^c\\
&=& (A\cup B) \cap (C \cap A^c)^c \\
&=& (A\cup B) \cap (C^c \cup A) \\
&=& A \cup (B\cap C^c) \\
&=& A \cup (B-C)
\end{eqnarray*}
{% endlatex %}

And you’ll get:

\[ \begin{eqnarray*} (A\cup B)-(C-A) &=& (A\cup B) \cap (C-A)^c\\ &=& (A\cup B) \cap (C \cap A^c)^c \\ &=& (A\cup B) \cap (C^c \cup A) \\ &=& A \cup (B\cap C^c) \\ &=& A \cup (B-C) \end{eqnarray*} \]

Another example:

{% latex density=72 %}
\begin{picture}(100,100)(0,0)
\setlength{\unitlength}{1pt}
\put(20,70){\circle{30}}  \put(20,70){\circle*{10}}   % left eye
\put(80,70){\circle{30}}  \put(80,70){\circle*{10}}   % right eye
\put(40,40){\line(1,2){10}} \put(60,40){\line(-1,2){10}} \put(40,40){\line(1,0){20}} % nose
\put(50,20){\oval(80,10)[b]} % mouth
\multiput(0,90)(4,0){10}{\line(1,3){4}}  % left eyebrow
\multiput(100,90)(-4,0){10}{\line(-1,3){4}}  % right eyebrow
\end{picture}
{% endlatex %}

And get this:

Result of the second example 

Another example, you write in your post:

{% latex density=100 usepackages=sudoku %}
\begin{sudoku}
| |2| | |3| |9| |7|.
| |1| | | | | | | |.
|4| |7| | | |2| |8|.
| | |5|2| | | |9| |.
| | | |1|8| |7| | |.
| |4| | | |3| | | |.
| | | | |6| | |7|1|.
| |7| | | | | | | |.
|9| |3| |2| |6| |5|.
\end{sudoku}
{% endlatex %}

The result will be this:

Result of the third example 

As you can see, this last example depends on the sudoku package to be installed in your system. If you are using TeXLive, you must install it if it’s not already there:

sudo tlmgr install sudoku

Installation

Just copy the liquid_latex.rb file to the _plugins folder.

Requirements

Obviously you must have a LaTeX installation of some kind (like TeXLive) and some additional software capable of transforming a EPS file to its corresponding PNG equivalent (like ImageMagick).

Configuration

There are several configuration parameters that you can define in your _config.yml. Here is a sample of such items:

# ...
# ... your _config.yml file ...
# ...

# Liquid-LaTeX plugin
liquid_latex:
    debug: false
    density: 300
    usepackages: pst-all,pst-3dplot
    output_directory: /res/latex
    latex_cmd: "latex -interaction=nonstopmode $texfile &> /dev/null"
    dvips_cmd: "dvips -E $dvifile -o $epsfile &> /dev/null"
    convert_cmd: "convert -density $density $epsfile $pngfile &> /dev/null"
    temp_filename: "latex_temp"

An explanation of those parameters follows:

_config.xml parameters for this plugin:

Parameter Type Value
debug boolean Activates the debug mode with which you can see the compilation commands that are executed during build. Default value: false
density numeric Density for the conversion of PostScript (EPS) to PNG. Default value:300
usepackages string Name of the packages (as a list of comma-separated) that will be passed globally to each block of \(\LaTeX\) code. They will be added individually to their corresponding \usepackage{...} lines in the temporary \(\LaTeX\) file. Default value: empty string (no packages)
output_directory string Path in which the generated PNG will be placed. Default value: /latex
temp_filename string Name of the temporary file that will be generated for the compilation process. Default value: latex_temp
latex_cmd string Command line to execute for the .tex to .div conversion. Default value: latex -interaction=nonstopmode $texfile &> /dev/null
dvips_cmd string Command line to execute for the .dvi to .eps conversion. Default value: dvips -E $dvifile -o $epsfile &> /dev/null
convert_cmd string Command line to execute for the .eps to .png conversion. Default value: convert -density $density $epsfile $pngfile &> /dev/null

In these last three parameters you can use the following variables:

Substitution variables for the command line configurations:

Variable Value
$texfile Name of the LaTeX temporary file
$dvifile Name of the DVI temporary file
$epsfile Name of the EPS temporary file
$pngfile Name of the generated PNG file
$density Density value that will be used by the conversion

This variables makes you able to choose which software you use for the whole conversion process. The sample shown above, as well as the default parameters, where defined for use with TeXLive and ImageMagick.

If you don’t use a certain parameter, it will take the default value. If you are happy with all the default values you can omit the whole liquid-latex section in your _config.xml.

Notes

  • The plugin doesn’t recompile a previously rendered block of \(\LaTeX\). It takes into consideration a change in the text or a change in the arguments (density and packages used). This reduces the total time of the building process.

    Aside, you can delete all the contents of your \(\LaTeX\) generated blocks in the source directory if you want to make a backup copy of your site. It will be completelly regenerated when you rebuild your site.

  • Also, this plugin keeps the folder of generated images in a clean state. That is, there will be only those images that are used in your site. All previously generated images will be deleted if they are detected as orphaned from the posts.

  • If you are trying to generate a picture with PSTricks, I recommend to insert the PSTricks code inside a TeXtoEPS environment. This ensures a perfect crop of the generated image.

    For example:

    {% latex density=72 usepackages=pst-all,pst-eps %}
    \begin{TeXtoEPS}
    \begin{pspicture}(0,0)(7,2)
    \psframe(0,0)(7,2) \psline(0,0)(7,2) \psline(7,0)(0,2)
    \end{pspicture}
    \end{TeXtoEPS}
    {% endlatex %}