X-Git-Url: https://git.cameronkatri.com/mandoc.git/blobdiff_plain/142d3c43402e6904480a35ff0f970621b9a5f700..6f9d9cf4d38fa9a821a61f50e3ee7caa2306cdb5:/Makefile

diff --git a/Makefile b/Makefile
index 1c78b441..84d51e65 100644
--- a/Makefile
+++ b/Makefile
@@ -1,160 +1,319 @@
-VERSION	= 1.0.3
+.SUFFIXES:	.html .sgml
 
-# FIXME
-CFLAGS += -W -Wall -Wno-unused-parameter -g -DDEBUG
+VERSION	= 1.3.18
+VDATE	= 04 March 2009
 
-LNS	= mdocml.ln html.ln xml.ln libmdocml.ln roff.ln ml.ln mlg.ln \
-	  compat.ln tokens.ln literals.ln tags.ln noop.ln
+BINDIR		= $(PREFIX)/bin
+INCLUDEDIR	= $(PREFIX)/include
+LIBDIR		= $(PREFIX)/lib
+MANDIR		= $(PREFIX)/man
 
-LLNS	= llib-lmdocml.ln
+INSTALL_PROGRAM	= install -m 0755
+INSTALL_DATA	= install -m 0444
+INSTALL_LIB	= install -m 0644
+INSTALL_MAN	= $(INSTALL_DATA)
 
