2012-02-25 01:05:05 +00:00
|
|
|
#!/usr/bin/make
|
2012-08-28 03:06:39 +00:00
|
|
|
# WARN: gmake syntax
|
2012-04-21 16:01:15 +00:00
|
|
|
########################################################
|
|
|
|
# Makefile for Ansible
|
|
|
|
#
|
|
|
|
# useful targets:
|
|
|
|
# make sdist ---------------- produce a tarball
|
|
|
|
# make rpm ----------------- produce RPMs
|
2012-07-24 19:38:52 +00:00
|
|
|
# make deb ------------------ produce a DEB
|
2012-04-21 16:01:15 +00:00
|
|
|
# make docs ----------------- rebuild the manpages (results are checked in)
|
|
|
|
# make tests ---------------- run the tests
|
2012-10-03 13:43:38 +00:00
|
|
|
# make pyflakes, make pep8 -- source code checks
|
2012-04-21 16:01:15 +00:00
|
|
|
|
|
|
|
########################################################
|
|
|
|
# variable section
|
|
|
|
|
2012-03-10 19:02:25 +00:00
|
|
|
NAME = "ansible"
|
2012-08-28 03:06:39 +00:00
|
|
|
OS = $(shell uname -s)
|
2012-04-21 16:01:15 +00:00
|
|
|
|
|
|
|
# Manpages are currently built with asciidoc -- would like to move to markdown
|
2012-04-17 14:39:36 +00:00
|
|
|
# This doesn't evaluate until it's called. The -D argument is the
|
|
|
|
# directory of the target file ($@), kinda like `dirname`.
|
2013-03-05 18:59:39 +00:00
|
|
|
MANPAGES := docs/man/man1/ansible.1 docs/man/man1/ansible-playbook.1 docs/man/man1/ansible-pull.1 docs/man/man1/ansible-doc.1
|
|
|
|
ifneq ($(shell which a2x 2>/dev/null),)
|
2012-02-25 01:05:05 +00:00
|
|
|
ASCII2MAN = a2x -D $(dir $@) -d manpage -f manpage $<
|
|
|
|
ASCII2HTMLMAN = a2x -D docs/html/man/ -d manpage -f xhtml
|
2013-03-05 18:59:39 +00:00
|
|
|
else
|
|
|
|
ASCII2MAN = @echo "ERROR: AsciiDoc 'a2x' command is not installed but is required to build $(MANPAGES)" && exit 1
|
|
|
|
endif
|
2012-04-21 16:01:15 +00:00
|
|
|
|
2013-03-02 14:38:02 +00:00
|
|
|
PYTHON=python
|
|
|
|
SITELIB = $(shell $(PYTHON) -c "from distutils.sysconfig import get_python_lib; print get_python_lib()")
|
2012-04-21 16:01:15 +00:00
|
|
|
|
|
|
|
# VERSION file provides one place to update the software version
|
2012-04-17 14:39:36 +00:00
|
|
|
VERSION := $(shell cat VERSION)
|
2012-04-21 16:01:15 +00:00
|
|
|
|
2012-11-12 13:21:08 +00:00
|
|
|
# Get the branch information from git
|
2012-08-01 12:52:37 +00:00
|
|
|
ifneq ($(shell which git),)
|
|
|
|
GIT_DATE := $(shell git log -n 1 --format="%ai")
|
|
|
|
endif
|
2012-08-28 03:06:39 +00:00
|
|
|
|
2013-09-15 19:27:18 +00:00
|
|
|
ifeq ($(shell echo $(OS) | egrep -c 'Darwin|FreeBSD|OpenBSD'),1)
|
|
|
|
DATE := $(shell date -j -r $(shell git log -n 1 --format="%at") +%Y%m%d%H%M)
|
2012-09-19 09:56:55 +00:00
|
|
|
else
|
2012-10-02 12:29:57 +00:00
|
|
|
DATE := $(shell date --utc --date="$(GIT_DATE)" +%Y%m%d%H%M)
|
2012-08-28 03:06:39 +00:00
|
|
|
endif
|
2012-08-01 12:52:37 +00:00
|
|
|
|
2012-04-21 16:01:15 +00:00
|
|
|
# RPM build parameters
|
2012-04-18 15:00:59 +00:00
|
|
|
RPMSPECDIR= packaging/rpm
|
|
|
|
RPMSPEC = $(RPMSPECDIR)/ansible.spec
|
2013-06-02 17:27:04 +00:00
|
|
|
RPMDIST = $(shell rpm --eval '%{?dist}')
|
2012-08-01 12:52:37 +00:00
|
|
|
RPMRELEASE = 1
|
|
|
|
ifeq ($(OFFICIAL),)
|
|
|
|
RPMRELEASE = 0.git$(DATE)
|
|
|
|
endif
|
|
|
|
RPMNVR = "$(NAME)-$(VERSION)-$(RPMRELEASE)$(RPMDIST)"
|
2012-02-25 01:05:05 +00:00
|
|
|
|
2013-05-11 10:13:29 +00:00
|
|
|
NOSETESTS := nosetests
|
|
|
|
|
2012-04-21 16:01:15 +00:00
|
|
|
########################################################
|
|
|
|
|
2012-02-28 09:15:52 +00:00
|
|
|
all: clean python
|
|
|
|
|
2012-10-03 13:43:38 +00:00
|
|
|
tests:
|
2013-05-11 10:13:29 +00:00
|
|
|
PYTHONPATH=./lib $(NOSETESTS) -d -v
|
2012-03-04 02:56:11 +00:00
|
|
|
|
2012-04-17 14:39:36 +00:00
|
|
|
# To force a rebuild of the docs run 'touch VERSION && make docs'
|
2013-03-05 12:05:00 +00:00
|
|
|
docs: $(MANPAGES) modulepages
|
2013-02-27 03:05:17 +00:00
|
|
|
|
|
|
|
authors:
|
|
|
|
sh hacking/authors.sh
|
2012-02-25 01:05:05 +00:00
|
|
|
|
2012-04-16 19:43:21 +00:00
|
|
|
# Regenerate %.1.asciidoc if %.1.asciidoc.in has been modified more
|
|
|
|
# recently than %.1.asciidoc.
|
|
|
|
%.1.asciidoc: %.1.asciidoc.in
|
2012-04-17 14:39:36 +00:00
|
|
|
sed "s/%VERSION%/$(VERSION)/" $< > $@
|
2012-02-25 01:05:05 +00:00
|
|
|
|
2012-04-17 14:39:36 +00:00
|
|
|
# Regenerate %.1 if %.1.asciidoc or VERSION has been modified more
|
|
|
|
# recently than %.1. (Implicitly runs the %.1.asciidoc recipe)
|
|
|
|
%.1: %.1.asciidoc VERSION
|
2012-02-25 01:05:05 +00:00
|
|
|
$(ASCII2MAN)
|
|
|
|
|
2012-03-03 03:03:03 +00:00
|
|
|
loc:
|
|
|
|
sloccount lib library bin
|
|
|
|
|
2012-02-25 01:05:05 +00:00
|
|
|
pep8:
|
|
|
|
@echo "#############################################"
|
|
|
|
@echo "# Running PEP8 Compliance Tests"
|
|
|
|
@echo "#############################################"
|
2012-08-11 22:41:36 +00:00
|
|
|
-pep8 -r --ignore=E501,E221,W291,W391,E302,E251,E203,W293,E231,E303,E201,E225,E261,E241 lib/ bin/
|
|
|
|
-pep8 -r --ignore=E501,E221,W291,W391,E302,E251,E203,W293,E231,E303,E201,E225,E261,E241 --filename "*" library/
|
2012-02-25 01:05:05 +00:00
|
|
|
|
2012-03-03 03:10:51 +00:00
|
|
|
pyflakes:
|
2013-11-02 15:07:58 +00:00
|
|
|
pyflakes lib/ansible/*.py lib/ansible/*/*.py bin/*
|
2012-03-03 03:10:51 +00:00
|
|
|
|
2012-02-25 01:05:05 +00:00
|
|
|
clean:
|
2012-03-05 19:06:39 +00:00
|
|
|
@echo "Cleaning up distutils stuff"
|
2012-04-17 14:39:36 +00:00
|
|
|
rm -rf build
|
|
|
|
rm -rf dist
|
2012-03-05 19:06:39 +00:00
|
|
|
@echo "Cleaning up byte compiled python stuff"
|
2012-04-17 14:39:36 +00:00
|
|
|
find . -type f -regex ".*\.py[co]$$" -delete
|
2012-03-05 19:06:39 +00:00
|
|
|
@echo "Cleaning up editor backup files"
|
|
|
|
find . -type f \( -name "*~" -or -name "#*" \) -delete
|
2012-03-06 03:47:30 +00:00
|
|
|
find . -type f \( -name "*.swp" \) -delete
|
2012-10-08 16:25:09 +00:00
|
|
|
@echo "Cleaning up manpage stuff"
|
2012-03-31 15:08:42 +00:00
|
|
|
find ./docs/man -type f -name "*.xml" -delete
|
2012-04-16 19:43:21 +00:00
|
|
|
find ./docs/man -type f -name "*.asciidoc" -delete
|
2012-10-08 16:25:09 +00:00
|
|
|
find ./docs/man/man3 -type f -name "*.3" -delete
|
2012-03-06 03:44:39 +00:00
|
|
|
@echo "Cleaning up output from test runs"
|
2012-04-17 14:39:36 +00:00
|
|
|
rm -rf test/test_data
|
2012-03-10 19:02:25 +00:00
|
|
|
@echo "Cleaning up RPM building stuff"
|
2012-04-17 14:39:36 +00:00
|
|
|
rm -rf MANIFEST rpm-build
|
2012-04-23 23:17:01 +00:00
|
|
|
@echo "Cleaning up Debian building stuff"
|
|
|
|
rm -rf debian
|
|
|
|
rm -rf deb-build
|
2012-10-09 20:04:55 +00:00
|
|
|
rm -rf docs/json
|
|
|
|
rm -rf docs/js
|
2013-03-26 07:19:45 +00:00
|
|
|
@echo "Cleaning up authors file"
|
|
|
|
rm -f AUTHORS.TXT
|
2012-02-25 01:05:05 +00:00
|
|
|
|
2012-03-16 00:21:10 +00:00
|
|
|
python:
|
2013-03-02 14:38:02 +00:00
|
|
|
$(PYTHON) setup.py build
|
2012-02-28 09:15:52 +00:00
|
|
|
|
2012-03-16 00:21:10 +00:00
|
|
|
install:
|
2013-03-02 14:38:02 +00:00
|
|
|
$(PYTHON) setup.py install
|
2012-02-28 09:15:52 +00:00
|
|
|
|
2012-10-09 10:10:32 +00:00
|
|
|
sdist: clean docs
|
2013-03-02 14:38:02 +00:00
|
|
|
$(PYTHON) setup.py sdist -t MANIFEST.in
|
2012-03-10 19:02:25 +00:00
|
|
|
|
|
|
|
rpmcommon: sdist
|
|
|
|
@mkdir -p rpm-build
|
|
|
|
@cp dist/*.gz rpm-build/
|
2012-08-01 12:52:37 +00:00
|
|
|
@sed -e 's#^Version:.*#Version: $(VERSION)#' -e 's#^Release:.*#Release: $(RPMRELEASE)%{?dist}#' $(RPMSPEC) >rpm-build/$(NAME).spec
|
2012-03-10 19:02:25 +00:00
|
|
|
|
|
|
|
srpm: rpmcommon
|
|
|
|
@rpmbuild --define "_topdir %(pwd)/rpm-build" \
|
|
|
|
--define "_builddir %{_topdir}" \
|
|
|
|
--define "_rpmdir %{_topdir}" \
|
|
|
|
--define "_srcrpmdir %{_topdir}" \
|
2012-04-18 15:00:59 +00:00
|
|
|
--define "_specdir $(RPMSPECDIR)" \
|
2012-03-10 19:02:25 +00:00
|
|
|
--define "_sourcedir %{_topdir}" \
|
2012-08-01 12:52:37 +00:00
|
|
|
-bs rpm-build/$(NAME).spec
|
|
|
|
@rm -f rpm-build/$(NAME).spec
|
2012-03-10 19:02:25 +00:00
|
|
|
@echo "#############################################"
|
|
|
|
@echo "Ansible SRPM is built:"
|
|
|
|
@echo " rpm-build/$(RPMNVR).src.rpm"
|
|
|
|
@echo "#############################################"
|
|
|
|
|
|
|
|
rpm: rpmcommon
|
|
|
|
@rpmbuild --define "_topdir %(pwd)/rpm-build" \
|
|
|
|
--define "_builddir %{_topdir}" \
|
|
|
|
--define "_rpmdir %{_topdir}" \
|
|
|
|
--define "_srcrpmdir %{_topdir}" \
|
2012-04-18 15:00:59 +00:00
|
|
|
--define "_specdir $(RPMSPECDIR)" \
|
2012-03-10 19:02:25 +00:00
|
|
|
--define "_sourcedir %{_topdir}" \
|
2012-11-07 23:09:18 +00:00
|
|
|
--define "_rpmfilename %%{NAME}-%%{VERSION}-%%{RELEASE}.%%{ARCH}.rpm" \
|
2013-03-11 15:22:37 +00:00
|
|
|
--define "__python `which $(PYTHON)`" \
|
2012-08-01 12:52:37 +00:00
|
|
|
-ba rpm-build/$(NAME).spec
|
|
|
|
@rm -f rpm-build/$(NAME).spec
|
2012-03-10 19:02:25 +00:00
|
|
|
@echo "#############################################"
|
|
|
|
@echo "Ansible RPM is built:"
|
2012-08-01 13:25:19 +00:00
|
|
|
@echo " rpm-build/$(RPMNVR).noarch.rpm"
|
2012-03-10 19:02:25 +00:00
|
|
|
@echo "#############################################"
|
2012-04-21 15:56:06 +00:00
|
|
|
|
2012-04-23 23:17:01 +00:00
|
|
|
debian: sdist
|
|
|
|
deb: debian
|
|
|
|
cp -r packaging/debian ./
|
|
|
|
chmod 755 debian/rules
|
|
|
|
fakeroot debian/rules clean
|
|
|
|
fakeroot dh_install
|
|
|
|
fakeroot debian/rules binary
|
2012-04-21 15:56:06 +00:00
|
|
|
|
|
|
|
# for arch or gentoo, read instructions in the appropriate 'packaging' subdirectory directory
|
|
|
|
|
2012-10-03 02:46:49 +00:00
|
|
|
modulepages:
|
2013-05-29 18:21:25 +00:00
|
|
|
PYTHONPATH=./lib $(PYTHON) hacking/module_formatter.py -A $(VERSION) -t man -o docs/man/man3/ --module-dir=library --template-dir=hacking/templates # --verbose
|
2012-10-09 20:04:55 +00:00
|
|
|
|
2012-10-10 22:46:51 +00:00
|
|
|
# because this requires Sphinx it is not run as part of every build, those building the RPM and so on can ignore this
|
|
|
|
|
2012-10-10 12:03:52 +00:00
|
|
|
webdocs:
|
2013-10-14 12:27:30 +00:00
|
|
|
(cd docsite/; make docs)
|
2013-04-12 21:41:16 +00:00
|
|
|
|