forked from lijiext/lammps
196 lines
5.9 KiB
Makefile
196 lines
5.9 KiB
Makefile
# Makefile for LAMMPS documentation
|
|
|
|
SHELL = /bin/bash
|
|
BUILDDIR = ${CURDIR}
|
|
RSTDIR = $(BUILDDIR)/src
|
|
TXTDIR = $(BUILDDIR)/txt
|
|
VENV = $(BUILDDIR)/docenv
|
|
TXT2RST = $(VENV)/bin/txt2rst
|
|
ANCHORCHECK = $(VENV)/bin/rst_anchor_check
|
|
|
|
PYTHON = $(shell which python3)
|
|
VIRTUALENV = virtualenv
|
|
HAS_PYTHON3 = NO
|
|
HAS_VIRTUALENV = NO
|
|
|
|
ifeq ($(shell which python3 >/dev/null 2>&1; echo $$?), 0)
|
|
HAS_PYTHON3 = YES
|
|
endif
|
|
|
|
ifeq ($(shell which virtualenv-3 >/dev/null 2>&1; echo $$?), 0)
|
|
VIRTUALENV = virtualenv-3
|
|
HAS_VIRTUALENV = YES
|
|
endif
|
|
|
|
ifeq ($(shell which virtualenv >/dev/null 2>&1; echo $$?), 0)
|
|
VIRTUALENV = virtualenv
|
|
HAS_VIRTUALENV = YES
|
|
endif
|
|
|
|
SPHINXEXTRA = -j $(shell $(PYTHON) -c 'import multiprocessing;print(multiprocessing.cpu_count())')
|
|
SOURCES=$(filter-out $(wildcard $(TXTDIR)/lammps_commands*.txt) $(TXTDIR)/lammps_support.txt $(TXTDIR)/lammps_tutorials.txt,$(wildcard $(TXTDIR)/*.txt))
|
|
OBJECTS=$(SOURCES:$(TXTDIR)/%.txt=$(RSTDIR)/%.rst)
|
|
|
|
.PHONY: help clean-all clean epub mobi rst html pdf venv spelling anchor_check
|
|
|
|
# ------------------------------------------
|
|
|
|
help:
|
|
@echo "Please use \`make <target>' where <target> is one of"
|
|
@echo " html create HTML doc pages in html dir"
|
|
@echo " pdf create Developer.pdf and Manual.pdf in this dir"
|
|
@echo " fetch fetch HTML and PDF files from LAMMPS web site"
|
|
@echo " epub create ePUB format manual for e-book readers"
|
|
@echo " mobi convert ePUB to MOBI format manual for e-book readers (e.g. Kindle)"
|
|
@echo " (requires ebook-convert tool from calibre)"
|
|
@echo " clean remove all intermediate RST files"
|
|
@echo " clean-all reset the entire build environment"
|
|
@echo " anchor_check scan for duplicate anchor labels"
|
|
@echo " spelling spell-check the manual"
|
|
|
|
# ------------------------------------------
|
|
|
|
clean-all: clean
|
|
rm -rf $(BUILDDIR)/docenv $(BUILDDIR)/doctrees
|
|
|
|
clean:
|
|
rm -rf html epub latex
|
|
rm -rf spelling
|
|
|
|
clean-spelling:
|
|
rm -rf spelling
|
|
|
|
rst: clean $(OBJECTS) $(ANCHORCHECK)
|
|
|
|
html: $(OBJECTS) $(ANCHORCHECK)
|
|
@(\
|
|
. $(VENV)/bin/activate ;\
|
|
sphinx-build $(SPHINXEXTRA) -b html -c utils/sphinx-config -d $(BUILDDIR)/doctrees $(RSTDIR) html ;\
|
|
echo "############################################" ;\
|
|
rst_anchor_check src/*.rst ;\
|
|
env LC_ALL=C grep -n '[^ -~]' $(RSTDIR)/*.rst ;\
|
|
echo "############################################" ;\
|
|
deactivate ;\
|
|
)
|
|
-rm html/searchindex.js
|
|
@rm -rf html/_sources
|
|
@rm -rf html/PDF
|
|
@rm -rf html/USER
|
|
@cp -r src/PDF html/PDF
|
|
@cp -r src/USER html/USER
|
|
@rm -rf html/PDF/.[sg]*
|
|
@rm -rf html/USER/.[sg]*
|
|
@rm -rf html/USER/*/.[sg]*
|
|
@rm -rf html/USER/*/*.[sg]*
|
|
@echo "Build finished. The HTML pages are in doc/html."
|
|
|
|
spelling: $(OBJECTS) utils/sphinx-config/false_positives.txt
|
|
@(\
|
|
. $(VENV)/bin/activate ;\
|
|
pip install sphinxcontrib-spelling ;\
|
|
cp utils/sphinx-config/false_positives.txt $(RSTDIR)/ ;\
|
|
sphinx-build -b spelling -c utils/sphinx-config -d $(BUILDDIR)/doctrees $(RSTDIR) spelling ;\
|
|
deactivate ;\
|
|
)
|
|
@echo "Spell check finished."
|
|
|
|
epub: $(OBJECTS)
|
|
@mkdir -p epub/JPG
|
|
@rm -f LAMMPS.epub
|
|
@cp src/JPG/lammps-logo.png epub/
|
|
@cp src/JPG/*.* epub/JPG
|
|
@(\
|
|
. $(VENV)/bin/activate ;\
|
|
sphinx-build $(SPHINXEXTRA) -b epub -c utils/sphinx-config -d $(BUILDDIR)/doctrees $(RSTDIR) epub ;\
|
|
deactivate ;\
|
|
)
|
|
@mv epub/LAMMPS.epub .
|
|
@rm -rf epub
|
|
@echo "Build finished. The ePUB manual file is created."
|
|
|
|
mobi: epub
|
|
@rm -f LAMMPS.mobi
|
|
@ebook-convert LAMMPS.epub LAMMPS.mobi
|
|
@echo "Conversion finished. The MOBI manual file is created."
|
|
|
|
pdf: $(OBJECTS) $(ANCHORCHECK)
|
|
@(\
|
|
cd src/Developer; \
|
|
pdflatex developer; \
|
|
pdflatex developer; \
|
|
mv developer.pdf ../../Developer.pdf; \
|
|
cd ../../; \
|
|
)
|
|
@(\
|
|
. $(VENV)/bin/activate ;\
|
|
sphinx-build $(SPHINXEXTRA) -b latex -c utils/sphinx-config -d $(BUILDDIR)/doctrees $(RSTDIR) latex ;\
|
|
echo "############################################" ;\
|
|
rst_anchor_check src/*.rst ;\
|
|
echo "############################################" ;\
|
|
deactivate ;\
|
|
)
|
|
@cd latex && \
|
|
sed 's/latexmk -pdf -dvi- -ps-/pdflatex/g' Makefile > temp && \
|
|
mv temp Makefile && \
|
|
sed 's/\\begin{equation}//g' LAMMPS.tex > tmp.tex && \
|
|
mv tmp.tex LAMMPS.tex && \
|
|
sed 's/\\end{equation}//g' LAMMPS.tex > tmp.tex && \
|
|
mv tmp.tex LAMMPS.tex && \
|
|
make && \
|
|
make && \
|
|
mv LAMMPS.pdf ../Manual.pdf && \
|
|
cd ../;
|
|
@rm -rf latex/_sources
|
|
@rm -rf latex/PDF
|
|
@rm -rf latex/USER
|
|
@cp -r src/PDF latex/PDF
|
|
@cp -r src/USER latex/USER
|
|
@rm -rf latex/PDF/.[sg]*
|
|
@rm -rf latex/USER/.[sg]*
|
|
@rm -rf latex/USER/*/.[sg]*
|
|
@rm -rf latex/USER/*/*.[sg]*
|
|
@echo "Build finished. Manual.pdf and Developer.pdf are in this directory."
|
|
|
|
fetch:
|
|
@rm -rf html_www Manual_www.pdf Developer_www.pdf
|
|
@curl -s -o Manual_www.pdf http://lammps.sandia.gov/doc/Manual.pdf
|
|
@curl -s -o Developer_www.pdf http://lammps.sandia.gov/doc/Developer.pdf
|
|
@curl -s -o lammps-doc.tar.gz http://lammps.sandia.gov/tars/lammps-doc.tar.gz
|
|
@tar xzf lammps-doc.tar.gz
|
|
@rm -f lammps-doc.tar.gz
|
|
|
|
anchor_check : $(ANCHORCHECK)
|
|
@(\
|
|
. $(VENV)/bin/activate ;\
|
|
rst_anchor_check src/*.txt ;\
|
|
deactivate ;\
|
|
)
|
|
|
|
# ------------------------------------------
|
|
|
|
$(RSTDIR)/%.rst : $(TXTDIR)/%.txt $(TXT2RST)
|
|
@(\
|
|
mkdir -p $(RSTDIR) ; \
|
|
. $(VENV)/bin/activate ;\
|
|
txt2rst -v $< > $@ ;\
|
|
deactivate ;\
|
|
)
|
|
|
|
$(VENV):
|
|
@if [ "$(HAS_PYTHON3)" == "NO" ] ; then echo "Python3 was not found! Please check README.md for further instructions" 1>&2; exit 1; fi
|
|
@if [ "$(HAS_VIRTUALENV)" == "NO" ] ; then echo "virtualenv was not found! Please check README.md for further instructions" 1>&2; exit 1; fi
|
|
@( \
|
|
$(VIRTUALENV) -p $(PYTHON) $(VENV); \
|
|
. $(VENV)/bin/activate; \
|
|
pip install Sphinx; \
|
|
deactivate;\
|
|
)
|
|
|
|
$(TXT2RST) $(ANCHORCHECK): $(VENV)
|
|
@( \
|
|
. $(VENV)/bin/activate; \
|
|
(cd utils/converters;\
|
|
python setup.py develop);\
|
|
deactivate;\
|
|
)
|