]> code.delx.au - gnu-emacs/blobdiff - doc/emacs/Makefile.in
* cmdargs.texi (General Variables): Setting
[gnu-emacs] / doc / emacs / Makefile.in
index 09986ecab0964a29257e8e13080de1b5f1a6b2ef..8f2078192b2c6c8312306fe23c7dc8762afca8e6 100644 (file)
@@ -1,7 +1,6 @@
 #### Makefile for the Emacs Manual
 
-# Copyright (C) 1994, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003,
-#   2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012  Free Software Foundation, Inc.
+# Copyright (C) 1994, 1996-2012 Free Software Foundation, Inc.
 
 # This file is part of GNU Emacs.
 
 # You should have received a copy of the GNU General Public License
 # along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.
 
+SHELL = /bin/sh
 
-# Where to find the source code.  $(srcdir) will be the man
-# subdirectory of the source tree.  This is
-# set by the configure script's `--srcdir' option.
+# Where to find the source code.  $(srcdir) will be the doc/emacs subdirectory
+# of the source tree.  This is set by configure's `--srcdir' option.
 srcdir=@srcdir@
-top_srcdir=@top_srcdir@
 
-# Tell make where to find source files; this is needed for the makefiles.
-VPATH=@srcdir@
+# Only for make dist.
+version=@version@
 
 ## Where the output files go.
 ## Note that the setfilename command in the .texi files assumes this.
-infodir=../../info
+## This is a bit funny.  Because the info files are in the
+## distribution tarfiles, they are always made in $scrdir/../../info,
+## even for out-of-tree builds.
+buildinfodir = $(srcdir)/../../info
 # Directory with the (customized) texinfo.tex file.
 texinfodir = $(srcdir)/../misc
 
-# The makeinfo program is part of the Texinfo distribution.
-# Use --force so that it generates output even if there are errors.
-MAKEINFO = makeinfo --force
+MKDIR_P = @MKDIR_P@
 
-INFO_TARGETS = $(infodir)/emacs
-DVI_TARGETS  = emacs.dvi
+INFO_EXT=@INFO_EXT@
+# Options used only when making info output.
+# --no-split is only needed because of MS-DOS.
+# For a possible alternative, see
+# http://lists.gnu.org/archive/html/emacs-devel/2011-01/msg01182.html
+INFO_OPTS=@INFO_OPTS@
 
+# The makeinfo program is part of the Texinfo distribution.
+# Use --force so that it generates output even if there are errors.
+MAKEINFO = @MAKEINFO@
+MAKEINFO_OPTS = --force --enable-encoding -I $(srcdir)
 
 TEXI2DVI = texi2dvi
 TEXI2PDF = texi2pdf
+DVIPS = dvips
 
-# The following rule does not work with all versions of `make'.
-.SUFFIXES: .texi .dvi
-.texi.dvi:
-       $(TEXI2DVI) $<
 
-ENVADD = TEXINPUTS="$(srcdir):$(texinfodir):$(TEXINPUTS)" MAKEINFO="$(MAKEINFO) -I$(srcdir)"
+ENVADD = TEXINPUTS="$(srcdir):$(texinfodir):$(TEXINPUTS)" \
+         MAKEINFO="$(MAKEINFO) $(MAKEINFO_OPTS)"
 
 
-EMACS_XTRA=\
+EMACS_XTRA= \
+       ${srcdir}/emacs-xtra.texi \
        $(srcdir)/arevert-xtra.texi \
        $(srcdir)/cal-xtra.texi \
        $(srcdir)/dired-xtra.texi \
@@ -66,6 +72,7 @@ EMACS_XTRA=\
 
 EMACSSOURCES= \
        ${srcdir}/emacs.texi \
+       ${srcdir}/emacsver.texi \
        ${srcdir}/doclicense.texi \
        ${srcdir}/gpl.texi \
        ${srcdir}/screen.texi \
@@ -86,7 +93,7 @@ EMACSSOURCES= \
        ${srcdir}/windows.texi \
        ${srcdir}/frames.texi \
        ${srcdir}/mule.texi \
-       ${srcdir}/major.texi \
+       ${srcdir}/modes.texi \
        ${srcdir}/indent.texi \
        ${srcdir}/text.texi \
        ${srcdir}/programs.texi \
@@ -98,6 +105,7 @@ EMACSSOURCES= \
        ${srcdir}/dired.texi \
        ${srcdir}/calendar.texi \
        ${srcdir}/misc.texi \
+       ${srcdir}/package.texi \
        ${srcdir}/custom.texi \
        ${srcdir}/trouble.texi \
        ${srcdir}/cmdargs.texi \
@@ -111,56 +119,84 @@ EMACSSOURCES= \
        ${srcdir}/kmacro.texi \
        $(EMACS_XTRA)
 
-info: $(infodir) $(INFO_TARGETS)
+## This seems pointless.  The info/ directory exists in both the
+## repository and the release tarfiles.
+mkinfodir = @${MKDIR_P} ${buildinfodir}
 
