all: docs workspace crates
.PHONY: docs workspace crates
-# Documentation
+## Documentation
docs: $(DOCFILES)
.tmp/docs/%.rs: src/%.rs Makefile
@mkdir -p .tmp/docs
@echo "$< -> $@"
- @sed 's|^\(\s*//\)@|\1|;s|\s*/\*@\*/||' $< > $@
+ @# sed-fu: remove the "@" from "//@", and remove trailing "/*@*/".
+ @sed 's|^\(\s*//\)@|\1|;s|\s*/\*@\*/$$||' $< > $@
docs/%.html: .tmp/docs/%.rs
@./pycco-rs $<
-# Workspace
+## Workspace
+# The generated files are shipped only for the benefit of Windows users, who
+# typically don't have the necessary tools for generating the workspace
+# available.
workspace: $(WORKSPACEFILES)
workspace/src/%.rs: src/%.rs Makefile dup-unimpl.sed
@mkdir -p .tmp/docs
@echo "$< -> $@"
+ @# sed-fu: remove lines starting with "//@", and replace those ending in "/*@*/" by "unimplemented!()".
+ @# Also coalesce multiple adjacent such lines to one.
@sed '/^\s*\/\/@/d;s|\(\s*\)\S.*/\*@\*/|\1unimplemented!()|' $< | sed -f dup-unimpl.sed > $@
workspace/src/main.rs:
# Don't touch this file
-# Crates
+## Crates
crates: $(WORKSPACEFILES)
@cargo build
@cd solutions && cargo build
``docs/`` using ``make docs`` (this step needs Pycco_), or go directly to
`the rendered output`_.
+The files ``workspace/src/part*.rs`` are generated by ``make workspace``.
+
.. _Pycco: https://fitzgen.github.io/pycco/
.. _the rendered output: https://www.ralfj.de/projects/rust-101/main.html