8c94e9d56361d31ae8c7bf6f4fefa2ceb7b91094
[ncurses.git] / dist.mk
1 ##############################################################################
2 # Copyright 2018-2019,2020 Thomas E. Dickey                                  #
3 # Copyright 1998-2017,2018 Free Software Foundation, Inc.                    #
4 #                                                                            #
5 # Permission is hereby granted, free of charge, to any person obtaining a    #
6 # copy of this software and associated documentation files (the "Software"), #
7 # to deal in the Software without restriction, including without limitation  #
8 # the rights to use, copy, modify, merge, publish, distribute, distribute    #
9 # with modifications, sublicense, and/or sell copies of the Software, and to #
10 # permit persons to whom the Software is furnished to do so, subject to the  #
11 # following conditions:                                                      #
12 #                                                                            #
13 # The above copyright notice and this permission notice shall be included in #
14 # all copies or substantial portions of the Software.                        #
15 #                                                                            #
16 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR #
17 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,   #
18 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL    #
19 # THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER      #
20 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING    #
21 # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER        #
22 # DEALINGS IN THE SOFTWARE.                                                  #
23 #                                                                            #
24 # Except as contained in this notice, the name(s) of the above copyright     #
25 # holders shall not be used in advertising or otherwise to promote the sale, #
26 # use or other dealings in this Software without prior written               #
27 # authorization.                                                             #
28 ##############################################################################
29 # $Id: dist.mk,v 1.1360 2020/07/11 08:26:05 tom Exp $
30 # Makefile for creating ncurses distributions.
31 #
32 # This only needs to be used directly as a makefile by developers, but
33 # configure mines the current version number out of here.  To move
34 # to a new version number, just edit this file and run configure.
35 #
36 SHELL = /bin/sh
37
38 # These define the major/minor/patch versions of ncurses.
39 NCURSES_MAJOR = 6
40 NCURSES_MINOR = 2
41 NCURSES_PATCH = 20200711
42
43 # We don't append the patch to the version, since this only applies to releases
44 VERSION = $(NCURSES_MAJOR).$(NCURSES_MINOR)
45
46 WEBSITE = https://invisible-island.net
47 HOMEPAGE = $(WEBSITE)/ncurses
48
49 # The most recent html files were generated with lynx 2.8.6 (or later), using
50 # ncurses configured with
51 #       --without-manpage-renames
52 # on Debian/testing.  The -scrollbar and -width options are used to make lynx
53 # use 79 columns as it did in 2.8.5 and before.
54 DUMP    = lynx -dump -scrollbar=0 -width=79 -display_charset=US-ASCII
55 DUMP2   = $(DUMP) -nolist
56
57 # gcc's file is "gnathtml.pl"
58 GNATHTML= gnathtml
59
60 # man2html is a Perl script which assumes that pages are fixed size.
61 # Not all man programs agree with this assumption; some use half-spacing, which
62 # has the effect of lengthening the text portion of the page -- so man2html
63 # would remove some text.  The man program on Redhat 6.1 appears to work with
64 # man2html if we set the top/bottom margins to 6 (the default is 7).  Newer
65 # versions of 'man' leave no margin (and make it harder to sync with pages).
66 MAN2HTML= man2html -botm=0 -topm=0 -cgiurl '$$title.$$section$$subsection.html' -index
67
68 ALL     = ANNOUNCE doc/html/announce.html doc/ncurses-intro.doc doc/hackguide.doc manhtml adahtml
69
70 all :   $(ALL)
71
72 dist:   $(ALL)
73         (cd ..;  tar cvf ncurses-$(VERSION).tar `sed <ncurses-$(VERSION)/MANIFEST 's/^./ncurses-$(VERSION)/'`;  gzip ncurses-$(VERSION).tar)
74
75 distclean:
76         rm -f $(ALL) subst.tmp subst.sed
77
78 # Don't mess with announce.html.in unless you have lynx available!
79 doc/html/announce.html: announce.html.in
80         sed \
81                 -e 's,@VERSION@,$(VERSION),g' \
82                 -e 's,@WEBSITE@,$(WEBSITE),g' \
83                 -e 's,@HOMEPAGE@,$(HOMEPAGE),g' <announce.html.in > $@
84
85 ANNOUNCE : doc/html/announce.html
86         $(DUMP2) doc/html/announce.html > $@
87
88 doc/ncurses-intro.doc: doc/html/ncurses-intro.html
89         $(DUMP2) doc/html/ncurses-intro.html > $@
90 doc/hackguide.doc: doc/html/hackguide.html
91         $(DUMP2) doc/html/hackguide.html > $@
92
93 # The distributed html files are formatted using
94 #       configure --without-manpage-renames
95 #
96 # The edit_man.sed script is built as a side-effect of installing the manpages.
97 # If that conflicts with the --without-manpage-renames, you can install those
98 # in a different location using the --with-install-prefix option of the
99 # configure script.
100 MANPROG = tbl | nroff -mandoc -rLL=78n -rLT=78n -Tascii
101
102 manhtml:
103         @for f in doc/html/man/*.html; do \
104            test -f $$f || continue; \
105            case $$f in \
106            */index.html) ;; \
107            *) rm -f $$f ;; \
108            esac; \
109         done
110         @mkdir -p doc/html/man
111         @rm -f subst.tmp ;
112         @for f in man/*.[0-9]*; do \
113            m=`basename $$f` ;\
114            x=`echo $$m | awk -F. '{print $$2;}'` ;\
115            xu=`echo $$x | dd conv=ucase 2>/dev/null` ;\
116            if [ "$${x}" != "$${xu}" ]; then \
117              echo "s/$${xu}/$${x}/g" >> subst.tmp ;\
118            fi ;\
119         done
120         # change some things to make weblint happy:
121         @cat man_alias.sed           >> subst.tmp
122         @echo 's/<B>/<STRONG>/g'     >> subst.tmp
123         @echo 's/<\/B>/<\/STRONG>/g' >> subst.tmp
124         @echo 's/<I>/<EM>/g'         >> subst.tmp
125         @echo 's/<\/I>/<\/EM>/g'     >> subst.tmp
126         @misc/csort < subst.tmp | uniq > subst.sed
127         @echo '/<\/TITLE>/a\' >> subst.sed
128         @echo '<link rel="author" href="mailto:bug-ncurses@gnu.org">\' >> subst.sed
129         @echo '<meta http-equiv="Content-Type" content="text\/html; charset=iso-8859-1">' >> subst.sed
130         @rm -f subst.tmp
131         @for f in man/*.[0-9]* ; do \
132            m=`basename $$f` ;\
133            T=`egrep '^.TH' $$f|sed -e 's/^.TH //' -e s'/"//g' -e 's/[   ]\+$$//'` ; \
134            g=$${m}.html ;\
135            if [ -f doc/html/$$g ]; then chmod +w doc/html/$$g; fi;\
136            echo "Converting $$m to HTML" ;\
137            echo '<!-- ' > doc/html/man/$$g ;\
138            egrep '^.\\"[^#]' $$f | \
139                 sed     -e 's/\$$/@/g' \
140                         -e 's/^.../  */' \
141                         -e 's/</\&lt;/g' \
142                         -e 's/>/\&gt;/g' \
143            >> doc/html/man/$$g ;\
144            echo '-->' >> doc/html/man/$$g ;\
145            ./edit_man.sh normal editing /usr/man man $$f | \
146                    $(MANPROG) | \
147                    tr '\255' '-' | \
148                    $(MAN2HTML) \
149                         -title "$$T" \
150                         -aliases man/manhtml.aliases \
151                         -externs man/manhtml.externs | \
152                    sed -f subst.sed |\
153                    sed -e 's/"curses.3x.html"/"ncurses.3x.html"/g' \
154            >> doc/html/man/$$g ;\
155         done
156         @rm -f subst.sed
157
158 #
159 # Please note that this target can only be properly built if the build of the
160 # Ada95 subdir has been done.  The reason is, that the gnathtml tool uses the
161 # .ali files generated by the Ada95 compiler during the build process.  These
162 # .ali files contain cross referencing information required by gnathtml.
163 adahtml:
164         if [ ! -z "$(GNATHTML)" ]; then \
165           (cd ./Ada95/gen ; make html GNATHTML=$(GNATHTML) ) ;\
166         fi
167
168 # This only works on a clean source tree, of course.
169 MANIFEST:
170         -rm -f $@
171         touch $@
172         find . -type f -print |misc/csort | fgrep -v .lsm |fgrep -v .spec >$@
173
174 TAGS:
175         etags */*.[ch]
176
177 # Makefile ends here