Added submit_form method.
[perl4caml.git] / Makefile
index 661564c..f8b91df 100644 (file)
--- 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