-LIBS	= libmdocml.a
-
-OBJS	= mdocml.o html.o xml.o libmdocml.o roff.o ml.o mlg.o \
-	  compat.o tokens.o literals.o tags.o noop.o
-
-SRCS	= mdocml.c html.c xml.c libmdocml.c roff.c ml.c mlg.c \
-	  compat.c tokens.c literals.c tags.c noop.c
-
-HEADS	= libmdocml.h private.h ml.h roff.h html.h
-
-MANS	= mdocml.1 index.7
-
-HTML	= index.html mdocml.html 
-
-XML	= index.xml
-
-TEXT	= index.txt
-
-CLEAN	= mdocml mdocml.tgz $(LLNS) $(LNS) $(OBJS) $(LIBS) $(HTML) \
-	  $(XML) $(TEXT)
-
-INSTALL	= Makefile $(HEADS) $(SRCS) $(MANS)
-
-FAIL	= test.0 test.1 test.2 test.3 test.4 test.5 test.6 \
-	  test.15 test.20 test.22 test.24 test.26 test.27 test.30 \
-	  test.36 test.37 test.40 test.50 test.61 test.64 test.65 \
-	  test.66 test.69 test.70
-
-SUCCEED	= test.7 test.8 test.9 test.10 test.11 test.12 test.13 \
-	  test.14 test.16 test.17 test.18 test.19 test.21 test.23 \
-	  test.25 test.28 test.29 test.31 test.32 test.33 test.34 \
-	  test.35 test.38 test.39 test.41 test.42 test.43 test.44 \
-	  test.45 test.46 test.47 test.48 test.49 test.51 test.52 \
-	  test.54 test.55 test.56 test.57 test.58 test.59 test.60 \
-	  test.62 test.63 test.67 test.68 test.71 test.72 test.73
-
-all: mdocml
-
-lint: llib-lmdocml.ln
-
-dist: mdocml.tgz mdocml-port.tgz
-
-www: all $(HTML) $(XML) $(TEXT)
-
-regress: mdocml
-	@for f in $(FAIL); do \
-		echo "./mdocml $$f" ; \
-		./mdocml -v $$f 1>/dev/null 2>/dev/null || continue ; \
-	done
-	@for f in $(SUCCEED); do \
-		echo "./mdocml $$f" ; \
-		./mdocml -v $$f 1>/dev/null || exit 1 ; \
-	done
-
-mdocml: mdocml.o libmdocml.a
-	$(CC) $(CFLAGS) -o $@ mdocml.o libmdocml.a
+CFLAGS += -W -Wall -Wstrict-prototypes -Wno-unused-parameter -g 
+
+LIBLNS	= macro.ln mdoc.ln hash.ln strings.ln xstd.ln argv.ln \
+	  validate.ln action.ln 
+
+TREELNS	= mdoctree.ln mmain.ln 
+
+TERMLNS	= mdoctree.ln mmain.ln term.ln
+
+LINTLNS	= mdoclint.ln mmain.ln
+
+LNS	= $(LIBLNS) $(TREELNS) $(TERMLNS)
+
+LLNS	= llib-llibmdoc.ln llib-lmdoctree.ln llib-lmdocterm.ln
+
+LIBS	= libmdoc.a
+
+LIBOBJS	= macro.o mdoc.o hash.o strings.o xstd.o argv.o \
+	  validate.o action.o
+
+TERMOBJS= mdocterm.o mmain.o term.o
+
+TREEOBJS= mdoctree.o mmain.o
+
+LINTOBJS= mdoclint.o mmain.o
+
+OBJS	= $(LIBOBJS) $(TERMOBJS) $(TREEOBJS)
+
+SRCS	= macro.c mdoc.c hash.c strings.c xstd.c argv.c validate.c \
+	  action.c term.c mdoctree.c mdocterm.c mmain.c mdoclint.c
+
+HEADS	= mdoc.h private.h term.h mmain.h
+
+SGMLS	= index.sgml
+
+HTMLS	= index.html
+
+STATICS	= style.css external.png
+
+TARGZS	= mdocml-$(VERSION).tar.gz mdocml-oport-$(VERSION).tar.gz \
+	  mdocml-nport-$(VERSION).tar.gz
+
+MANS	= mdoctree.1 mdocterm.1 mdoclint.1 mdoc.3
+
+BINS	= mdocterm mdoctree mdoclint
+
+CLEAN	= $(BINS) $(LNS) $(LLNS) $(LIBS) $(OBJS) $(HTMLS) \
+	  $(TARGZS)
+
+INSTALL	= $(SRCS) $(HEADS) Makefile DESCR $(MANS) $(SGMLS) \
+	  $(STATICS) Makefile.netbsd Makefile.openbsd
+
+FAIL	= regress/test.empty \
+	  regress/test.prologue.00 \
+	  regress/test.prologue.01 \
+	  regress/test.prologue.02 \
+	  regress/test.prologue.03 \
+	  regress/test.prologue.04 \
+	  regress/test.prologue.06 \
+	  regress/test.prologue.13 \
+	  regress/test.prologue.15 \
+	  regress/test.prologue.16 \
+	  regress/test.prologue.18 \
+	  regress/test.prologue.19 \
+	  regress/test.prologue.21 \
+	  regress/test.prologue.22 \
+	  regress/test.prologue.23 \
+	  regress/test.prologue.24 \
+	  regress/test.prologue.25 \
+	  regress/test.prologue.26 \
+	  regress/test.prologue.27 \
+	  regress/test.prologue.28 \
+	  regress/test.prologue.29 \
+	  regress/test.prologue.30 \
+	  regress/test.prologue.31 \
+	  regress/test.prologue.32 \
+	  regress/test.prologue.33 \
+	  regress/test.sh.03 \
+	  regress/test.escape.01 \
+	  regress/test.escape.02 \
+	  regress/test.escape.03 \
+	  regress/test.escape.04 \
+	  regress/test.escape.06 \
+	  regress/test.escape.07 \
+	  regress/test.escape.08 \
+	  regress/test.escape.09 \
+	  regress/test.escape.11 \
+	  regress/test.escape.12 \
+	  regress/test.escape.14 \
+	  regress/test.argv.01
+
+SUCCEED	= regress/test.prologue.05 \
+	  regress/test.prologue.07 \
+	  regress/test.prologue.08 \
+	  regress/test.prologue.09 \
+	  regress/test.prologue.10 \
+	  regress/test.prologue.11 \
+	  regress/test.prologue.12 \
+	  regress/test.prologue.14 \
+	  regress/test.prologue.17 \
+	  regress/test.prologue.20 \
+	  regress/test.sh.00 \
+	  regress/test.name.00 \
+	  regress/test.name.01 \
+	  regress/test.name.02 \
+	  regress/test.name.03 \
+	  regress/test.list.00 \
+	  regress/test.list.01 \
+	  regress/test.list.02 \
+	  regress/test.list.03 \
+	  regress/test.list.04 \
+	  regress/test.list.05 \
+	  regress/test.list.06 \
+	  regress/test.list.07 \
+	  regress/test.sh.01 \
+	  regress/test.sh.02 \
+	  regress/test.escape.00 \
+	  regress/test.escape.05 \
+	  regress/test.escape.10 \
+	  regress/test.escape.13 \
+	  regress/test.argv.00
+
+REGRESS	= $(FAIL) $(SUCCEED)
+
+all:	$(BINS)
+
+lint:	$(LLNS)
 
 clean:
 	rm -f $(CLEAN)
 
