runcode
is a LaTeX package that executes programming source codes (including
all command line tools) from LaTeX, and embeds the results in the resulting pdf
file. Many programming languages can be easily used and any command-line
executable can be invoked when preparing the pdf file from a tex file. runcode
is also available on CTAN.
It is recommended to use this package in the server mode together with the Python talk2stat package. Currently, the server mode supports Julia, MatLab, Python, and R. More languages will be added.
You can simply put the runcode.sty file in the LaTeX project folder.The server mode requires the talk2stat package, and some chunk command (e.g.,
\showChunk
) requires the advance-touch package. To install them from the
command line, use:
pip3 install talk2stat advance-touch
Note: runcode
requires to enable the shell-escape
option when
compiling a LaTeX document.
\usepackage[options]{runcode}
Available options are:
cache
: use cached results.fvextra
: use the fvextra package to show code.julia
: start server for Julia (requires talk2stat).listings
: use the listings package to show code.matlab
: start server for MatLab (requires talk2stat).minted
: use the minted package to show code (requires the pygments package). This is the default option.nominted
: use the fvextra package instead of the minted package to show code (this does not require the pygments package, but it does not provide syntax highlights).nohup
: use thenohup
command when starting a server. When using the server-mode, some editors terminate all child processes after LaTeX compiling such as Emacs with Auctex. This option set the variable notnohup to be false, and the server will not be terminated by the parent process. This option has to be declared before declaring any language, e.g.,[nohup, R]
works but[R, nohup]
does not work.python
: start server for Python (requires talk2stat).run
: run source code.R
: start server for R (requires talk2stat).stopserver
: stop the server(s) when the pdf compilation is done.
Note: If minted is used, the style of the code block is controlled through the minted package, e.g.:
\setminted[julia]{linenos, frame=single, bgcolor=bg, breaklines=true}
\setminted[R]{linenos, frame=single, bgcolor=lightgray, breaklines=true}
Similarly, fvextra and listings packages can be customized through the \fvset
and \lstset
commands, respectively, e.g.:
\fvset{fontsize=\small, linenos=true, frame=single}
\lstset{basicstyle=\large, frame=single}
The outputs from executing codes are displayed in
tcolorbox, so the style can
be customized with \tcbset
,
e.g.:
\tcbset{breakable,colback=red!5!white,colframe=red!75!black}
\runExtCode{Arg1}{Arg2}{Arg3}[Arg4]
runs an external code.Arg1
is the executable program.Arg2
is the source file name.Arg3
is the output file name (with an empty value, the countercodeOutput
is used).Arg4
controls whether to run the code.Arg4
is optional with three possible values.- empty value or skipped: the value of the global Boolean variable
runcode
is used; run
: the code will be executed;cache
(or anything else): use cached results; if the output file does not exist, the cache option will be overridden and the code will run.
- empty value or skipped: the value of the global Boolean variable
\showCode{Arg1}{Arg2}[Arg3][Arg4]
shows the source code, using minted (requires pygments), fvextra, or listings.Arg1
is the programming language.Arg2
is the source file name.Arg3
is the first line to show (optional with a default value 1).Arg4
is the last line to show (optional with a default value of the last line).
\includeOutput{Arg1}[Arg2]
is used to embed the output from executed code.Arg1
is the output file name, and it needs to have the same value as that ofArg3
in\runExtCode
. If an empty value is given toArg1
, the countercodeOutput
is used.Arg2
is optional and it controls the type of output with a default valuevbox
.vbox
(or skipped) = verbatim in a box;tex
= pure latex;inline
= embed result in text.
\inln{Arg1}{Arg2}[Arg3][Arg4]
is designed for simple calculations; it runs one command (or a short batch) and displays the output within the text.Arg1
is the executable program or programming language.Arg2
is the source code.Arg3
is the output file name (optional);Arg4
is the output type and controls whether to run the code.inline
(or skipped or with empty value): embed result in text;vbox
: verbatim in a box;cache
or appending.cache
to the argument (e.g.,vbox.cache
) AND the output file inArg3
exists: the cached result will be used and the code will not run.
\showChunk{Arg1}{Arg2}[Arg3][Arg4]
prints a selected chunk from source code. The chunk is identified in the source code by two strings that define the beginning and end of the chunk. The default beginning islabel===<name>
where<name>
should be a unique user-defined chunk ID. The default end marker is===end
. In the code, these markers should appear after a comment character, so that the code will run.Arg1
is the programming language.Arg2
is the source file name.Arg3
is is the chunk identifier.Arg4
andArg5
are the beginning and end markings of a chunk (optional with defaultlabel==
and===end
.
\runCodeIncOut{Arg1}{Arg2}[Arg3][Arg4][Arg5]
runs an external code and embeds the output. This is a combination of\runExtCode
and\includeOutput
.Arg1
is the executable program.Arg2
is the source file name.Arg3
(optional) controls whether to run the code. Its functionality is the same as that ofArg4
of\runExtCode
.Arg4
(optional) is the output file name. Its functionality is the same as that ofArg3
of\runExtCode
.Arg5
(optional) controls the type of output with a default valuevbox
. Its functionality is the same as that ofArg3
of\includeOutput
.
Replace LANG
with Julia
, MatLab
, Python
, or R
, for the Julia, MatLab, Python, R
language, respectively, for the following commands.
\runLANG[Arg1]{Arg2}{Arg3}[Arg4]
runs an externalLANG
code file.Arg1
is optional and uses talk2stat’sLANG
server by default.Arg2
,Arg3
, andArg4
have the same effects as those of the basic command\runExtCode
.
\runLANGIncOut[Arg1]{Arg2}[Arg3][Arg4][Arg5]
runs an externalLANG
code file and embeds the output.Arg1
is optional and uses talk2stat’sLANG
server by default.Arg2
,Arg3
,Arg4
, andArg5
have the same effects as those of the command\runCodeIncOut
.
\inlnLANG[Arg1]{Arg2}[Arg3][Arg4]
runsLANG
source code (Arg2
) and displays the output in line.Arg1
is optional and uses theLANG
server by default.Arg2
is theLANG
source code to run. If theLANG
source code is wrapped between ”```
” on both sides (as in the markdown grammar), then it will be implemented directly; otherwise the code will be written to a file on the disk and then be called.Arg3
andArg4
have the same effects as those of the basic command\inln
.
\runLANGChunk[Arg1]{Arg2}{Arg3}[Arg4][Arg5][Arg6]
runs a selected chunk from an externalLANG
code file and embeds the output.Arg1
(optional ) uses talk2stat’sLANG
server by default.Arg2
is the source file name.Arg3
is is the chunk identifier.Arg4
(optional) controls whether to run the code.Arg5
(optional) is the output file name.Arg6
(optional) controls the type of output with a default valuevbox
.
For example,
\runR{code/MontyHall_1.R}{montyhall-R1}
\runRIncOut{code/MontyHall_1.R}[][montyhall-R1]
Specifically for Python,
\runPythonBatch[Arg1][Arg2]
runs an external Python code file in batch mode (without a server running). Python (at least currently), unlike the other languages we use, does not have an option to save and restore a session, which means that once a Python session ends, the working environement (variable, functions) is deleted. In order to allow a batch-mode in Python, we implemented such capability. It requires the dill module, which has to be installed viapip3 install dill
.Arg1
is the Python source file name,Arg2
is the output file name.
- v2.4, January 17, 2025: 1. put file names within $$ for more robust warnings; 2. use the python advance-touch package to create sub-folders for chunk related commands.
- v2.3, January 12, 2024: two bug fixes (1. removed an extra space after
\inlnX
; 2. when an underscore appeared inside R code, the tex file would compile with an error). - v2.2, September 8, 2023: add
\showChunk
basic command and\runLANGChunk
commands for multiple languages. - v2.1, June 30, 2023: detokenize code which is passed to
\inln
. This is necessary when the code contains special latex characters like backslash. These characters are escaped by latex when they are passed to macros as arguments, which, in the case of\inln
, alters the correct syntax and causes execution errors. Detokenizing ensures that the code is passed as-is to R/Julia/MatLab/Python. We thank kiryph for reporting the issue. - v2.0, June 23, 2023: add
\runCodeIncOut
command that runs an external code and embeds the output and andd some language specific shortcuts; update\runExtCode
so that if the output file does not exist, thecache
option will be overridden and the code will run; update\inln
so that itsArg4
acceptcache
or appending.cache
to use the cached result. We thank kiryph for suggesting these features. - v1.9, June 13, 2023: update
\inln
command; the optionalArg3
is the output file name and the optionalArg4
is the output type. - v1.8, January 18, 2023, add support to listings.
- v1.7, August 20, 2022: changed the tmp/ folder to generated/ in order to conform with CTAN suggestions; renamed the troubleshooting file.
- v1.6, August 10, 2022: stop only configured/running servers; a new reducedspace option - some document classes put more space after the code box; changed the default timeout of servers to 60 seconds; expanded the troubleshooting document. New examples are now available on GitHub, including how to collaborate with people who use Overleaf.
- v1.5, July 23, 2022: Removed the utf8x option when loading inputenc due to a conflict with hyperref.
- v1.4, July 18, 2022: Fixed a bug in the cache mode.
- v1.3, May 14, 2022: Removed the hard-coded minted options.
- v1.2, May 3, 2022: Added python options (server and batch).
- v1.1, April 17, 2021: Added a nohup option; improved error handling (missing code files, zero bytes in output files.)
runcode
.
Citing runcode
:
Haim Bar and HaiYing Wang (2021). Reproducible Science with LaTeX,
Journal of Data Science 2021; 19, no. 1, 111-125, DOI 10.6339/21-JDS998