Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/liffiton/code2tex
Convert source code to a LaTeX document / PDF with syntax highlighting and line numbers.
https://github.com/liffiton/code2tex
code-highlight syntax-highlighting
Last synced: 2 months ago
JSON representation
Convert source code to a LaTeX document / PDF with syntax highlighting and line numbers.
- Host: GitHub
- URL: https://github.com/liffiton/code2tex
- Owner: liffiton
- License: mit
- Created: 2011-01-22T21:32:58.000Z (almost 14 years ago)
- Default Branch: master
- Last Pushed: 2021-10-27T19:05:12.000Z (about 3 years ago)
- Last Synced: 2024-11-01T04:42:32.694Z (2 months ago)
- Topics: code-highlight, syntax-highlighting
- Language: Python
- Homepage:
- Size: 165 KB
- Stars: 26
- Watchers: 5
- Forks: 10
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- stars - liffiton/code2tex - Convert source code to a LaTeX document / PDF with syntax highlighting and line numbers. \[*MIT License*\] (⭐️26) (Python)
- stars - liffiton/code2tex - Convert source code to a LaTeX document / PDF with syntax highlighting and line numbers. \[*MIT License*\] (⭐️26) (Python)
README
# Code2Tex
Code2Tex was created to aid in grading programming assignments. It takes
source code and inserts it into a simple LaTeX document from which a PDF can be
made. This provides a document with syntax highlighting and clear headings for
each file that can be marked up and returned to the students.Syntax highlighting is provided via the
[listings](https://www.ctan.org/pkg/listings) LaTeX package. Not all languages
are currently supported; the list of included languages is in the [package
documentation](https://texdoc.org/serve/listings/0#page=13) (Javascript is a
notable exception, but I have added support for the language thanks to [Gary
Hammock](https://github.com/ghammock/LaTeX_Listings_JavaScript_ES6)). For any
language that does not have syntax highlighting rules, the file will simply be
included as monospaced black text.## Alternatives
* [render50](https://cs50.readthedocs.io/render50/) - Developed for Harvard's
CS50 course. Solves the same problem with different tools.## Usage / Examples
Run `code2tex.py` followed by any number of filenames. It will output the
LaTeX document to standard out, which may be redirected to a file:./code2tex.py file [file [file [...]]] > output.tex
This will create `output.tex`, ready to pass to `pdflatex` or `xelatex`. For
example, if a student with user id "jsmith" submitted several java files:./code2tex.py jsmith*.java > jsmith.tex
pdflatex jsmith.texThis would create a PDF named `jsmith.pdf` containing the contents of all
`jsmith*.java` files, nicely formatted with syntax highlighting and a separate
header for each.If you have UTF-8 characters in a filename or within an included file, use
`xelatex` in place of `pdflatex` for better unicode handling. The output may
look better if you have the `lmodern` package installed as well. This should
work for Latin characters, but non-Latin characters may still render
incorrectly within a file listing.Wildcards and [brace
expansion](https://www.gnu.org/software/bash/manual/html_node/Brace-Expansion.html)
can be used to quickly grab files of multiple extensions from within a folder:./code2tex.py codefolder/*.{html,css,js} > code.tex
Or from multiple nested folders:
./code2tex.py codefolder/*/*.{html,css,js} > code.tex
See the `hello_worlds` folder for example output; `hello_world.tex` and
`hello_world.pdf` were created from the various "Hello, World!" programs in
that directory. The syntax highlighter recognizes a wide variety of
programming languages.### convert_all.py
To quickly convert all user submissions downloaded from a [Moodle](https://moodle.org/) or [Canvas](https://www.canvaslms.com/) assignment:
1. Use the "Download submissions" option in a Moodle or Canvas assignment and extract the resulting zip file.
2. run `convert_all.py ` where `` is the directory with the unzipped files.The script will attempt to create PDFs from all the files. It parses the
filenames constructed from Moodle and outputs PDFs named
"[Name]\_[ID]\_files.pdf".## Dependencies
The python scripts require Python 3 and have no other dependencies.
Producing a PDF of the LaTeX output requires LaTeX. Code2tex's output depends
on a few packages that are not always included by default in a LaTeX install;
in Ubuntu, for example, you'll need to install the following packages (along
with their dependencies):texlive-fonts-recommended
texlive-latex-extra
texlive-latex-extra-doc
texlive-math-extra
texlive-pictures-docInstall these with the following command:
sudo apt-get install texlive-fonts-recommended texlive-latex-extra texlive-latex-extra-doc texlive-math-extra texlive-pictures-doc
On other systems, you will need to find the correct packages. Look for
"[latex]-extra" and "math-extra" packages.## Marking up PDFs
Once you have a PDF, various software can be used to mark it up. I and my TAs
have had success with [PDF-XChange
Viewer](http://www.tracker-software.com/product/pdf-xchange-viewer), the best
free Windows software I've found for annotating PDFs. It has a wide range of
tools for creating text boxes, circling things, pointing with arrows, etc. In
Linux, [Xournal](http://xournal.sourceforge.net/) is a decent option. Please
let me know if you find other applications that work well for this.