diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile index d9bbae82892b26e8a8bf6dcd63cd3b421f15e66d..eb03f231ffd994161666115c1e2895896caef107 100644 --- a/.devcontainer/Dockerfile +++ b/.devcontainer/Dockerfile @@ -2,6 +2,8 @@ FROM registry.gitlab.com/lukenaylor/latex/sage-tex-chroma-image:latest # Add the tree-sitter parser for Rust RUN git clone --depth=1 --branch v0.20.4 https://github.com/tree-sitter/tree-sitter-rust.git /root/src/tree-sitter-rust +# Add the tree-sitter parser for Python +RUN git clone --depth=1 --branch v0.21.0 https://github.com/tree-sitter/tree-sitter-python /root/src/tree-sitter-python # Install the pseudowalls sage package RUN /usr/bin/bash -c ". ~/.bashrc; sage -pip install pseudowalls --extra-index-url https://gitlab.com/api/v4/projects/43962374/packages/pypi/simple" RUN /usr/bin/bash -c ". ~/.bashrc; sage -pip install pandas" diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 32e0ef6a4e76df879731e720c2c1515028a0a56d..40d6676e8e95904556ba1f1a4686cdc19fae3943 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -9,6 +9,7 @@ build: - echo $SHELL - source /root/.bashrc - git clone --depth=1 --branch v0.20.4 https://github.com/tree-sitter/tree-sitter-rust.git /root/src/tree-sitter-rust + - git clone --depth=1 --branch v0.21.0 https://github.com/tree-sitter/tree-sitter-python /root/src/tree-sitter-python - sage -pip install pseudowalls --extra-index-url https://gitlab.com/api/v4/projects/43962374/packages/pypi/simple - sage -pip install pandas script: diff --git a/.gitmodules b/.gitmodules index 13ace21200f245dd10a83a9c7c6bc751f72e9238..1a31441e6028c5cfab660a7aca9a18d861d5defb 100644 --- a/.gitmodules +++ b/.gitmodules @@ -19,3 +19,6 @@ [submodule "subprojects/intro-to-bridgeland-stability-parametrisations"] path = subprojects/intro-to-bridgeland-stability-parametrisations url = git@git.ecdf.ed.ac.uk:personal-latex-documents/research/intro-to-bridgeland-stability-parametrisations.git +[submodule "pseudowalls"] + path = pseudowalls + url = https://gitlab.com/pseudowalls/pseudowalls.git diff --git a/Makefile b/Makefile index 161ded272b7a633b16ec3e41a53229142e5fbaef..54cb13214fc56daa07b06e829c4e6e1b21f06d33 100644 --- a/Makefile +++ b/Makefile @@ -71,6 +71,19 @@ $(foreach _base, $(RUSTBASENAMES), $(eval $(call RUST_TO_TEX_RULE, $(_base)))) rust_tex: $(addsuffix .tex, $(RUSTBASENAMES)) +# TEX FILES FROM PYTHON +# +define PY_TO_TEX_RULE +$(1).tex: $(1).py + chromacode -r -i $(1).py -o $(1).tex +endef + +PYBASENAMES=$(basename $(shell find pseudowalls/src/pseudowalls/ -regex '.*\.py$$')) + +$(foreach _base, $(PYBASENAMES), $(eval $(call PY_TO_TEX_RULE, $(_base)))) + +py_tex: $(addsuffix .tex, $(PYBASENAMES)) + .PHONY: clean clean: latexmk -C diff --git a/pseudowalls b/pseudowalls new file mode 160000 index 0000000000000000000000000000000000000000..17e4163da4699e346d1e75353a68b1d1959fc43d --- /dev/null +++ b/pseudowalls @@ -0,0 +1 @@ +Subproject commit 17e4163da4699e346d1e75353a68b1d1959fc43d diff --git a/tex/appendix.tex b/tex/appendix.tex index 9496743364967f45363e5915b3b394afb004ddb8..4f242827092320b0f326423d30c51b7a8985da89 100644 --- a/tex/appendix.tex +++ b/tex/appendix.tex @@ -30,6 +30,17 @@ \rustlisting{../tilt.rs/src/}{tilt_stability/left_pseudo_semistabilizers/fixed_q_beta/fixed_r.tex} \rustlisting{../tilt.rs/src/}{tilt_stability/left_pseudo_semistabilizers/fixed_q_beta/fixed_r/bound_on_d.tex} +\chapter{Pseudowalls Computer Algebra Library} + +\pylisting{../pseudowalls/src/}{pseudowalls/integral_chern.tex} +\pylisting{../pseudowalls/src/}{pseudowalls/chern_character.tex} +\pylisting{../pseudowalls/src/}{pseudowalls/__init__.tex} +\pylisting{../pseudowalls/src/}{pseudowalls/integral_chern.tex} +\pylisting{../pseudowalls/src/}{pseudowalls/stability.tex} +\pylisting{../pseudowalls/src/}{pseudowalls/utils/__init__.tex} +\pylisting{../pseudowalls/src/}{pseudowalls/utils/stability_util.tex} +\pylisting{../pseudowalls/src/}{pseudowalls/utils/symb_util.tex} + \chapter{Jupyter Notebooks} \bgroup diff --git a/tex/chromalisting.lua b/tex/chromalisting.lua index 6e7e738427bc57f24d7f36d6f2ea370a3dd96a18..084cba603748617d25e5d9edfd413a2b5a1bb4d7 100644 --- a/tex/chromalisting.lua +++ b/tex/chromalisting.lua @@ -12,3 +12,16 @@ function rust_listing (dir, subpath) .. "]{" .. dir .. subpath .. "}" ) end +function py_listing (dir, subpath) + local module_name = subpath + :gsub(".tex$","") + :gsub("/","\\discretionary{}{.}{.}") + + local caption = "\\raggedleft \\texttt{" .. module_name .. "}" + + return ( + "\\lstinputlisting[" + .. "caption={" .. caption .. "}" + .. "]{" .. dir .. subpath .. "}" + ) +end diff --git a/tex/chromalisting.sty b/tex/chromalisting.sty index 02988613bd378928f66139c8a7ad500b674629e6..200ae6e9b12d2d04538fe21e05ed312f694f7790 100644 --- a/tex/chromalisting.sty +++ b/tex/chromalisting.sty @@ -5,3 +5,4 @@ private package for chromacode listings with automatically created captions \directlua{require("chromalisting.lua")} \newcommand\rustlisting[2]{ \directlua{tex.sprint(rust_listing("#1", "#2"))} } +\newcommand\pylisting[2]{ \directlua{tex.sprint(py_listing("#1", "#2"))} }