summaryrefslogtreecommitdiffabout
path: root/doc/Makefile.am
blob: f1e7c90c6cb416af66297458b79ea77d62cdd1d4 (plain)
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
# This file is part of GNU Pies.
# Copyright (C) 2005-2010, 2013, 2017 Sergey Poznyakoff
#
# GNU Pies is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3, or (at your option)
# any later version.
#
# GNU Pies is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with GNU Pies.  If not, see <http://www.gnu.org/licenses/>.

info_TEXINFOS=pies.texi
pies_TEXINFOS=\
 fdl.texi\
 inetd.texi\
 macros.texi\
 usr-acl.texi

EXTRA_DIST = \
 gendocs_template

clean-local:
	@rm -rf manual

# Checking

AM_MAKEINFOFLAGS = @IMPRIMATUR_MAKEINFOFLAGS@
imprimatur_INPUT=$(info_TEXINFOS) $(pies_TEXINFOS)
include ../imprimatur/imprimatur.mk
CHECK_DOCS=$(top_srcdir)/@IMPRIMATUR_MODULE_DIR@/check-docs.sh

check-format: imprimatur-format imprimatur-check-sentence-spacing

check-options:
	@$(CHECK_DOCS) options \
	   '/OPTIONS_BEGIN/,/OPTIONS_END/{s/OPTION( *\([^,][^,]*\),.*/\1/pg;s/ALIAS(\([^,][^,)]*\)[,)]/\1/p;}' \
	   's/@opindex *\([^@,]*\).*/\1/p' \
	   $(top_srcdir)/src/cmdline.opt -- \
	   $(MAKEINFO) $(AM_MAKEINFOFLAGS) $(MAKEINFOFLAGS) -I $(srcdir) -E - \
		$(info_TEXINFOS)

check-config:
	@$(CHECK_DOCS) 'configuration statements' \
	   '/pies_keywords\[\] *= *{/,/^}/s/[ \t]*{ *"\([^,"]*\)".*/\1/pg' \
	   's/@deffnx\{0,1\} {Config} *\([^@,]*\).*/\1/p' \
	   $(top_srcdir)/src/pies.c -- \
	   $(MAKEINFO) $(AM_MAKEINFOFLAGS) $(MAKEINFOFLAGS) -I $(srcdir) -E - \
		$(info_TEXINFOS)

check-sub-config:
	@sed -n '/pies_keywords\[\] *= *{/,/^}/{p}' ../src/pies.c|tr  '\n{' ' \n'|sed -n '/grecs_type_section/s/"\([^"]*\)".*grecs_type_section,[^,]*,[^,]*,[^,]*,[^,]*,[^,]*, *\(.*\) *}.*/\1 \2/p' | \
        while read ident kw; do \
	   $(CHECK_DOCS) "$$ident configuration statements" \
	   "/$$kw"'\[\] *= *{/,/^}/s/[ \t]*{ *"\([^,"]*\)".*/\1/pg' \
	   "s/@deffnx\{0,1\} {Config: *$${ident}}"' *\([^@,]*\).*/\1/p' \
	   $(top_srcdir)/src/pies.c $(top_srcdir)/src/acl.c -- \
	   $(MAKEINFO) $(AM_MAKEINFOFLAGS) $(MAKEINFOFLAGS) -I $(srcdir) -E - \
		$(info_TEXINFOS); \
        done

all-check-docs: imprimatur-basic-checks \
                check-options check-config check-sub-config

check-docs:
	@$(MAKE) -k all-check-docs

#
master-menu: imprimatur-master-menu
untabify: imprimatur-untabify
final: imprimatur-final

GENDOCS=$(srcdir)/gendocs.sh
EXTRA_DIST += gendocs.sh

TEXI2DVI=texi2dvi -t '@set $(RENDITION)' -I $(top_srcdir)/imprimatur

.PHONY: manual man-tar
# Make sure you set TEXINPUTS.
# TEXINPUTS=/usr/share/texmf/pdftex/plain/misc/ is ok for most distributions
manual:
	rm -rf manual
	TEXINPUTS=$(srcdir):$(top_srcdir)/build-aux:$(TEXINPUTS) \
	 MAKEINFO="$(MAKEINFO) $(AM_MAKEINFOFLAGS) $(MAKEINFOFLAGS)" \
	 TEXI2DVI="$(TEXI2DVI) -t @finalout" \
	 $(GENDOCS) --no-copy-images $(PACKAGE) '$(PACKAGE_NAME) manual'

manual.tar.bz2: manual
	tar cfj manual.tar.bz2 manual

man-tar: manual.tar.bz2

Return to:

Send suggestions and report system problems to the System administrator.