X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=Makefile;h=f8b91df1ce719df6504aee1ef8f4a672e78ca040;hb=55318cc354e514953bca429618150bb069e9920d;hp=661564cf760f807e8969f1bc0bad84d31a6ba49e;hpb=918648a5563d9ae8e4079fdf7d364387b02b1b34;p=perl4caml.git diff --git a/Makefile b/Makefile index 661564c..f8b91df 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,6 @@ # Interface to Perl from OCaml. # Copyright (C) 2003 Merjis Ltd. -# $Id: Makefile,v 1.9 2003-10-15 09:49:52 rich Exp $ +# $Id: Makefile,v 1.30 2005-01-31 15:23:23 rich Exp $ include Makefile.config @@ -8,6 +8,7 @@ OCAMLC := ocamlc OCAMLOPT := ocamlopt OCAMLMKLIB := ocamlmklib OCAMLDEP := ocamldep +OCAMLDOC := ocamldoc OCAMLCINCS := -I wrappers OCAMLOPTINCS := $(OCAMLCINCS) @@ -15,12 +16,22 @@ OCAMLOPTINCS := $(OCAMLCINCS) OCAMLCFLAGS := -w s -g $(OCAMLCINCS) OCAMLOPTFLAGS := -w s $(OCAMLOPTINCS) +PERLCFLAGS := $(shell perl -e 'use Config; print $$Config{ccflags};') + CC := gcc -CFLAGS := -Wall -Wno-unused -I$(PERLINCDIR) +CFLAGS := -fPIC -Wall -Wno-unused -I$(PERLINCDIR) $(PERLCFLAGS) $(EXTRA_CFLAGS) LIBPERL := $(shell perl -MExtUtils::Embed -e ldopts) +SED := sed + +OCAMLDOCFLAGS := -html -stars -sort $(OCAMLCINCS) + WRAPPERS := \ + wrappers/pl_Data_Dumper.cmo \ + wrappers/pl_Date_Calc.cmo \ + wrappers/pl_Date_Format.cmo \ + wrappers/pl_Date_Parse.cmo \ wrappers/pl_Net_Google_Cache.cmo \ wrappers/pl_Net_Google_Response.cmo \ wrappers/pl_Net_Google_Search.cmo \ @@ -30,12 +41,18 @@ WRAPPERS := \ wrappers/pl_HTML_Parser.cmo \ wrappers/pl_HTML_TreeBuilder.cmo \ wrappers/pl_URI.cmo \ + wrappers/pl_HTTP_Cookies.cmo \ + wrappers/pl_HTTP_Headers.cmo \ wrappers/pl_HTTP_Message.cmo \ wrappers/pl_HTTP_Request.cmo \ + wrappers/pl_HTTP_Request_Common.cmo \ wrappers/pl_HTTP_Response.cmo \ - wrappers/pl_LWP_UserAgent.cmo + wrappers/pl_HTML_Form.cmo \ + wrappers/pl_LWP_UserAgent.cmo \ + wrappers/pl_Template.cmo \ + wrappers/pl_WWW_Mechanize.cmo -all: perl4caml.cma perl4caml.cmxa perl_init.cmo perl_init.cmx all-examples +all: perl4caml.cma perl4caml.cmxa META all-examples html perl4caml.cma: perl.cmo perl_c.o $(WRAPPERS) $(OCAMLMKLIB) -o perl4caml $(LIBPERL) $^ @@ -43,25 +60,41 @@ perl4caml.cma: perl.cmo perl_c.o $(WRAPPERS) perl4caml.cmxa: perl.cmx perl_c.o $(WRAPPERS:.cmo=.cmx) $(OCAMLMKLIB) -o perl4caml $(LIBPERL) $^ -all-examples: examples/test examples/loadpage examples/google - -examples/test: examples/test.cmo - $(OCAMLC) $(OCAMLCFLAGS) perl4caml.cma perl_init.cmo $^ -o $@ - -#examples/test.opt: examples/test.cmx -# $(OCAMLOPT) $(OCAMLOPTFLAGS) perl4caml.cmxa perl_init.cmx $^ -o $@ - -examples/loadpage: examples/loadpage.cmo - $(OCAMLC) $(OCAMLCFLAGS) perl4caml.cma perl_init.cmo $^ -o $@ - -#examples/loadpage.opt: examples/loadpage.cmx -# $(OCAMLOPT) $(OCAMLOPTFLAGS) perl4caml.cmxa perl_init.cmx $^ -o $@ - -examples/google: examples/google.cmo - $(OCAMLC) $(OCAMLCFLAGS) perl4caml.cma perl_init.cmo $^ -o $@ - -#examples/google.opt: examples/google.cmx -# $(OCAMLOPT) $(OCAMLOPTFLAGS) perl4caml.cmxa perl_init.cmx $^ -o $@ +all-examples: examples/test.bc examples/loadpage.bc examples/google.bc \ + examples/test.opt examples/loadpage.opt examples/google.opt \ + examples/parsedate.bc examples/parsedate.opt + +TEST_PROGRAMS := $(patsubst %.ml,%.bc,$(wildcard test/*.ml)) \ + $(patsubst %.ml,%.opt,$(wildcard test/*.ml)) + +test: $(TEST_PROGRAMS) run-tests + +check: test + +run-tests: + @fails=0; count=0; \ + export LD_LIBRARY_PATH=`pwd`:$LD_LIBRARY_PATH; \ + for prog in $(TEST_PROGRAMS); do \ + if ! $$prog; then \ + echo Test $$prog failed; \ + fails=$$(($$fails+1)); \ + fi; \ + count=$$(($$count+1)); \ + done; \ + if [ $$fails -eq 0 ]; then \ + echo All tests succeeded.; \ + exit 0; \ + else \ + echo $$fails/$$count tests failed.; \ + exit 1; \ + fi + +%.bc: %.cmo + $(OCAMLC) $(OCAMLCFLAGS) perl4caml.cma $^ -o $@ + +%.opt: %.cmx + $(OCAMLOPT) $(OCAMLOPTFLAGS) -cclib -L. perl4caml.cmxa \ + $(DYNALOADER_HACK) $^ -o $@ %.cmi: %.mli $(OCAMLC) $(OCAMLCFLAGS) -c $< @@ -74,13 +107,21 @@ examples/google: examples/google.cmo .SUFFIXES: .mli .ml .cmi .cmo .cmx +META: META.in Makefile.config + $(SED) -e 's/@PACKAGE@/$(PACKAGE)/' \ + -e 's/@VERSION@/$(VERSION)/' \ + < $< > $@ + # Clean. -JUNKFILES = core *~ *.bak *.cmi *.cmo *.cmx *.cma *.cmxa *.o *.a *.so +JUNKFILES = core *~ *.bak *.cmi *.cmo *.cmx *.cma *.cmxa *.o *.a *.so \ + *.bc *.opt clean: - rm -f examples/test examples/loadpage examples/google - for d in . examples wrappers; do (cd $$d; rm -f $(JUNKFILES)); done + rm -f META + for d in . examples test wrappers; do \ + (cd $$d; rm -f $(JUNKFILES)); \ + done # Build dependencies. @@ -98,16 +139,19 @@ depend: .depend # Install. install: - install -c -m 0755 -d $(OCAMLLIBDIR)/perl - install -c -m 0755 -d $(OCAMLLIBDIR)/stublibs + rm -rf $(DESTDIR)$(OCAMLLIBDIR)/perl + install -c -m 0755 -d $(DESTDIR)$(OCAMLLIBDIR)/perl + install -c -m 0755 -d $(DESTDIR)$(OCAMLLIBDIR)/stublibs install -c -m 0644 perl.cmi perl.mli perl4caml.cma perl4caml.cmxa \ - perl_init.cmo perl_init.cmx perl4caml.a libperl4caml.a \ - $(WRAPPERS:.cmo=.ml) $(WRAPPERS:.cmo=.cmi) $(OCAMLLIBDIR)/perl - install -c -m 0644 dllperl4caml.so $(OCAMLLIBDIR)/stublibs + perl4caml.a libperl4caml.a META \ + $(WRAPPERS:.cmo=.ml) $(WRAPPERS:.cmo=.cmi) \ + $(DESTDIR)$(OCAMLLIBDIR)/perl + install -c -m 0644 dllperl4caml.so $(DESTDIR)$(OCAMLLIBDIR)/stublibs # Distribution. dist: + $(MAKE) check-manifest rm -rf $(PACKAGE)-$(VERSION) mkdir $(PACKAGE)-$(VERSION) tar -cf - -T MANIFEST | tar -C $(PACKAGE)-$(VERSION) -xf - @@ -116,14 +160,45 @@ dist: ls -l $(PACKAGE)-$(VERSION).tar.gz check-manifest: - @for d in `find -type d -name CVS`; \ + @for d in `find -type d -name CVS | grep -v '^\./debian/'`; \ do \ b=`dirname $$d`/; \ awk -F/ '$$1 != "D" {print $$2}' $$d/Entries | \ sed -e "s|^|$$b|" -e "s|^\./||"; \ done | sort > .check-manifest; \ sort MANIFEST > .orig-manifest; \ - diff -u .orig-manifest .check-manifest; \ - rm -f .orig-manifest .check-manifest - -.PHONY: depend dist check-manifest \ No newline at end of file + diff -u .orig-manifest .check-manifest; rv=$$?; \ + rm -f .orig-manifest .check-manifest; \ + exit $$rv + +# Debian packages. + +dpkg: + @if [ 0 != `cvs -q update | wc -l` ]; then \ + echo Please commit all changes to CVS first.; \ + exit 1; \ + fi + $(MAKE) dist + rm -rf /tmp/dbuild + mkdir /tmp/dbuild + cp $(PACKAGE)-$(VERSION).tar.gz \ + /tmp/dbuild/$(PACKAGE)_$(VERSION).orig.tar.gz + export CVSROOT=`cat CVS/Root`; \ + cd /tmp/dbuild && \ + cvs export \ + -d $(PACKAGE)-$(VERSION) \ + -D now merjis/test/perl4caml + cd /tmp/dbuild/$(PACKAGE)-$(VERSION) && dpkg-buildpackage -rfakeroot + rm -rf /tmp/dbuild/$(PACKAGE)-$(VERSION) + ls -l /tmp/dbuild + +# Documentation. + +html: html/index.html + +html/index.html: $(wildcard *.ml) $(wildcard *.mli) $(wildcard wrappers/*.ml) + rm -rf html + mkdir html + -$(OCAMLDOC) $(OCAMLDOCFLAGS) -d html $^ + +.PHONY: depend dist check-manifest html dpkg test run-tests \ No newline at end of file