-index.html: index.7 mdocml.css
-	./mdocml -Wall -fhtml -e -o $@ index.7
+cleanlint:
+	rm -f $(LNS) $(LLNS)
 
-index.xml: index.7 mdocml.css
-	./mdocml -Wall -o $@ index.7
+dist:	mdocml-$(VERSION).tar.gz
 
-index.txt: index.7
-	cp -f index.7 index.txt
+port:	mdocml-oport-$(VERSION).tar.gz mdocml-nport-$(VERSION).tar.gz
 
-mdocml.html: mdocml.1 mdocml.css
-	./mdocml -Wall -fhtml -e -o $@ mdocml.1
+www:	$(HTMLS) $(TARGZS)
 
-install-www: www dist
-	install -m 0644 mdocml.tgz $(PREFIX)/mdocml-$(VERSION).tgz
-	install -m 0644 mdocml.tgz $(PREFIX)/mdocml.tgz
-	install -m 0644 mdocml-port.tgz $(PREFIX)/mdocml-port-$(VERSION).tgz
-	install -m 0644 mdocml-port.tgz $(PREFIX)/mdocml-port.tgz
-	install -m 0644 $(HTML) $(XML) $(TEXT) $(PREFIX)/
+installwww: www
+	install -m 0444 $(HTMLS) $(STATICS) $(PREFIX)/
+	install -m 0444 mdocml-$(VERSION).tar.gz $(PREFIX)/snapshots/
+	install -m 0444 mdocml-$(VERSION).tar.gz $(PREFIX)/snapshots/mdocml.tar.gz
+	install -m 0444 mdocml-oport-$(VERSION).tar.gz $(PREFIX)/ports-openbsd/
+	install -m 0444 mdocml-oport-$(VERSION).tar.gz $(PREFIX)/ports-openbsd/mdocml.tar.gz
+	install -m 0444 mdocml-nport-$(VERSION).tar.gz $(PREFIX)/ports-netbsd/
+	install -m 0444 mdocml-nport-$(VERSION).tar.gz $(PREFIX)/ports-netbsd/mdocml.tar.gz
 
