In LaTeX there's an easy way to handle source code. Though it was difficult to figure out, once in place this requires no maintenance at all - no need to manually syntax highlight your code nor update any files other than the source code itself. Even more, you can even change the source code language and it won't even matter in the presentation.
Preliminars
You'll need "pygmentyze" which is provided by the package python-pygments:
apt-cache search pygment
python-pygments - syntax highlighting package written in Python
sudo apt-get install python-pygments
Using it is really easy, check the manpage. Anyway, I'm too lazy to generate the syntax highlighted document by hand, let's add it to the makefile.
Automating the source code generation
Let's beging by adding a "code" folder inside our project. We'll store there all the source code files, and having them in a separated folder will enable us to add a target in the makefile to automatically update the source code in the LaTeX file.
Remember the makefile from a couple of posts back? Let's add a target:
# Hack to make it work when foo.code => foo.code.tex
code/%.tex: code/%.* code/%.aux code/%.tex
@rm code/*.aux
$(MAKE) -C .
code/%.tex: code/%.*
pygmentize -f latex -O style='border=#000000,colorful,linenos=1' $< > $@
# Search each code file to format and include
CODE_FILES:=$(shell ls code/|egrep -v '.tex$ |.aux$ ' )
CODE_FILES_DEP:=$(addprefix code/, $(CODE_FILES))
CODE_FILES_TGT:=$(addsuffix .tex, $(basename $(CODE_FILES_DEP)))
main.pdf: $(shell ls *.tex) $(CODE_FILES_TGT)
pdflatex main.tex > /dev/null
OK, maybe a couple more than one. It may seem like a lot of makefile code but all it does is define a code directory and a target to run pygmentize on each source file found there. We'll have to add a dependency in the document's target so it'll be automatically generated with each build:
main.pdf: code_frames *.tex
pdflatex main.tex && pdflatex main.tex
and then, we'll need to clean up the new temp files:
code_clean:
@rm -f $(CODE_FILES_TGT) code/*.aux
Don't worry, there's a link to the full makefile.
At last!
It shouldn't have been too much work and we're done anyway. To include a source code file in your document now use the include command (like include{code/foobar.cpp) and re build. I'm attaching a complete example in a zip file, with my latest implementation of a bogosort algorithm (now 50% faster).
You can use the package listings too.
ReplyDelete