#
# Make file to install/uninstall AsciiDoc
#
# Run `make help` to print out directions on running
# this file. To add new messages to help, prepend
# the line with ## and then one additional character,
# e.g. `## help` to show "help" or `##   help` will show
# "  help" or `##.` will show a blank line.

.NOTPARALLEL:

INSTALL = /usr/bin/install -c
INSTALL_PROG = ${INSTALL}
INSTALL_DATA = ${INSTALL} -m 644
PACKAGE_TARNAME = asciidoc
SED = /bin/sed

prefix = /usr/local
exec_prefix = ${prefix}
bindir = ${exec_prefix}/bin
datadir = ${datarootdir}
docdir = ${datarootdir}/doc/${PACKAGE_TARNAME}
sysconfdir = ${prefix}/etc
datarootdir = ${prefix}/share
mandir=${datarootdir}/man
srcdir = .



ASCIIDOCVERSION = 9.0.2
ASCIIDOCDATE = 21 July 2020
ASCIIDOCCONF = $(sysconfdir)/asciidoc

prog = asciidoc.py a2x.py
progdir = $(bindir)

manp = $(patsubst %1.txt,%1,$(wildcard doc/*.1.txt))
manpdir = $(mandir)/man1

conf = $(wildcard *.conf)
confdir = $(ASCIIDOCCONF)

filtersdir = $(ASCIIDOCCONF)/filters

codefilter = filters/code/code-filter.py
codefilterdir = $(filtersdir)/code
codefilterconf = filters/code/code-filter.conf
codefilterconfdir = $(filtersdir)/code

graphvizfilter = filters/graphviz/graphviz2png.py
graphvizfilterdir = $(filtersdir)/graphviz
graphvizfilterconf = filters/graphviz/graphviz-filter.conf
graphvizfilterconfdir = $(filtersdir)/graphviz

musicfilter = filters/music/music2png.py
musicfilterdir = $(filtersdir)/music
musicfilterconf = filters/music/music-filter.conf
musicfilterconfdir = $(filtersdir)/music

sourcefilterconf = filters/source/source-highlight-filter.conf
sourcefilterconfdir = $(filtersdir)/source

latexfilter = filters/latex/latex2img.py
latexfilterdir = $(filtersdir)/latex
latexfilterconf = filters/latex/latex-filter.conf
latexfilterconfdir = $(filtersdir)/latex

unwraplatexfilter = filters/unwraplatex.py
unwraplatexfilterdir = $(filtersdir)

themesdir = $(ASCIIDOCCONF)/themes

flasktheme = themes/flask/flask.css
flaskthemedir = $(themesdir)/flask

volnitskytheme = themes/volnitsky/volnitsky.css
volnitskythemedir = $(themesdir)/volnitsky

docbook = $(wildcard docbook-xsl/*.xsl)
docbookdir = $(ASCIIDOCCONF)/docbook-xsl

dblatex = $(wildcard dblatex/*.xsl) $(wildcard dblatex/*.sty)
dblatexdir = $(ASCIIDOCCONF)/dblatex

css = $(wildcard stylesheets/*.css)
cssdir = $(ASCIIDOCCONF)/stylesheets

js = $(wildcard javascripts/*.js)
jsdir = $(ASCIIDOCCONF)/javascripts

callouts = $(wildcard images/icons/callouts/*)
calloutsdir = $(ASCIIDOCCONF)/images/icons/callouts

icons = $(wildcard images/icons/*.png) images/icons/README
iconsdir = $(ASCIIDOCCONF)/images/icons

doc = $(wildcard README*) $(wildcard BUGS*) $(wildcard INSTALL*) $(wildcard CHANGELOG*)

DATATARGETS = manp conf docbook dblatex css js callouts icons codefilterconf graphvizfilterconf latexfilterconf musicfilterconf sourcefilterconf flasktheme volnitskytheme
PROGTARGETS = prog codefilter graphvizfilter latexfilter musicfilter unwraplatexfilter
TARGETS = $(DATATARGETS) $(PROGTARGETS) doc

INSTDIRS = $(TARGETS:%=%dir)

.PHONY: $(TARGETS)

# this needs to be above help so that it runs
# by default
all: build

.PHONY : help
help : Makefile
	@sed -n 's/^##.//p' $<

## Makefile for AsciiDoc 9.0.2 (21 July 2020)
## Usage: make [VARIABLE=value] ... [TARGET]
##.
##   all: runs the build target

# create directories used during the install
$(INSTDIRS):
	$(INSTALL) -d $(DESTDIR)$($@)

$(PROGTARGETS): % : %dir
	$(INSTALL_PROG) $($@) $(DESTDIR)$($<)/

$(DATATARGETS): % : %dir
	$(INSTALL_DATA) $($@) $(DESTDIR)$($<)/

$(manp): %.1 : %.1.txt
	python3 a2x.py -f manpage $<

progsymlink:
	(cd $(DESTDIR)$(progdir); ln -sf asciidoc.py asciidoc)
	(cd $(DESTDIR)$(progdir); ln -sf a2x.py a2x)

##.

##   version: print out the version to use for the other targets
.PHONY: version
version:
	@echo "Version $(ASCIIDOCVERSION) (released $(ASCIIDOCDATE))";

##   vers_update: updates the version string in asciidoc and a2x
.PHONY: vers_update
vers_update:
	@for f in $(prog); do \
		echo "Setting VERSION in $$f to $(ASCIIDOCVERSION)"; \
		$(SED) "s#^VERSION = '.*'#VERSION = '$(ASCIIDOCVERSION)'#" $$f > $$f.out; \
		mv $$f.out $$f; \
		chmod +x $$f; \
	done

##.

DOC_FILES = CHANGELOG.txt README.asciidoc BUGS.txt INSTALL.txt doc/a2x.1.txt \
	 		doc/faq.txt doc/asciidocapi.txt doc/testasciidoc.txt \
			doc/epub-notes.txt doc/publishing-ebooks-with-asciidoc.txt \
			doc/source-highlight-filter.txt doc/slidy.txt doc/slidy-example.txt

WEBSITE_FILES = $(wildcard website/*.txt)

##   spell: run doc_spell and website_spell
.PHONY: spell
spell: doc_spell website_spell


##   doc_spell: run aspell over all files under doc/
.PHONY: doc_spell
doc_spell:
	@for f in $(DOC_FILES); do \
		echo "aspell check -p ./doc/asciidoc.dict $$f"; \
		aspell check -p ./doc/asciidoc.dict $$f; \
	done

##   website_spell: run aspell over all files under website/
.PHONY: website_spell
website_spell:
	@for f in $(WEBSITE_FILES); do \
		echo "aspell check -p ./website/asciidoc-website.dict $$f"; \
		aspell check -p ./website/asciidoc-website.dict $$f; \
	done

##.

##   install: install asciidoc to target directory
.PHONY: install
install: all $(PROGTARGETS) $(DATATARGETS) progsymlink

##   build: runs fconfpath and manpages
.PHONY: build
build: fixconfpath manpages

##   fixconfpath: update the CONF_PATH global variable to target install directory
.PHONY: fixconfpath
fixconfpath:
	@for f in $(prog); do \
		echo "Fixing CONF_DIR in $$f"; \
		$(SED) "s#^CONF_DIR = '.*'#CONF_DIR = '$(ASCIIDOCCONF)'#" $$f > $$f.out; \
		mv $$f.out $$f; \
		chmod +x $$f; \
	done

##   manpages: generate manpages for asciidoc, a2x, and testasciidoc
manpages: doc/asciidoc.1 doc/a2x.1 doc/testasciidoc.1

##   docs: install documentation files to filesystem (e.g. /usr/local/share/doc/asciidoc)
docs:
	$(INSTALL) -d $(DESTDIR)$(docdir)
	$(INSTALL_DATA) $(doc) $(DESTDIR)$(docdir)
	$(INSTALL) -d $(DESTDIR)$(docdir)/docbook-xsl
	$(INSTALL_DATA) docbook-xsl/asciidoc-docbook-xsl.txt $(DESTDIR)$(docdir)/docbook-xsl
	$(INSTALL) -d $(DESTDIR)$(docdir)/dblatex
	$(INSTALL_DATA) dblatex/dblatex-readme.txt $(DESTDIR)$(docdir)/dblatex
	$(INSTALL) -d $(DESTDIR)$(docdir)/stylesheets
	$(INSTALL_DATA) $(css) $(DESTDIR)$(docdir)/stylesheets
	$(INSTALL) -d $(DESTDIR)$(docdir)/javascripts
	$(INSTALL_DATA) $(js) $(DESTDIR)$(docdir)/javascripts
	$(INSTALL) -d $(DESTDIR)$(docdir)/images
	( cd images && \
		cp -R * $(DESTDIR)$(docdir)/images )
	$(INSTALL) -d $(DESTDIR)$(docdir)/doc
	( cd doc && \
		cp -R * $(DESTDIR)$(docdir)/doc )
	$(INSTALL) -d $(DESTDIR)$(docdir)/website
	( cd website && \
		cp -R * $(DESTDIR)$(docdir)/website )

##   website: generates the website into ./gh-pages directory (which will point at gh-pages branch)
.PHONY: website
website:
	bash build_website.sh

##   tags: generate tags index files for use with vim and other tags-capable editors
.PHONY: tags
tags:
	rm -f tags
	ctags asciidoc.py asciidocapi.py tests/testasciidoc.py

##   uninstall: uninstall asciidoc
.PHONY: uninstall
uninstall:
	rm -f $(DESTDIR)$(progdir)/asciidoc
	rm -f $(DESTDIR)$(progdir)/asciidoc.py
	rm -f $(DESTDIR)$(progdir)/a2x
	rm -f $(DESTDIR)$(progdir)/a2x.py
	rm -f $(DESTDIR)$(manpdir)/asciidoc.1
	rm -f $(DESTDIR)$(manpdir)/testasciidoc.1
	rm -f $(DESTDIR)$(manpdir)/a2x.1
	rm -rf $(DESTDIR)$(confdir)
	rm -rf $(DESTDIR)$(docdir)

##   clean: delete built asciidoc doc files
.PHONY: clean
clean:
	rm -f $(manp)

MANIFEST: MANIFEST.in
	bash build_manifest.sh

##.
##   dist: creates the zip and tarball for release
.PHONY: dist
dist: vers_update manpages MANIFEST
	mkdir -p build
	rm -rf build/*
	tar -czf build/asciidoc-tmp.tar.gz -T MANIFEST
	mkdir -p build/asciidoc-$(ASCIIDOCVERSION)
	tar -xf build/asciidoc-tmp.tar.gz -C build/asciidoc-$(ASCIIDOCVERSION)
	cd build && tar -czf asciidoc-$(ASCIIDOCVERSION).tar.gz asciidoc-$(ASCIIDOCVERSION) && zip -r asciidoc-$(ASCIIDOCVERSION).zip asciidoc-$(ASCIIDOCVERSION)
	rm -rf build/asciidoc-tmp.tar.gz
	rm -rf build/asciidoc-$(ASCIIDOCVERSION)

##.
##   test: run the asciidoc test suite
.PHONY: test
test:
	python3 ./asciidoc.py --doctest
	python3 ./asciidocapi.py
	python3 tests/testasciidoc.py run