-mdocml.tgz: $(INSTALL)
-	mkdir -p .dist/mdocml/mdocml-$(VERSION)/
-	install -m 0644 $(INSTALL) .dist/mdocml/mdocml-$(VERSION)/
-	( cd .dist/mdocml/ && tar zcf ../../$@ mdocml-$(VERSION)/ )
+regress: mdoclint
+	@for f in $(FAIL); do \
+		echo "./mdoclint $$f" ; \
+		./mdoclint $$f 2>/dev/null || continue ; exit 1 ; done
+	@for f in $(SUCCEED); do \
+		echo "./mdoclint $$f" ; \
+		./mdoclint $$f 2>/dev/null || exit 1 ; done
+
+install:
+	mkdir -p $(BINDIR)
+	mkdir -p $(INCLUDEDIR)
+	mkdir -p $(LIBDIR)/lib
+	mkdir -p $(MANDIR)/man1
+	mkdir -p $(MANDIR)/man3
+	$(INSTALL_PROGRAM) mdocterm $(BINDIR)
+	$(INSTALL_PROGRAM) mdoctree $(BINDIR)
+	$(INSTALL_PROGRAM) mdoclint $(BINDIR)
+	$(INSTALL_MAN) mdocterm.1 $(MANDIR)/man1
+	$(INSTALL_MAN) mdoctree.1 $(MANDIR)/man1
+	$(INSTALL_MAN) mdoclint.1 $(MANDIR)/man1
+	$(INSTALL_MAN) mdoc.3 $(MANDIR)/man3
+	$(INSTALL_LIB) libmdoc.a $(LIBDIR)
+	$(INSTALL_DATA) mdoc.h $(INCLUDEDIR)
+
+uninstall:
+	rm -f $(BINDIR)/mdocterm
+	rm -f $(BINDIR)/mdoctree
+	rm -f $(BINDIR)/mdoclint
+	rm -f $(MANDIR)/man1/mdocterm.1
+	rm -f $(MANDIR)/man1/mdoctree.1
+	rm -f $(MANDIR)/man1/mdoclint.1
+	rm -f $(MANDIR)/man3/mdoc.3
+	rm -f $(LIBDIR)/libmdoc.a
+	rm -f $(INCLUDEDIR)/mdoc.h
+
+macro.ln: macro.c private.h
+macro.o: macro.c private.h
+
+term.ln: term.c term.h 
+term.o: term.c term.h
+
+strings.ln: strings.c private.h
+strings.o: strings.c private.h
+
+hash.ln: hash.c private.h
+hash.o: hash.c private.h
+
+mdoc.ln: mdoc.c private.h
+mdoc.o: mdoc.c private.h
+
+mdocterm.ln: mdocterm.c mmain.h
+mdocterm.o: mdocterm.c mmain.h
+
+mdoclint.ln: mdoclint.c mmain.h
+mdoclint.o: mdoclint.c mmain.h
+
+mdoctree.ln: mdoctree.c mmain.h
+mdoctree.o: mdoctree.c mmain.h
+
+xstd.ln: xstd.c private.h
+xstd.o: xstd.c private.h
+
+argv.ln: argv.c private.h
+argv.o: argv.c private.h
+
+validate.ln: validate.c private.h
+validate.o: validate.c private.h
+
+action.ln: action.c private.h
+action.o: action.c private.h
+
+mmain.ln: mmain.c mmain.h
+mmain.o: mmain.c mmain.h
+
+private.h: mdoc.h
+
+mmain.h: mdoc.h
+
+term.h: mdoc.h
+
+mdocml-nport-$(VERSION).tar.gz: mdocml-$(VERSION).tar.gz Makefile.netbsd DESCR
+	mkdir -p .dist/mdocml/
+	sed -e "s!@VERSION@!$(VERSION)!" Makefile.netbsd > \
+		.dist/mdocml/Makefile
+	md5 mdocml-$(VERSION).tar.gz > .dist/mdocml/distinfo
+	rmd160 mdocml-$(VERSION).tar.gz >> .dist/mdocml/distinfo
+	sha1 mdocml-$(VERSION).tar.gz >> .dist/mdocml/distinfo
+	install -m 0644 DESCR .dist/mdocml/
+	echo @comment $$NetBSD$$ > .dist/mdocml/PLIST
+	echo bin/mdocterm >> .dist/mdocml/PLIST
+	echo bin/mdoctree >> .dist/mdocml/PLIST
+	echo bin/mdoclint >> .dist/mdocml/PLIST
+	echo lib/libmdoc.a >> .dist/mdocml/PLIST
+	echo include/mdoc.h >> .dist/mdocml/PLIST
+	echo man/man1/mdoctree.1 >> .dist/mdocml/PLIST
+	echo man/man1/mdocterm.1 >> .dist/mdocml/PLIST
+	echo man/man1/mdoclint.1 >> .dist/mdocml/PLIST
+	echo man/man3/mdoc.3 >> .dist/mdocml/PLIST
+	( cd .dist/ && tar zcf ../$@ mdocml/ )
 	rm -rf .dist/
 
-mdocml-port.tgz: $(INSTALL)
+mdocml-oport-$(VERSION).tar.gz: mdocml-$(VERSION).tar.gz Makefile.openbsd DESCR
 	mkdir -p .dist/mdocml/pkg
-	sed -e "s!@VERSION@!$(VERSION)!" Makefile.port > .dist/mdocml/Makefile
-	md5 mdocml-$(VERSION).tgz > .dist/mdocml/distinfo
-	rmd160 mdocml-$(VERSION).tgz >> .dist/mdocml/distinfo
-	sha1 mdocml-$(VERSION).tgz >> .dist/mdocml/distinfo
+	sed -e "s!@VERSION@!$(VERSION)!" Makefile.openbsd > \
+		.dist/mdocml/Makefile
+	md5 mdocml-$(VERSION).tar.gz > .dist/mdocml/distinfo
+	rmd160 mdocml-$(VERSION).tar.gz >> .dist/mdocml/distinfo
+	sha1 mdocml-$(VERSION).tar.gz >> .dist/mdocml/distinfo
 	install -m 0644 DESCR .dist/mdocml/pkg/DESCR
 	echo @comment $$OpenBSD$$ > .dist/mdocml/pkg/PLIST
