From 95f23febe7a97aff8f852b194ceeaec6acf92ea0 Mon Sep 17 00:00:00 2001 From: Vincent Beffara Date: Sun, 25 Feb 2024 00:45:48 +0100 Subject: [PATCH] Setup blueprint --- .github/workflows/blueprint.yml | 92 +++++++++++++++++++++++++++++++++ blueprint/src/content.tex | 7 +++ blueprint/src/extra_styles.css | 25 +++++++++ blueprint/src/latexmkrc | 5 ++ blueprint/src/macros/common.tex | 3 ++ blueprint/src/macros/print.tex | 26 ++++++++++ blueprint/src/macros/web.tex | 5 ++ blueprint/src/plastex.cfg | 17 ++++++ blueprint/src/print.tex | 33 ++++++++++++ blueprint/src/web.tex | 27 ++++++++++ lake-manifest.json | 9 ++++ lakefile.lean | 8 ++- 12 files changed, 255 insertions(+), 2 deletions(-) create mode 100644 .github/workflows/blueprint.yml create mode 100644 blueprint/src/content.tex create mode 100644 blueprint/src/extra_styles.css create mode 100644 blueprint/src/latexmkrc create mode 100644 blueprint/src/macros/common.tex create mode 100644 blueprint/src/macros/print.tex create mode 100644 blueprint/src/macros/web.tex create mode 100644 blueprint/src/plastex.cfg create mode 100644 blueprint/src/print.tex create mode 100644 blueprint/src/web.tex diff --git a/.github/workflows/blueprint.yml b/.github/workflows/blueprint.yml new file mode 100644 index 0000000..8536a10 --- /dev/null +++ b/.github/workflows/blueprint.yml @@ -0,0 +1,92 @@ +on: + push: + branches: + - main + +# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages +permissions: + contents: read + pages: write + id-token: write + +jobs: + build_project: + runs-on: ubuntu-latest + name: Build project + steps: + - name: Checkout project + uses: actions/checkout@v2 + with: + fetch-depth: 0 + + - name: Install elan + run: curl https://raw.githubusercontent.com/leanprover/elan/master/elan-init.sh -sSf | sh -s -- -y --default-toolchain leanprover/lean4:4.5.0 + + - name: Update checkdecls + run: ~/.elan/bin/lake update checkdecls + + - name: Get cache + run: ~/.elan/bin/lake -Kenv=dev exe cache get || true + + - name: Build project + run: ~/.elan/bin/lake -Kenv=dev build RMT4 + + - name: Cache mathlib docs + uses: actions/cache@v3 + with: + path: | + .lake/build/doc/Init + .lake/build/doc/Lake + .lake/build/doc/Lean + .lake/build/doc/Std + .lake/build/doc/Mathlib + .lake/build/doc/declarations + !.lake/build/doc/declarations/declaration-data-RMT4* + key: MathlibDoc-${{ hashFiles('lake-manifest.json') }} + restore-keys: | + MathlibDoc- + + - name: Build documentation + run: ~/.elan/bin/lake -Kenv=dev build RMT4:docs + + - name: Build blueprint and copy to `docs/blueprint` + uses: xu-cheng/texlive-action@v2 + with: + docker_image: ghcr.io/xu-cheng/texlive-full:20231201 + run: | + apk update + apk add --update make py3-pip git pkgconfig graphviz graphviz-dev gcc musl-dev + git config --global --add safe.directory $GITHUB_WORKSPACE + git config --global --add safe.directory `pwd` + python3 -m venv env + source env/bin/activate + pip install --upgrade pip requests wheel + pip install pygraphviz --global-option=build_ext --global-option="-L/usr/lib/graphviz/" --global-option="-R/usr/lib/graphviz/" + pip install git+https://github.com/PatrickMassot/leanblueprint.git@client + leanblueprint pdf + mkdir docs + cp blueprint/print/print.pdf docs/blueprint.pdf + leanblueprint web + cp -r blueprint/web docs/blueprint + + - name: Check declarations + run: | + ~/.elan/bin/lake exe checkdecls blueprint/lean_decls + + - name: Move documentation to `docs/docs` + run: | + sudo chown -R runner docs + cp -r .lake/build/doc docs/docs + + - name: Upload docs & blueprint artifact + uses: actions/upload-pages-artifact@v1 + with: + path: docs/ + + - name: Deploy to GitHub Pages + id: deployment + uses: actions/deploy-pages@v1 + + - name: Make sure the cache works + run: | + mv docs/docs .lake/build/doc \ No newline at end of file diff --git a/blueprint/src/content.tex b/blueprint/src/content.tex new file mode 100644 index 0000000..b5cd27b --- /dev/null +++ b/blueprint/src/content.tex @@ -0,0 +1,7 @@ +% In this file you should put the actual content of the blueprint. +% It will be used both by the web and the print version. +% It should *not* include the \begin{document} +% +% If you want to split the blueprint content into several files then +% the current file can be a simple sequence of \input. Otherwise It +% can start with a \section or \chapter for instance. \ No newline at end of file diff --git a/blueprint/src/extra_styles.css b/blueprint/src/extra_styles.css new file mode 100644 index 0000000..b96c776 --- /dev/null +++ b/blueprint/src/extra_styles.css @@ -0,0 +1,25 @@ +/* This file contains CSS tweaks for this blueprint. + * As an example, we included CSS rules that put + * a vertical line on the left of theorem statements + * and proofs. + * */ + +div.theorem_thmcontent { + border-left: .15rem solid black; +} + +div.proposition_thmcontent { + border-left: .15rem solid black; +} + +div.lemma_thmcontent { + border-left: .1rem solid black; +} + +div.corollary_thmcontent { + border-left: .1rem solid black; +} + +div.proof_content { + border-left: .08rem solid grey; +} diff --git a/blueprint/src/latexmkrc b/blueprint/src/latexmkrc new file mode 100644 index 0000000..38d5963 --- /dev/null +++ b/blueprint/src/latexmkrc @@ -0,0 +1,5 @@ +# This file configures the latexmk command you can use to compile +# the pdf version of the blueprint +$pdf_mode = 1; +$pdflatex = 'xelatex -synctex=1'; +@default_files = ('print.tex'); \ No newline at end of file diff --git a/blueprint/src/macros/common.tex b/blueprint/src/macros/common.tex new file mode 100644 index 0000000..131c9f8 --- /dev/null +++ b/blueprint/src/macros/common.tex @@ -0,0 +1,3 @@ +% In this file you should put all LaTeX macros to be used +% both by the pdf version and the web version. +% This should be most of your macros. \ No newline at end of file diff --git a/blueprint/src/macros/print.tex b/blueprint/src/macros/print.tex new file mode 100644 index 0000000..0b59bae --- /dev/null +++ b/blueprint/src/macros/print.tex @@ -0,0 +1,26 @@ +% In this file you should put macros to be used only by +% the printed version. Of course they should have a corresponding +% version in macros/web.tex. +% Typically the printed version could have more fancy decorations. +% This should be a very short file. +% +% This file starts with dummy macros that ensure the pdf +% compiler will ignore macros provided by plasTeX that make +% sense only for the web version, such as dependency graph +% macros. + + +% Dummy macros that make sense only for web version. +\newcommand{\lean}[1]{} +\newcommand{\leanok}{} +% Make sure that arguments of \uses and \proves are real labels, by using invisible refs: +% latex prints a warning if the label is not defined, but nothing is shown in the pdf file. +% It uses LaTeX3 programming, this is why we use the expl3 package. +\ExplSyntaxOn +\NewDocumentCommand{\uses}{m} + {\clist_map_inline:nn{#1}{\vphantom{\ref{##1}}}% + \ignorespaces} +\NewDocumentCommand{\proves}{m} + {\clist_map_inline:nn{#1}{\vphantom{\ref{##1}}}% + \ignorespaces} +\ExplSyntaxOff \ No newline at end of file diff --git a/blueprint/src/macros/web.tex b/blueprint/src/macros/web.tex new file mode 100644 index 0000000..ceee975 --- /dev/null +++ b/blueprint/src/macros/web.tex @@ -0,0 +1,5 @@ +% In this file you should put macros to be used only by +% the web version. Of course they should have a corresponding +% version in macros/print.tex. +% Typically the printed version could have more fancy decorations. +% This will probably be a very short file. \ No newline at end of file diff --git a/blueprint/src/plastex.cfg b/blueprint/src/plastex.cfg new file mode 100644 index 0000000..de3dbae --- /dev/null +++ b/blueprint/src/plastex.cfg @@ -0,0 +1,17 @@ +[general] +renderer=HTML5 +copy-theme-extras=yes +plugins=plastexdepgraph plastexshowmore leanblueprint + +[document] +toc-depth=3 +toc-non-files=True + +[files] +directory=../web/ +split-level= 0 + +[html5] +localtoc-level=0 +extra-css=extra_styles.css +mathjax-dollars=False \ No newline at end of file diff --git a/blueprint/src/print.tex b/blueprint/src/print.tex new file mode 100644 index 0000000..a000cbe --- /dev/null +++ b/blueprint/src/print.tex @@ -0,0 +1,33 @@ +% This file makes a printable version of the blueprint +% It should include all the \usepackage needed for the pdf version. +% The template version assume you want to use a modern TeX compiler +% such as xeLaTeX or luaLaTeX including support for unicode +% and Latin Modern Math font with standard bugfixes applied. +% It also uses expl3 in order to support macros related to the dependency graph. +% It also includes standard AMS packages (and their improved version +% mathtools) as well as support for links with a sober decoration +% (no ugly rectangles around links). +% It is otherwise a very minimal preamble (you should probably at least +% add cleveref and tikz-cd). + +\documentclass[a4paper]{report} + +\usepackage{geometry} + +\usepackage{expl3} + +\usepackage{amssymb, amsthm, mathtools} +\usepackage[unicode,colorlinks=true,linkcolor=blue,urlcolor=magenta, citecolor=blue]{hyperref} + +\usepackage[warnings-off={mathtools-colon,mathtools-overbracket}]{unicode-math} + +\input{macros/common} +\input{macros/print} + +\title{RMT4} +\author{Vincent Beffara} + +\begin{document} +\maketitle +\input{content} +\end{document} \ No newline at end of file diff --git a/blueprint/src/web.tex b/blueprint/src/web.tex new file mode 100644 index 0000000..be10481 --- /dev/null +++ b/blueprint/src/web.tex @@ -0,0 +1,27 @@ +% This file makes a web version of the blueprint +% It should include all the \usepackage needed for this version. +% The template includes standard AMS packages. +% It is otherwise a very minimal preamble (you should probably at least +% add cleveref and tikz-cd). + +\documentclass{report} + +\usepackage{amssymb, amsthm, amsmath} +\usepackage{hyperref} +\usepackage[showmore, dep_graph]{blueprint} + + +\input{macros/common} +\input{macros/web} + +\home{https://vbeffara.github.io/RMT4} +\github{https://github.com/vbeffara/RMT4} +\dochome{https://vbeffara.github.io/RMT4/docs} + +\title{RMT4} +\author{Vincent Beffara} + +\begin{document} +\maketitle +\input{content} +\end{document} \ No newline at end of file diff --git a/lake-manifest.json b/lake-manifest.json index 17e0538..1bcdac4 100644 --- a/lake-manifest.json +++ b/lake-manifest.json @@ -99,6 +99,15 @@ "manifestFile": "lake-manifest.json", "inputRev": "main", "inherited": false, + "configFile": "lakefile.lean"}, + {"url": "https://github.com/PatrickMassot/checkdecls.git", + "type": "git", + "subDir": null, + "rev": "2ee81a0269048010900117b675876a1d8db5883c", + "name": "checkdecls", + "manifestFile": "lake-manifest.json", + "inputRev": null, + "inherited": false, "configFile": "lakefile.lean"}], "name": "rMT4", "lakeDir": ".lake"} diff --git a/lakefile.lean b/lakefile.lean index 5ff74aa..6790692 100644 --- a/lakefile.lean +++ b/lakefile.lean @@ -8,8 +8,6 @@ package «rMT4» { require mathlib from git "https://github.com/leanprover-community/mathlib4.git" -require «doc-gen4» from git "https://github.com/leanprover/doc-gen4" @ "main" - -- require LeanCopilot from git "https://github.com/lean-dojo/LeanCopilot.git" @ "v1.0.2" @[default_target] @@ -17,3 +15,9 @@ lean_lib RMT4 { -- add any library configuration options here -- moreLinkArgs := #["-L./.lake/packages/LeanCopilot/.lake/build/lib", "-lctranslate2"] } + +require checkdecls from git "https://github.com/PatrickMassot/checkdecls.git" + +meta if get_config? env = some "dev" then +require «doc-gen4» from git + "https://github.com/leanprover/doc-gen4" @ "main"