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. To install it from the command line, use:
pip3 install talk2stat
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 thenohupcommand 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.Arg1is the executable program.Arg2is the source file name.Arg3is the output file name (with an empty value, the countercodeOutputis used).Arg4controls whether to run the code.Arg4is optional with three possible values.- empty value or skipped: the value of the global Boolean variable
runcodeis 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.Arg1is the programming language.Arg2is the source file name.Arg3is the first line to show (optional with a default value 1).Arg4is 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.Arg1is the output file name, and it needs to have the same value as that ofArg3in\runExtCode. If an empty value is given toArg1, the countercodeOutputis used.Arg2is 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.Arg1is the executable program or programming language.Arg2is the source code.Arg3is the output file name (optional);Arg4is 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;cacheor appending.cacheto the argument (e.g.,vbox.cache) AND the output file inArg3exists: 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.Arg1is the programming language.Arg2is the source file name.Arg3is is the chunk identifier.Arg4andArg5are 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\runExtCodeand\includeOutput.Arg1is the executable program.Arg2is the source file name.Arg3(optional) controls whether to run the code. Its functionality is the same as that ofArg4of\runExtCode.Arg4(optional) is the output file name. Its functionality is the same as that ofArg3of\runExtCode.Arg5(optional) controls the type of output with a default valuevbox. Its functionality is the same as that ofArg3of\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 externalLANGcode file.Arg1is optional and uses talk2stat’sLANGserver by default.Arg2,Arg3, andArg4have the same effects as those of the basic command\runExtCode.
\runLANGIncOut[Arg1]{Arg2}[Arg3][Arg4][Arg5]runs an externalLANGcode file and embeds the output.Arg1is optional and uses talk2stat’sLANGserver by default.Arg2,Arg3,Arg4, andArg5have the same effects as those of the command\runCodeIncOut.
\inlnLANG[Arg1]{Arg2}[Arg3][Arg4]runsLANGsource code (Arg2) and displays the output in line.Arg1is optional and uses theLANGserver by default.Arg2is theLANGsource code to run. If theLANGsource 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.Arg3andArg4have the same effects as those of the basic command\inln.
\runLANGChunk[Arg1]{Arg2}{Arg3}[Arg4][Arg5][Arg6]runs a selected chunk from an externalLANGcode file and embeds the output.Arg1(optional ) uses talk2stat’sLANGserver by default.Arg2is the source file name.Arg3is 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.Arg1is the Python source file name,Arg2is the output file name.
- 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
\showChunkbasic command and\runLANGChunkcommands 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
\runCodeIncOutcommand that runs an external code and embeds the output and andd some language specific shortcuts; update\runExtCodeso that if the output file does not exist, thecacheoption will be overridden and the code will run; update\inlnso that itsArg4acceptcacheor appending.cacheto use the cached result. We thank kiryph for suggesting these features. - v1.9, June 13, 2023: update
\inlncommand; the optionalArg3is the output file name and the optionalArg4is 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