Skip to content

Commit

Permalink
Merge branch 'makefile' into master
Browse files Browse the repository at this point in the history
  • Loading branch information
alexpovel committed Oct 31, 2020
2 parents 80f6e76 + ecd2fb9 commit b4a9881
Show file tree
Hide file tree
Showing 3 changed files with 152 additions and 22 deletions.
8 changes: 4 additions & 4 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
## Generated PDF is not suitable for Git. We get our compiled PDF via CI anyway.

*.pdf
# Generated PDF is not suitable for Git. We get our compiled PDF via CI.
# Only ignore root level PDF, since images/vectors might be in PDF format.
/*.pdf

# Testing environment
testing.tex
Expand All @@ -19,7 +19,7 @@ dirty_directory/
*contourtmp*

# Automatically generated files by svg package:
images/vectors/svg-inkscape
**/svg-inkscape/*

## Core latex/pdflatex auxiliary files:
*.aux
Expand Down
36 changes: 18 additions & 18 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,11 @@ default:
# Override any entrypoint back to a naked shell so that job `script`s can be
# executed normally.
# See also: https://docs.gitlab.com/ee/ci/docker/using_docker_images.html#overriding-the-entrypoint-of-an-image
# Cannot use `make` as ENTRYPOINT even if all scripts used it: runner expects an
# entrypoint that accepts shell scripts ("the runner expects that the image has
# no entrypoint or that the entrypoint is prepared to start a shell command. ")
# See also:
# https://docs.gitlab.com/ee/ci/docker/using_docker_images.html#overriding-the-entrypoint-of-an-image
entrypoint: [ "" ]
# LaTeX and pandoc stages both provide PDFs:
artifacts:
Expand All @@ -19,28 +24,23 @@ default:
# only:
# - tags

preflight:
stage: .pre
script:
- make preflight
# Preflight checks are relevant, but we are interested in how exactly later jobs
# error out if preflight fails. Therefore, allow failure.
allow_failure: true
inherit:
# Do not inherit artifacts, this stage has none.
default: [image]

build_latex:
stage: build
script:
# For debugging: show commands that will be used for compilation, as configured
# after reading all found config (RC) files.
# Looks like: https://tex.stackexchange.com/a/311753/120853
- latexmk --commands
# No *.tex-file given as argument to latexmk: run on all *.tex-files found in root.
# Configure latexmk tool using '.latexmkrc' in project root.
# After the run, display the relevant rules (for debugging).
- latexmk --rules
- make tex

build_pandoc:
stage: build
variables:
README_BASENAME: "README"
script:
# Provide dynamic metadata for the date. All other settings are in the `defaults`
# file.
- |
pandoc \
--defaults=pandoc/defaults.yaml \
--metadata=date:$(date --iso-8601) \
--output=${README_BASENAME}.pdf \
${README_BASENAME}.md
- make README.pdf
130 changes: 130 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,130 @@
# =====================================================================================
# =====================================================================================
# Prerequisites
# =====================================================================================
# =====================================================================================

# The following are "special targets", see:
# https://www.gnu.org/software/make/manual/html_node/Special-Targets.html#Special-Targets
# A phony target: not a file, just some routine.
.PHONY: all clean mostlyclean tex preflight

# =====================================================================================
# Set variables, executables and their flags
# =====================================================================================

# Configure latexmk tool using '.latexmkrc' in project root, not in here.
LATEXMK = latexmk
LATEXMK_FLAGS =

PANDOC = pandoc
# For pandoc, provide dynamic metadata for the date (see below). Git short SHA works
# both in CI and locally. All other settings are in the `defaults` file.
PANDOC_FLAGS = --defaults=pandoc/defaults.yaml

# GitLab CI defines variables that we can check for. This allows us to detect if we're
# in a CI scenario.
# See also:
# https://www.gnu.org/software/make/manual/html_node/Conditional-Syntax.html#Conditional-Syntax
# https://docs.gitlab.com/ee/ci/variables/predefined_variables.html
ifdef CI
GIT_SHORT_SHA = $$CI_COMMIT_SHORT_SHA
# pandoc is quiet by default
PANDOC_FLAGS += --verbose
# After the run, display the relevant rules (for debugging)
LATEXMK_FLAGS += --rules
else
# latexmk is verbose by default
GIT_SHORT_SHA = $(shell git rev-parse --short HEAD)
LATEXMK_FLAGS += --quiet
endif

PANDOC_FLAGS += --metadata=date:"$(shell date --iso-8601) ($(GIT_SHORT_SHA))"

# =====================================================================================
# =====================================================================================
# Files to build
# =====================================================================================
# =====================================================================================

# Produce all found tex files.
tex_sources = $(wildcard *.tex)
tex_pdfs := $(tex_sources:.tex=.pdf)

# First rule is what is run by default if just using `make` with no arguments.
# It is the 'goal': https://www.gnu.org/software/make/manual/html_node/Goals.html.
# The name `all` is just a convention.
# Change suffix of multiple different extensions (.tex, .md), to the same suffix (.pdf).
# See also: https://stackoverflow.com/a/33926814
all: preflight tex README.pdf
# A rule for only LaTeX files:
tex: $(tex_pdfs)

# =====================================================================================
# Rules for file building
# =====================================================================================

# This Makefile uses implicit rules, see:
# https://www.gnu.org/software/make/manual/html_node/Implicit-Rules.html#Implicit-Rules
# For those, Automatic Variables are important:
# https://www.gnu.org/software/make/manual/html_node/Automatic-Variables.html
# $*: "The stem with which an implicit rule matches"
# $<: "The name of the first prerequisite"
# $@: "The file name of the target of the rule"
# $^: "The names of all the prerequisites, with spaces between them"

# Pattern rule, see:
# https://www.gnu.org/software/make/manual/html_node/Pattern-Rules.html,
# Just sets up an implicit rule to specify how to get from prerequisite to target,
# called whever `make` detects it needs to do so. No need to specify things manually.
%.pdf: %.tex
$(info Running $(LATEXMK) to build $@...)
@$(LATEXMK) $(LATEXMK_FLAGS) $<

PANDOC_TEMPLATE = $(strip $(shell grep "^template:" pandoc/defaults.yaml | cut --delimiter=":" --field=2)).latex
PANDOC_TEMPLATE_DIR = /usr/share/pandoc/data/templates

%.pdf: %.md $(PANDOC_TEMPLATE_DIR)/$(PANDOC_TEMPLATE)
$(info Running $(PANDOC) to build $@...)
@$(PANDOC) $(PANDOC_FLAGS) --output=$@ $<

EISVOGEL_ARCHIVE = Eisvogel.tar.gz

# The `$(info ...)` function gives out-of-order logging, while `echo` works with the
# `wget` progress display.
$(PANDOC_TEMPLATE_DIR)/$(PANDOC_TEMPLATE):
@echo "Template not found at $@, downloading..."
@wget --quiet --show-progress --no-clobber \
"https://github.com/Wandmalfarbe/pandoc-latex-template/releases/latest/download/${EISVOGEL_ARCHIVE}"
@echo "Extracting $(EISVOGEL_ARCHIVE)..."
@tar --extract --file=${EISVOGEL_ARCHIVE} eisvogel.tex
@echo "Moving template to $@. This is required for make to work reliably but requires sudo privileges."
@sudo mv eisvogel.tex $@

# =====================================================================================
# Help users install programs required for compilation and help debug.
# =====================================================================================
preflight:
@echo "Checking presence of required libraries..."
@ldconfig --print-cache | grep --silent "librsvg" || \
(echo "librsvg missing: required by pandoc to convert files containing SVGs."; exit 69)
@echo "Libraries OK."
# Output looks like: https://tex.stackexchange.com/a/311753/120853
@$(LATEXMK) --commands

# For target name, see: https://www.gnu.org/prep/standards/html_node/Standard-Targets.html
mostlyclean:
@echo "Removing generated and auxiliary files of all found TeX files..."
@$(LATEXMK) -C $(LATEXMK_FLAGS)
@echo "Remaining PDF files are (e.g. those generated by pandoc):"
@ls *.pdf 2>/dev/null || echo "None."
@echo "Removing all remaining PDF files..."
@$(RM) *.pdf
@echo "Removing downloaded pandoc archive, if any..."
@$(RM) $(EISVOGEL_ARCHIVE)

clean: mostlyclean
@echo "Removing all files ignored by git (.gitignore)..."
@git clean --force -xd
@echo "Removing pandoc template..."
@sudo $(RM) $(PANDOC_TEMPLATE_DIR)/$(PANDOC_TEMPLATE)

0 comments on commit b4a9881

Please sign in to comment.