-$(infodir):
-       mkdir $@
+.PHONY: info dvi html pdf ps
 
-dvi: $(DVI_TARGETS)
+info: $(buildinfodir)/emacs$(INFO_EXT)
+dvi: emacs.dvi
+html: emacs.html
+pdf: emacs.pdf
+ps: emacs.ps
 
-# Note that all the Info targets build the Info files
-# in srcdir.  There is no provision for Info files
-# to exist in the build directory.
+# Note that all the Info targets build the Info files in srcdir.
+# There is no provision for Info files to exist in the build directory.
 # In a distribution of Emacs, the Info files should be up to date.
-
-emacs : $(infodir)/emacs
-
-$(infodir)/emacs: ${EMACSSOURCES}
-       cd $(srcdir); $(MAKEINFO) emacs.texi
+# Note: "<" is not portable in ordinary make rules.
+$(buildinfodir)/emacs$(INFO_EXT): ${EMACSSOURCES}
+       $(mkinfodir)
+       $(MAKEINFO) $(MAKEINFO_OPTS) $(INFO_OPTS) -o $@ ${srcdir}/emacs.texi
 
 emacs.dvi: ${EMACSSOURCES}
        $(ENVADD) $(TEXI2DVI) ${srcdir}/emacs.texi
 
+emacs.ps: emacs.dvi
+       $(DVIPS) -o $@ emacs.dvi
+
 emacs.pdf: ${EMACSSOURCES}
        $(ENVADD) $(TEXI2PDF) ${srcdir}/emacs.texi
 
+emacs.html: ${EMACSSOURCES}
+       $(MAKEINFO) $(MAKEINFO_OPTS) --html -o $@ ${srcdir}/emacs.texi
 
-emacs-xtra.dvi: emacs-xtra.texi $(EMACS_XTRA)
+emacs-xtra.dvi: $(EMACS_XTRA)
        $(ENVADD) $(TEXI2DVI) ${srcdir}/emacs-xtra.texi
 
-emacs-xtra.pdf: emacs-xtra.texi $(EMACS_XTRA)
+emacs-xtra.ps: emacs-xtra.dvi
+       $(DVIPS) -o $@ emacs-xtra.dvi
+
+emacs-xtra.pdf: $(EMACS_XTRA)
        $(ENVADD) $(TEXI2PDF) ${srcdir}/emacs-xtra.texi
 
+.PHONY: mostlyclean clean distclean maintainer-clean infoclean
 
+## Temp files.
 mostlyclean:
-       rm -f *.log *.cp *.fn *.ky *.op *.ops *.pg *.vr core *.tp *.core
-       rm -f *.aux *.cps *.fns *.kys *.pgs *.vrs *.toc
+       rm -f *.aux *.log *.toc *.cp *.cps *.fn *.fns *.ky *.kys \
+         *.op *.ops *.pg *.pgs *.tp *.tps *.vr *.vrs
 
+## Products not in the release tarfiles.
 clean: mostlyclean
-       rm -f *.dvi
+       rm -f emacs.dvi emacs-xtra.dvi emacs.pdf emacs-xtra.pdf \
+         emacs.ps emacs-xtra.ps
+       rm -rf emacs.html/
+       rm -f emacs-manual-${version}.tar*
 
 distclean: clean
-#      rm -f Makefile
-
-maintainer-clean: distclean
-       for file in $(INFO_TARGETS); do rm -f $${file}*; done
-
-
-# Formerly this directory had texindex.c and getopt.c in it
-# and this makefile built them to make texindex.
-# That caused trouble because this is run entirely in the source directory.
-# Since we expect to get texi2dvi from elsewhere,
-# it is ok to expect texindex from elsewhere also.
 
+## In the standalone tarfile, the clean rule runs this.
+infoclean:
+       -cd $(buildinfodir) && rm -f emacs$(INFO_EXT) emacs$(INFO_EXT)-[1-9] emacs$(INFO_EXT)-[1-9][0-9]
+
+maintainer-clean: distclean infoclean
+
+.PHONY: dist
+
+## Make a standalone tarfile of the Emacs manual sources.
+## The [c] is a dumb way to prevent configure expanding it.
+dist:
+       rm -rf emacs-manual-${version}
+       mkdir emacs-manual-${version}
+       cp ${srcdir}/*.texi ${texinfodir}/texinfo.tex \
+         ${srcdir}/ChangeLog* emacs-manual-${version}/
+       sed -e 's/@sr[c]dir@/./' -e 's/^\(texinfodir *=\).*/\1 ./' \
+         -e 's/^\(buildinfodir *=\).*/\1 ./' \
+         -e 's/^\(clean:.*\)/\1 infoclean/' \
+         -e "s/@ver[s]ion@/${version}/" \
+         ${srcdir}/Makefile.in > emacs-manual-${version}/Makefile
+       tar -cf emacs-manual-${version}.tar emacs-manual-${version}
+       rm -rf emacs-manual-${version}
 
 ### Makefile ends here