forked from Kurento/doc-kurento
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
116 lines (102 loc) · 4.37 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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
# Makefile for Sphinx documentation
# Special Make configuration:
# - Run all targets sequentially (disable parallel jobs)
# See: https://www.gnu.org/software/make/manual/html_node/Parallel.html
# - Run all commands in the same shell (disable one shell per command)
# See: https://www.gnu.org/software/make/manual/html_node/One-Shell.html
.NOTPARALLEL:
.ONESHELL:
.PHONY: help init-workdir langdoc Makefile*
# Check required features
ifeq ($(filter oneshell,$(.FEATURES)),)
$(error This Make doesn't support '.ONESHELL', use Make >= 3.82)
endif
# You can set these variables from the command line.
SPHINXOPTS :=
SPHINXBUILD := sphinx-build
SPHINXPROJ := Kurento
SOURCEDIR := source
BUILDDIR := build
WORKDIR := $(CURDIR)/$(BUILDDIR)/$(SOURCEDIR)
# Put this target first so that "make" without argument is like "make help"
help:
@$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)
@echo " langdoc to make JavaDocs and JsDocs of the Kurento Clients"
@echo " dist to make <langdoc html epub latexpdf> and then pack"
@echo " all resulting files as kurento-doc-|VERSION_DOC|.tgz"
@echo " readthedocs to make <langdoc> and then copy the results to the"
@echo " Sphinx theme's static folder"
@echo ""
@echo "apt-get dependencies:"
@echo "- make >= 3.82"
@echo "- javadoc (default-jdk-headless)"
@echo "- npm"
@echo "- latexmk"
@echo "- texlive-fonts-recommended"
@echo "- texlive-latex-recommended"
@echo "- texlive-latex-extra"
@echo ""
@echo "python pip dependencies:"
@echo "- sphinx >= 1.5.0 (Tested: 1.6.6)"
@echo "- sphinx_rtd_theme"
init-workdir:
mkdir -p $(WORKDIR)
rsync -a $(SOURCEDIR)/ $(WORKDIR)
langdoc-init:
# Care must be taken because the Current Directory changes in this target,
# so it's better to use absolute paths for destination dirs.
# The 'client-doc' part must match the setting 'html_static_path' in 'conf.py',
# and its contents must match the URLs used in the documentation files.
$(eval WORKPATH := $(CURDIR)/$(BUILDDIR)/client-src)
$(eval DESTPATH := $(CURDIR)/$(BUILDDIR)/langdoc)
mkdir -p $(WORKPATH)
mkdir -p $(DESTPATH)
langdoc-client-java: langdoc-init
cd $(WORKPATH)
git clone https://github.com/Kurento/kurento-java.git
cd kurento-java
[ "|VERSION_RELEASE|" = "true" ] && git checkout "|VERSION_CLIENT_JAVA|"
cd kurento-client || { echo "ERROR: 'cd' failed, ls:"; ls -lA; exit 1; }
mvn --batch-mode --quiet clean package \
-DskipTests || { echo "ERROR: 'mvn clean' failed"; exit 1; }
mvn --batch-mode --quiet javadoc:javadoc \
-DreportOutputDirectory="$(DESTPATH)" -DdestDir="client-javadoc" \
-Dsourcepath="src/main/java:target/generated-sources/kmd" \
-Dsubpackages="org.kurento.client" -DexcludePackageNames="*.internal" \
|| { echo "ERROR: 'mvn javadoc' failed"; exit 1; }
langdoc-client-js: langdoc-init
cd $(WORKPATH)
git clone https://github.com/Kurento/kurento-client-js.git
cd kurento-client-js
[ "|VERSION_RELEASE|" = "true" ] && git checkout "|VERSION_CLIENT_JS|"
npm install --no-color
node_modules/.bin/grunt --no-color --force jsdoc \
|| { echo "ERROR: 'grunt jsdoc' failed"; exit 1; }
rsync -a doc/jsdoc/ $(DESTPATH)/client-jsdoc
langdoc-utils-js: langdoc-init
cd $(WORKPATH)
git clone https://github.com/Kurento/kurento-utils-js.git
cd kurento-utils-js
[ "|VERSION_RELEASE|" = "true" ] && git checkout "|VERSION_UTILS_JS|"
npm install --no-color
node_modules/.bin/grunt --no-color --force jsdoc \
|| { echo "ERROR: 'grunt jsdoc' failed"; exit 1; }
rsync -a doc/jsdoc/kurento-utils/*/ $(DESTPATH)/utils-jsdoc
langdoc: langdoc-client-java langdoc-client-js langdoc-utils-js
dist: langdoc html epub latexpdf
$(eval DISTDIR := $(BUILDDIR)/dist/kurento-doc-|VERSION_DOC|)
mkdir -p $(DISTDIR)
rsync -a $(BUILDDIR)/html $(BUILDDIR)/epub/Kurento.epub \
$(BUILDDIR)/latex/Kurento.pdf $(DISTDIR)
tar zcf $(DISTDIR).tgz -C $(DISTDIR) .
# Target to be run by CI. It modifies the source directory,
# so the worspace should get deleted afterwards.
ci-readthedocs: init-workdir langdoc
rsync -a $(WORKDIR)/ $(SOURCEDIR)
rsync -a $(BUILDDIR)/langdoc $(SOURCEDIR)
# Comment this target to disable unconditional generation of JavaDoc & JsDoc
#html: langdoc
# Catch-all target: route all unknown targets to Sphinx using the new
# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS).
%: init-workdir Makefile*
$(SPHINXBUILD) -M $@ "$(WORKDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O)