-	echo bin/mdocml >> .dist/mdocml/pkg/PLIST
-	echo @man man/man1/mdocml.1 >> .dist/mdocml/pkg/PLIST
+	echo bin/mdocterm >> .dist/mdocml/pkg/PLIST
+	echo bin/mdoctree >> .dist/mdocml/pkg/PLIST
+	echo bin/mdoclint >> .dist/mdocml/pkg/PLIST
+	echo lib/libmdoc.a >> .dist/mdocml/pkg/PLIST
+	echo include/mdoc.h >> .dist/mdocml/pkg/PLIST
+	echo @man man/man1/mdoctree.1 >> .dist/mdocml/pkg/PLIST
+	echo @man man/man1/mdocterm.1 >> .dist/mdocml/pkg/PLIST
+	echo @man man/man1/mdoclint.1 >> .dist/mdocml/pkg/PLIST
+	echo @man man/man3/mdoc.3 >> .dist/mdocml/pkg/PLIST
 	( cd .dist/ && tar zcf ../$@ mdocml/ )
 	rm -rf .dist/
 
-llib-lmdocml.ln: mdocml.ln libmdocml.ln html.ln xml.ln roff.ln ml.ln mlg.ln compat.ln tokens.ln literals.ln tags.ln noop.ln
-	$(LINT) $(LINTFLAGS) -Cmdocml mdocml.ln libmdocml.ln html.ln xml.ln roff.ln ml.ln mlg.ln compat.ln tokens.ln literals.ln tags.ln noop.ln
-
-mdocml.ln: mdocml.c libmdocml.h
-
-mdocml.o: mdocml.c libmdocml.h
-
-libmdocml.a: libmdocml.o html.o xml.o roff.o ml.o mlg.o compat.o tokens.o literals.o tags.o noop.o
-	$(AR) rs $@ libmdocml.o html.o xml.o roff.o ml.o mlg.o compat.o tokens.o literals.o tags.o noop.o
-
-xml.ln: xml.c ml.h
-
-xml.o: xml.c ml.h
-
-html.ln: html.c private.h
-
-html.o: html.c private.h 
-
-tags.ln: tags.c html.h 
-
-tags.o: tags.c html.h
-
-roff.ln: roff.c private.h
-
-roff.o: roff.c private.h 
-
-libmdocml.ln: libmdocml.c private.h
-
-libmdocml.o: libmdocml.c private.h
-
-ml.ln: ml.c ml.h
-
-ml.o: ml.c ml.h
-
-mlg.ln: mlg.c ml.h
+mdocml-$(VERSION).tar.gz: $(INSTALL)
+	mkdir -p .dist/mdocml/mdocml-$(VERSION)/
+	mkdir -p .dist/mdocml/mdocml-$(VERSION)/regress/
+	install -m 0644 $(INSTALL) .dist/mdocml/mdocml-$(VERSION)/
+	install -m 0644 $(REGRESS) .dist/mdocml/mdocml-$(VERSION)/regress/
+	( cd .dist/mdocml/ && tar zcf ../../$@ mdocml-$(VERSION)/ )
+	rm -rf .dist/
 
-mlg.o: mlg.c ml.h
+llib-llibmdoc.ln: $(LIBLNS)
+	$(LINT) $(LINTFLAGS) -Clibmdoc $(LIBLNS)
 
-compat.ln: compat.c
+llib-lmdoctree.ln: $(TREELNS) llib-llibmdoc.ln
+	$(LINT) $(LINTFLAGS) -Cmdoctree $(TREELNS) llib-llibmdoc.ln
 
-compat.o: compat.c
+llib-lmdocterm.ln: $(TERMLNS) llib-llibmdoc.ln
+	$(LINT) $(LINTFLAGS) -Cmdocterm $(TERMLNS) llib-llibmdoc.ln
 
-noop.ln: noop.c private.h
+libmdoc.a: $(LIBOBJS)
+	$(AR) rs $@ $(LIBOBJS)
 
-noop.o: noop.c private.h
+mdocterm: $(TERMOBJS) libmdoc.a
+	$(CC) $(CFLAGS) -o $@ $(TERMOBJS) libmdoc.a 
 
-html.h: ml.h
+mdoctree: $(TREEOBJS) libmdoc.a
+	$(CC) $(CFLAGS) -o $@ $(TREEOBJS) libmdoc.a 
 
-ml.h: private.h
+mdoclint: $(LINTOBJS) libmdoc.a
+	$(CC) $(CFLAGS) -o $@ $(LINTOBJS) libmdoc.a 
 
-private.h: libmdocml.h
+.sgml.html:
+	validate $<
+	sed -e "s!@VERSION@!$(VERSION)!" -e "s!@VDATE@!$(VDATE)!" $< > $@