diff options
| author | Mohammad Akhlaghi <mohammad@akhlaghi.org> | 2019-09-16 00:55:07 +0100 | 
|---|---|---|
| committer | Mohammad Akhlaghi <mohammad@akhlaghi.org> | 2019-09-16 01:06:05 +0100 | 
| commit | c88950e788e17f8213330624b0d44c83344c2f1e (patch) | |
| tree | 64b890db11a5d7cbdc8cfbd1dd0fe904f457f283 /reproduce/analysis/make/initialize.mk | |
| parent | 403ec7d7c632ae410ee2052bfc0a5f52aa05e466 (diff) | |
Distribution tarball now builds in arXiv
`./project make dist' will package all the LaTeX-specific files (and
analysis source files) into one `tar.gz' file that is ready to upload to
servers like arXiv. However, it wasn't updated for some time, so running it
would complain about not having a `configure' script in the top of the
project.
With this commit, it now works with the new file-structure of the project
and also copies all the BibLaTeX source files and `paper.bbl' into the top
tarball directory, which allows arXiv to build the paper as intended.
The output of `./project make dist' has been uploaded and tested on arXiv
and it is built by arXiv perfectly.
Also, a short description of all the special `make' targets was added to
the output of `./project --help'.
Diffstat (limited to 'reproduce/analysis/make/initialize.mk')
| -rw-r--r-- | reproduce/analysis/make/initialize.mk | 33 | 
1 files changed, 25 insertions, 8 deletions
| diff --git a/reproduce/analysis/make/initialize.mk b/reproduce/analysis/make/initialize.mk index 644efe4..94008f2 100644 --- a/reproduce/analysis/make/initialize.mk +++ b/reproduce/analysis/make/initialize.mk @@ -228,7 +228,7 @@ distclean: clean  # that is ready for building the final PDF with LaTeX. This is useful for  # collaborators who only want to contribute to the text of your project,  # without having to worry about the technicalities of the analysis. -$(packagecontents): | $(texdir) +$(packagecontents): paper.pdf | $(texdir)          # Set up the output directory, delete it if it exists and remake it          # to fill with new contents. @@ -250,7 +250,7 @@ $(packagecontents): | $(texdir)  	printf "\trm -f *.blg *.log *.out *.run.xml\n"           >> $$m          # Copy the top-level contents into it. -	cp configure COPYING for-group README.md README-hacking.md $$dir/ +	cp COPYING project README.md README-hacking.md $$dir/          # Build the top-level directories.  	mkdir $$dir/reproduce $$dir/tex $$dir/tex/tikz $$dir/tex/build @@ -259,7 +259,7 @@ $(packagecontents): | $(texdir)  	shopt -s extglob  	cp -r tex/src                            $$dir/tex/src  	cp tex/tikz/*.pdf                        $$dir/tex/tikz -	cp -r reproduce/                         $$dir/reproduce +	cp -r reproduce/*                        $$dir/reproduce  	cp -r tex/build/!($(packagebasename))    $$dir/tex/build          # Clean up un-necessary/local files: 1) the $(texdir)/build* @@ -272,18 +272,35 @@ $(packagecontents): | $(texdir)  	rm $$dir/reproduce/software/config/installation/LOCAL.mk  	rm $$dir/reproduce/software/config/gnuastro/gnuastro-local.conf -        # PROJECT SPECIFIC: under this comment, copy any other file for -        # packaging, or remove any of the copied files above to suite your -        # project. +        # When submitting to places like arXiv, they will just run LaTeX +        # once and won't run `biber'. So we need to also keep the `.bbl' +        # file into the distributing tarball. However, BibLaTeX is +        # particularly sensitive to versioning (a `.bbl' file has to be +        # read by the same BibLaTeX version that created it). This is hard +        # to do with non-up-to-date places like arXiv. Therefore, we thus +        # just copy the whole of BibLaTeX's source (the version we are +        # using) into the top tarball directory. In this way, arXiv's LaTeX +        # engine will use the same BibLaTeX version to interpret the `.bbl' +        # file. TIP: you can use the same strategy for other LaTeX packages +        # that may cause problems on the arXiv server. +	cp tex/build/build/paper.bbl $$dir/ +	tltopdir=.local/texlive/2019/texmf-dist/tex/latex +	find $$tltopdir/biblatex/ -maxdepth 1 -type f -print0 \ +	     | xargs -0 cp -t $$dir + +        # PROJECT SPECIFIC +        # ---------------- +        # Put any project specific distribution steps here. +        # ----------------          # Since the packaging is mainly intended for high-level building of          # the PDF with LaTeX, we'll comment the `makepdf' LaTeX macro in -        # the paper. +        # the paper. This will disable usage of TiKZ.  	sed -e's|\\newcommand{\\makepdf}{}|%\\newcommand{\\makepdf}{}|' \  	    paper.tex > $$dir/paper.tex          # Just in case the package users want to rebuild some of the -        # figures (manually un-comments the `makepdf' command we commented +        # figures (manually un-comment the `makepdf' command we commented          # above), correct the TikZ external directory, so the figures can          # be rebuilt.  	pgfsettings="$$dir/tex/src/preamble-pgfplots.tex" | 
