nixpkgs/pkgs/applications/science/math/sage/sagedoc.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

87 lines
2.7 KiB
Nix
Raw Normal View History

{ stdenv
2018-04-24 21:53:36 +00:00
, sage-with-env
2020-11-30 13:09:26 +00:00
, python3
, jupyter-kernel-specs
2018-04-24 21:53:36 +00:00
}:
stdenv.mkDerivation rec {
2018-11-12 22:28:29 +00:00
version = src.version;
pname = "sagedoc";
2018-11-12 22:28:29 +00:00
src = sage-with-env.env.lib.src;
2018-04-24 21:53:36 +00:00
2022-05-20 18:03:25 +00:00
strictDeps = true;
2018-04-24 21:53:36 +00:00
nativeBuildInputs = [
# for patchShebangs below
python3
];
2018-04-24 21:53:36 +00:00
unpackPhase = ''
export SAGE_DOC_OVERRIDE="$PWD/share/doc/sage"
export SAGE_DOC_SRC_OVERRIDE="$PWD/docsrc"
2018-11-12 22:28:29 +00:00
cp -r "${src}/src/doc" "$SAGE_DOC_SRC_OVERRIDE"
2018-04-24 21:53:36 +00:00
chmod -R 755 "$SAGE_DOC_SRC_OVERRIDE"
'';
buildPhase = ''
export SAGE_NUM_THREADS="$NIX_BUILD_CORES"
export HOME="$TMPDIR/sage_home"
mkdir -p "$HOME"
# run bootstrap script to generate Sage spkg docs, because unfortunately some unrelated doc
# pages link to them. it needs a few ugly (but self-contained) hacks for a standalone run.
cp -r "${src}/build" "$HOME"
chmod -R 755 "$HOME/build"
sed -i "/assert/d" "$HOME/build/sage_bootstrap/env.py"
sed -i "s|sage-bootstrap-python|python3|" "$HOME/build/bin/sage-package"
patchShebangs "$HOME/build/bin/sage-package"
pushd "$SAGE_DOC_SRC_OVERRIDE"
sed -i "s|OUTPUT_DIR=\"src/doc/|OUTPUT_DIR=\"$SAGE_DOC_SRC_OVERRIDE/|" bootstrap
PATH="$HOME/build/bin:$PATH" SAGE_ROOT="${src}" ./bootstrap
popd
# adapted from src/doc/Makefile (doc-src target), which tries to call Sage from PATH
mkdir -p $SAGE_DOC_SRC_OVERRIDE/en/reference/repl
${sage-with-env}/bin/sage -advanced > $SAGE_DOC_SRC_OVERRIDE/en/reference/repl/options.txt
# needed to link them in the sage docs using intersphinx
2020-11-30 13:09:26 +00:00
export PPLPY_DOCS=${python3.pkgs.pplpy.doc}/share/doc/pplpy
# jupyter-sphinx calls the sagemath jupyter kernel during docbuild
export JUPYTER_PATH=${jupyter-kernel-specs}
# sage --docbuild unsets JUPYTER_PATH, so we call sage_docbuild directly
# https://trac.sagemath.org/ticket/33650#comment:32
${sage-with-env}/bin/sage --python3 -m sage_docbuild \
2018-04-24 21:53:36 +00:00
--mathjax \
--no-pdf-links \
all html < /dev/null
2018-04-24 21:53:36 +00:00
'';
installPhase = ''
cd "$SAGE_DOC_OVERRIDE"
mkdir -p "$out/share/doc/sage"
cp -r html "$out"/share/doc/sage
# Replace duplicated files by symlinks (Gentoo)
cd "$out"/share/doc/sage
mv html/en/_static{,.tmp}
for _dir in `find -name _static` ; do
rm -r $_dir
ln -rs html/en/_static $_dir
2018-04-24 21:53:36 +00:00
done
mv html/en/_static{.tmp,}
'';
doCheck = true;
checkPhase = ''
2022-03-19 02:16:18 +00:00
# sagemath_doc_html tests assume sage tests are being run, so we
# compromise: we run standard tests, but only on files containing
# relevant tests. as of Sage 9.6, there are only 4 such files.
grep -PRl "#.*optional.*sagemath_doc_html" ${src}/src/sage{,_docbuild} | \
xargs ${sage-with-env}/bin/sage -t --optional=sage,sagemath_doc_html
2018-04-24 21:53:36 +00:00
'';
}