forked from tjworks/docs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmakefile
97 lines (91 loc) · 4.34 KB
/
makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# Makefile for MongoDB Sphinx documentation
MAKEFLAGS += -j -r --no-print-directory
include bin/makefile.bootstrap
include bin/makefile.dynamic
############# Meta targets that control the build and publication process. #############
publish:$(sphinx-content) $(static-content)
@echo [build]: $(manual-branch) branch is succeessfully deployed to '$(public-output)'.
############# Targets that define the production build process #############
# Generating files with build specific info.
conf.py:meta.yaml
setup:source/includes/hash.rst composite-pages.yaml meta.yaml
@mkdir -p $(public-branch-output) $(public-output)
@echo [build]: created $(public-branch-output) and $(public-output)
meta.yaml:
@$(PYTHONBIN) bin/docs_meta.py yaml $@
@echo [meta]: regenerated $@
composite-pages.yaml:bin/composite-pages.yaml
@cp $< $@
@echo [meta]: compsite pages $@
source/includes/hash.rst:source/about.txt
@$(PYTHONBIN) bin/update_hash.py
@-git update-index --assume-unchanged $@
@echo [build]: \(re\)generated $@.
$(public-branch-output)/release.txt:$(public-branch-output)/
@echo $(last-commit) >|$@
@echo [build]: generated '$@' with current release hash.
# migrating and processing dirhtml and singlehtml content.
$(public-output)/ $(output):
@mkdir -p $@
@echo [build]: created $@
htaccess:$(public-output)/.htaccess
$(public-output)/.htaccess:bin/htaccess.yaml bin/htaccess.py $(public-output)/
@$(PYTHONBIN) bin/htaccess.py $@
$(public-branch-output):$(branch-output)/dirhtml
@mkdir -p $@
@rsync -a $</ $@/
@rm -rf $(public-branch-output)/meta/reference $(public-branch-output)/meta/use-cases
@touch $@
@echo [build]: migrated '$</*' to '$@'
$(public-branch-output)/single:$(branch-output)/singlehtml
@mkdir -p $@
@rsync -a $</ $@/
@rm -f $@/contents.html
@touch $@
@echo [build]: migrated '$</*' to '$@'
$(public-branch-output)/single/index.html:$(branch-output)/singlehtml/contents.html
@cp $< $@
@sed $(SED_ARGS_FILE) -e 's/href="contents.html/href="index.html/g' \
-e 's/name="robots" content="index"/name="robots" content="noindex"/g' \
-e 's/(href=")genindex.html"/\1..\/genindex\/"/g' $@
@echo [single]: generating and processing '$@' page
$(branch-output)/sitemap.xml.gz:$(public-branch-output) $(public-output)/manual error-pages links
@echo -e "----------\n[sitemap]: build started\: `date`" >> $(branch-output)/sitemap-build.log
@$(PYTHONBIN) bin/sitemap_gen.py --testing --config=conf-sitemap.xml 2>&1 >> $(branch-output)/sitemap-build.log
@echo [sitemap]: sitemap build complete at `date`.
@echo "[sitemap]: build finished: `date`" >> $(branch-output)/sitemap-build.log
############# PDF generation infrastructure. #############
LATEX_CORRECTION = "s/(index|bfcode)\{(.*!*)*--(.*)\}/\1\{\2-\{-\}\3\}/g"
LATEX_LINK_CORRECTION = "s%\\\code\{/%\\\code\{http://docs.mongodb.org/$(current-if-not-manual)/%g"
pdflatex-command = TEXINPUTS=".:$(branch-output)/latex/:" pdflatex --interaction batchmode --output-directory $(branch-output)/latex/ $(LATEXOPTS)
# Uses 'latex' target to generate latex files.
pdfs:$(subst .tex,.pdf,$(wildcard $(branch-output)/latex/*.tex))
$(branch-output)/latex/%.tex:
@sed $(SED_ARGS_FILE) -e $(LATEX_CORRECTION) -e $(LATEX_CORRECTION) -e $(LATEX_LINK_CORRECTION) $@
@echo [latex]: fixing the Sphinx ouput of '$@'.
%.pdf:%.tex
@$(pdflatex-command) $(LATEXOPTS) '$<' >|[email protected]
@echo "[pdf]: (1/4) pdflatex $<"
@-makeindex -s $(output)/latex/python.ist '$(basename $<).idx' >>[email protected] 2>&1
@echo "[pdf]: (2/4) Indexing: $(basename $<).idx"
@$(pdflatex-command) $(LATEXOPTS) '$<' >>[email protected]
@echo "[pdf]: (3/4) pdflatex $<"
@$(pdflatex-command) $(LATEXOPTS) '$<' >>[email protected]
@echo "[pdf]: (4/4) pdflatex $<"
@echo "[pdf]: see '[email protected]' for a full report of the pdf build process."
############# General purpose targets. Not used (directly) in the production build #############
tags:
@etags -I --language=none --regex=@bin/etags.regexp `find source -name "*.txt" | grep -v "\.#"`
@echo "[dev]: etags generation complete."
test:
@echo "[dtf]: running test suite -- `date`"
@dtf --casedir dtf/cases/ --testdir dtf/
@echo "[dtf]: test suite complete -- `date`"
dtf-verbose:
@echo "[dtf]: running test suite -- `date`"
@dtf --casedir dtf/cases/ --testdir dtf/ -v
@echo "[dtf]: test suite complete -- `date`"
dtf-passing:
@echo "[dtf]: running test suite -- `date`"
@dtf --casedir dtf/cases/ --testdir dtf/ -p
@echo "[dtf]: test suite complete -- `date`"