We maintain styles, classes, bibliographies, and shared resources not available via the TeX distribution in repositories in our github organization.
To minimize conflicts when writing, we partition a document into several files,
usually
one header file, simply called paper.tex
(though other variants like main.tex
are also in use),
that imports
one file per section, along with possibly further files for figures, tables, programs and alike,
often gathered in corresponding folders (we suggest include/<name>
).
To this end, we provide a rough paper template for LaTeX that is also available when setting up a new repository.
We view a LaTeX document as source code and try to format it for readability. For instance, we start a new line with each sentence and sometimes break sentences into several lines to reflect their logical contents.
The set of LaTeX macros used in the Potassco book is available (but not in general use).
Our university guideline foresees that our First- and Lastname are followed by University of Potsdam. Unless required, we usually do not provide further details (after all there's Google).
We have created a slide template for presentations prepared with LaTeX' beamer style; this is also available when setting up a new repository.
Moreover, it comes with a submodule containing logos.
For collaborative writing we follow the feature branch workflow and use submodules for including styles, classes, bibliographies, or shared resources, as described below.
Best read the Pro Git book, at least the first chapters.
Do not copy styles, classes, bibliographies, or shared resources into a git repository.
Use Git submodules within your paper repositories, instead.
Conceptually, this means that Git will maintain a files from another repository within a subdirectory of your own repository (we suggest include/<name>
).
Git submodules are always locked to a specific commit. In other words, a submodule won’t automatically update itself, even when pulling in the latest changes of your paper repository. You’ll have to manually update the submodule whenever necessary.
On another note, never edit the content of the submodule directly, that is, within include/<name>
.
If you need modify the files in a submodule, clone it to a location outside of your paper repository and contribute from there.
Read more about Git submodules on the GitHub Blog and the in Pro Git book.
By default, the LaTeX toolchain won’t attempt to look for styles, classes, and bibliographies in subfolders.
If you build your paper with latexmk
(we can only recommend that), this can be easily solved.
Simply copy the .latexmkrc
file to the top level of your repository,
and LaTeX will automatically find any styles, classes, and bibliographies in the include
folder if you run with latexmk
:
$ latexmk -pdf paper.tex
If you do not use latexmk
, you need to set the following environment variables in your .bashrc
or LaTeX IDE instead:
export BIBINPUTS="./include//:"
export BSTINPUTS="./include//:"
export TEXINPUTS="./include//:"
Add the repository as a submodule to your paper repository as follows:
$ git submodule add ../<name> include/<name>
(Replace ../<name>
with https://github.com/krr-up/<name>
if your repository is hosted outside of the krr-up
organization.)
Next, commit and push the changes to make the submodule available to your coworkers. After your coworkers have pulled the change, they will need to execute the following command:
$ git submodule update --init --recursive
The submodule will now stay at the latest state of the master
branch at the time of adding it unless manually updated later on.
You can bring the latest changes to your paper repository as follows:
$ cd include/<name>
$ git fetch
$ git reset --hard origin/master
$ cd ../..
$ git add include/<name>
$ git commit -m "Update <name>"
$ git push
Finally, keep in mind that you need to run
$ git submodule update --init --recursive
every time one of the following happens:
- You clone your paper repository from scratch.
- Someone else updates the submodule to to a newer version.
- Files in
include/<name>
are missing or LaTeX complains about them. git status
tells youmodified: include/<name> (new commits)
and you didn’t expect this.- Someone else adds a new submodule to your paper repository.
- https://github.com/krr-up/bibliography
- https://github.com/krr-up/latex-style-comments
- https://github.com/krr-up/asp-macros
- https://github.com/krr-up/logos
For licensing reasons, we set the visibility of the following repositories to private: