Replace raw_input with six.moves.input
[mediagoblin.git] / Makefile.in
... / ...
CommitLineData
1# Makefile.in
2#
3# Copyright © 2012, 2013 Brandon Invergo <brandon@invergo.net>
4# Copyright © 2014, 2015 Christopher Allan Webber <cwebber@dustycloud.org>
5#
6# Copying and distribution of this file, with or without modification,
7# are permitted in any medium without royalty provided the copyright
8# notice and this notice are preserved. This file is offered as-is,
9# without any warranty.
10
11# List whatever files you want to include in your source distribution here.
12# You can include whole directories but note that *everything* under that
13# directory will be included
14DISTFILES = PKG-INFO Makefile.in configure setup.py install-sh
15
16DESTDIR =
17VPATH = @srcdir@
18PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
19PACKAGE_NAME = @PACKAGE_NAME@
20PACKAGE_STRING = @PACKAGE_STRING@
21PACKAGE_TARNAME = @PACKAGE_TARNAME@
22PACKAGE_DISTNAME = ${PACKAGE_NAME}-${PACKAGE_VERSION}
23PACKAGE_URL = @PACKAGE_URL@
24PACKAGE_VERSION = @PACKAGE_VERSION@
25PATH_SEPARATOR = @PATH_SEPARATOR@
26PYTHON = @PYTHON@
27VIRTUALENV = @VIRTUALENV@
28SHELL = @SHELL@
29MKDIR_P = @MKDIR_P@
30INSTALL = @INSTALL@
31INSTALL_PROGRAM = @INSTALL_PROGRAM@
32INSTALL_DATA = @INSTALL_DATA@
33INSTALL_SCRIPT = @INSTALL_SCRIPT@
34docdir = @docdir@
35dvidir = @dvidir@
36exec_prefix = @exec_prefix@
37htmldir = @htmldir@
38includedir = @includedir@
39infodir = @infodir@
40prefix = @prefix@
41srcdir = @srcdir@
42abs_srcdir = @abs_srcdir@
43datadir = @datadir@
44datarootdir = @datarootdir@
45pkgdatadir = $(datadir)/@PACKAGE_NAME@
46pkgincludedir = $(includedir)/@PACKAGE_NAME@
47PYTHONPATH = $(pythondir)$(PATH_SEPARATOR)$(DESTDIR)$(pythondir)
48USE_PYTHON3 = @USE_PYTHON3@
49
50EXTLIB_INSTALLS = extlib/jquery extlib/video.js extlib/leaflet extlib/tinymce
51
52# pkgpythondir = @pkgpythondir@
53# pkgpyexecdir = @pkgpyexecdir@
54# pythondir = @pythondir@
55# pyexecdir = @pyexecdir@
56# SPHINXBUILD = @SPHINXBUILD@
57# POSTGRES = @POSTGRES@
58
59
60# Maybe add a virtualenv prefix to a command
61ifneq ($(VIRTUALENV),no)
62# virtualenv specified to be included by config (default)
63# ... we only use virtualenv for local development, we don't
64# auto-deploy to it.
65
66maybe_venved = ./bin/
67maybe_venved_python = ./bin/python
68# Yes, build the virtualenv as a dependency!
69maybe_venv_dep = virtualenv
70# And to clean up!
71maybe_venv_clean = clean-virtualenv
72
73else
74# --without-virtualenv must have been passed in... don't build
75# a local virtualenv or use such commands
76maybe_venved =
77maybe_venved_python = $(PYTHON)
78# No need for commands to build virtualenv as a dependency!
79maybe_venv_dep =
80# Nor to clean up!
81maybe_venv_clean =
82endif
83
84.PHONY: all install uninstall distclean info install-html html \
85install-pdf pdf install-dvi dvi install-ps ps clean dist check \
86installdirs i18n virtualenv docs extlib
87
88# update postgresql
89
90all: develop
91
92docs:
93ifneq ($(VIRTUALENV),no)
94 source bin/activate && cd docs && make html
95else
96 cd docs && make html
97endif
98
99# In the future we may provide more options than just npm/bower here
100# eg, we may support guix updating.
101extlib:
102 ./devtools/update_extlib.sh
103
104develop: $(maybe_venv_dep) i18n mediagoblin.ini
105
106# NEVER clobber a user's mediagoblin.ini once they've defined it
107mediagoblin.ini:
108 cp -n mediagoblin.example.ini mediagoblin.ini
109
110# base-configs: paste.ini mediagoblin.example.ini
111
112install: installdirs
113 $(maybe_venved_python) $(srcdir)/setup.py install --prefix=$(DESTDIR)$(prefix)
114
115
116# In the future, maybe we can compile the individual .po files here?
117i18n: $(maybe_venv_dep)
118 ./devtools/compile_translations.sh
119
120
121ifneq ($(VIRTUALENV),no)
122./bin/python:
123 rm -f ./bin/python
124 ${VIRTUALENV} --system-site-packages --python=$(PYTHON) .
125 ./bin/python setup.py develop --upgrade
126
127virtualenv: bin/python extlib
128
129clean-virtualenv:
130 rm -rf ./bin/
131 rm -rf ./lib/
132 rm -rf ./include/
133endif
134
135# setup.py doesn't (yet) support an uninstall command, so until it does, you
136# must manually remove everything that was installed here. The following example
137# should remove a basic package installed via setup.py, but please double- and
138# triple-check it so that you don't remove something you shouldn't!
139# Be sure to remove any extra files you install, such as binaries or documentation!
140#
141# uninstall:
142# rm -rvf $(pkgpythondir)
143# rm -v $(pythondir)/$(PACKAGE_DISTNAME)-*.egg-info
144#
145
146# We don't know what this does yet.
147# Originally:
148## Just use the usual setup.py clean command
149#clean:
150# $(maybe_venved_python) setup.py clean
151clean:
152 @echo "No rule to clean house, yet."
153 @echo "distclean works but might do more than you want. :)"
154
155
156# It's not obvious to me whether the virtualenv/bower/npm things should be
157# auto-cleaned as part of distclean. I'm leaning towards "yes" for now but
158# I'm not really happy about that.
159
160# Clean up the output of configure
161distclean: $(maybe_venv_clean)
162 rm -vf $(srcdir)/config.log
163 rm -vf $(srcdir)/config.status
164 rm -rvf $(srcdir)/autom4te.cache
165 rm -vf $(srcdir)/aclocal.m4
166 rm -rf $(EXTLIB_INSTALLS)
167 rm -rf node_modules
168 rm -vf $(srcdir)/Makefile
169
170check:
171 ./runtests.sh
172
173###########################################################################
174# These things aren't really tested / supported yet.
175###########################################################################
176
177
178## NOTE: We don't use this yet, we use ./devtools/maketarball.sh
179## We can't switch out ./devtools/maketarball.sh in here because
180## it requires a git revision as a first argument, which
181## doesn't always work here
182
183dist: $(maybe_venv_dep)
184 $(maybe_venved_python) setup.py sdist
185
186# setup.py might complain if a directory doesn't exist so just in case, make the directory
187# here
188installdirs:
189 $(MKDIR_P) $(DESTDIR)$(prefix)
190
191######################
192# Needs to be updated?
193######################
194
195# The following show how to install documentation. In this example,
196# docs are built from a separate Makefile contained in the docs
197# directory which uses the SPHINXBUILD variable to store the location
198# of the sphinx-build (Python doc tool) binary to use.
199
200$(DESTDIR)$(infodir)/mediagoblin.info: docs/build/texinfo/mediagoblin.info
201 $(POST_INSTALL)
202 $(INSTALL_DATA) @< $(DESTDIR)$@
203 if $(SHELL) -c 'install-info --version' >/dev/null 2>&1; then
204 install-info --dir-file=$(DESTDIR)$(infodir)/dir \
205 $(DESTDIR)$(infodir)/foo.info;
206 else true; fi
207
208info: docs/build/texinfo/mediagoblin.info
209
210docs/build/texinfo/mediagoblin.info: $(wildcard docs/source/*)
211ifneq ($(VIRTUALENV),no)
212 source bin/activate && cd docs && make info
213else
214 cd docs && make info
215endif
216
217
218install-html: html installdirs
219 $(INSTALL_DATA) docs/build/html/* $(DESTDIR)$(htmldir)
220
221html: docs