X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=Makefile.in;h=a9e049559ecbbd8cb1afc8a8d9ed21325da11e71;hb=343ea65fbd231847142e876a5700cee8afbc8e98;hp=fba131c44df9fafa8a9ba7655835a7da692120f8;hpb=7c3ce1f99992caa51c6ce3eabea3b9bce137665f;p=ocaml-bitstring.git diff --git a/Makefile.in b/Makefile.in index fba131c..a9e0495 100644 --- a/Makefile.in +++ b/Makefile.in @@ -24,17 +24,44 @@ OCAMLFIND = @OCAMLFIND@ OCAMLMKLIB = @OCAMLMKLIB@ OCAMLDOC = @OCAMLDOC@ INSTALL = @INSTALL@ +TIME = @TIME@ +GPROF = @GPROF@ +BISECT_REPORT = @BISECT_REPORT@ + +BYTESWAP_H = @BYTESWAP_H@ + +OCAMLLIB = @OCAMLLIB@ +top_srcdir = @top_srcdir@ pkg_cil = @pkg_cil@ pkg_extlib = @pkg_extlib@ +enable_coverage = @enable_coverage@ + OCAMLCFLAGS = -g OCAMLCPACKAGES = +OCAMLCLIBS = -linkpkg OCAMLOPTFLAGS = OCAMLOPTPACKAGES = +OCAMLOPTLIBS = -linkpkg + +ifneq ($(enable_coverage),no) +OCAMLCFLAGS += -I +bisect -pp 'camlp4o $(OCAMLLIB)/bisect/instrument.cma' +OCAMLCLIBS += -I +bisect bisect.cma +OCAMLOPTFLAGS += -I +bisect -pp 'camlp4o $(OCAMLLIB)/bisect/instrument.cma' +OCAMLOPTLIBS += -I +bisect bisect.cmxa +endif OCAMLDOCFLAGS = -html -sort +CC = @CC@ +CFLAGS = @CFLAGS@ -Wall -Werror -fPIC -I$(top_srcdir) -I$(OCAMLLIB) + +LIBRARY_PATH = @abs_top_builddir@ +LD_LIBRARY_PATH = @abs_top_builddir@ +export LIBRARY_PATH +export LD_LIBRARY_PATH + SUBDIRS = ifneq ($(pkg_cil),no) ifneq ($(pkg_extlib),no) @@ -46,15 +73,18 @@ EXAMPLES = $(patsubst %.ml,%,$(wildcard examples/*.ml)) TESTS = $(patsubst %.ml,%,$(wildcard tests/*.ml)) -all: bitstring.cma bitstring_persistent.cma \ +BENCHMARKS = $(patsubst %.ml,%,$(wildcard benchmarks/*.ml)) + +all: $(BYTESWAP_H) \ + bitstring.cma bitstring_persistent.cma \ bitstring.cmxa bitstring_persistent.cmxa \ pa_bitstring.cmo \ bitstring-objinfo @for d in $(SUBDIRS); do $(MAKE) -C $$d $@; done -bitstring.cma: bitstring_types.cmo bitstring_config.cmo bitstring.cmo \ - bitmatch.cmo - $(OCAMLFIND) ocamlc -a -o $@ $^ +bitstring.cma: bitstring_types.cmo bitstring_config.cmo \ + bitstring_c.o bitstring.cmo bitmatch.cmo + $(OCAMLMKLIB) -o bitstring $^ bitstring_persistent.cma: bitstring_persistent.cmo $(OCAMLFIND) ocamlc -a -o $@ $^ @@ -63,9 +93,9 @@ bitstring_persistent.cmo: bitstring_persistent.ml $(OCAMLFIND) ocamlc $(OCAMLCFLAGS) $(OCAMLCPACKAGES) \ -I +camlp4 -pp camlp4of -c $< -bitstring.cmxa: bitstring_types.cmx bitstring_config.cmx bitstring.cmx \ - bitmatch.cmx - $(OCAMLFIND) ocamlopt -a -o $@ $^ +bitstring.cmxa: bitstring_types.cmx bitstring_config.cmx \ + bitstring_c.o bitstring.cmx bitmatch.cmx + $(OCAMLMKLIB) -o bitstring $^ bitstring_persistent.cmxa: bitstring_persistent.cmx $(OCAMLFIND) ocamlopt -a -o $@ $^ @@ -84,21 +114,34 @@ pa_bitstring.cmo: pa_bitstring.ml bitstring.cma bitstring_persistent.cma bitstring-objinfo: bitstring_objinfo.cmo bitstring.cma bitstring_persistent.cma $(OCAMLFIND) ocamlc -I +camlp4 unix.cma camlp4lib.cma \ + $(OCAMLCLIBS) \ bitstring.cma bitstring_persistent.cma \ $< -o $@ -# Tests and examples. +# Create byteswap.h if the system doesn't have this file. +# From gnulib, license is LGPLv2+. + +byteswap.h: byteswap.in.h + { echo '/* DO NOT EDIT! GENERATED AUTOMATICALLY! */'; \ + cat $(srcdir)/byteswap.in.h; \ + } > $@-t + mv -f $@-t $@ + +# Tests. -PP = -pp "camlp4o bitstring.cma bitstring_persistent.cma pa_bitstring.cmo" +ifeq ($(enable_coverage),no) +PP = -pp 'camlp4o bitstring.cma bitstring_persistent.cma pa_bitstring.cmo' +else +PP = -pp 'camlp4o $(OCAMLLIB)/bisect/bisect.cma bitstring.cma bitstring_persistent.cma pa_bitstring.cmo' +endif test: pa_bitstring.cmo bitstring.cma bitstring_persistent.cma tests/test.bmpp @for f in $(TESTS); do \ echo Building $$f; \ - $(OCAMLFIND) ocamlc $(OCAMLCFLAGS) $(PP) \ - -package unix -linkpkg -I . bitstring.cma $$f.ml -o $$f; \ + $(OCAMLFIND) ocamlopt $(OCAMLOPTFLAGS) $(PP) -package unix $(OCAMLOPTLIBS) -I . bitstring.cmxa $$f.ml -o $$f.opt; \ if [ $$? -ne 0 ]; then exit 1; fi; \ echo Running $$f; \ - $$f; \ + $$f.opt; \ if [ $$? -ne 0 ]; then exit 1; fi; \ done @for d in $(SUBDIRS); do $(MAKE) -C $$d $@; done @@ -110,6 +153,7 @@ tests/test.bmpp: create_test_pattern create_test_pattern: create_test_pattern.cmo $(OCAMLFIND) ocamlc $(OCAMLCFLAGS) -pp camlp4of \ unix.cma -I +camlp4 camlp4lib.cma \ + $(OCAMLCLIBS) \ -I . bitstring.cma bitstring_persistent.cma $< -o $@ create_test_pattern.cmo: create_test_pattern.ml @@ -117,6 +161,20 @@ create_test_pattern.cmo: create_test_pattern.ml unix.cma -I +camlp4 \ -I . -c $< -o $@ +# Coverage of tests. + +ifneq ($(BISECT_REPORT),no) +coverage: + rm -f coverage-report/* + rm -f bisect*.out + $(MAKE) test + $(BISECT_REPORT) -html coverage-report bisect*.out + rm -f bisect*.out + @echo Coverage report is in `pwd`/coverage-report/index.html +endif + +# Examples. + examples: pa_bitstring.cmo bitstring.cma bitstring_persistent.cma @for f in $(EXAMPLES); do \ echo Building $$f; \ @@ -143,12 +201,44 @@ print-examples: pa_bitstring.cmo if [ $$? -ne 0 ]; then exit 1; fi; \ done +# Benchmarks. + +ifneq ($(TIME),no) + +benchmarks: pa_bitstring.cmo bitstring.cma bitstring_persistent.cma + @for f in $(BENCHMARKS); do \ + $(OCAMLFIND) ocamlopt $(OCAMLOPTFLAGS) $(PP) \ + -package unix -linkpkg -I . bitstring.cmxa $$f.ml -o $$f.opt; \ + if [ $$? -ne 0 ]; then exit 1; fi; \ + $(TIME) -f "$$f: %e seconds" $$f.opt; \ + if [ $$? -ne 0 ]; then exit 1; fi; \ + done +ifneq ($(GPROF),no) + @for f in $(BENCHMARKS); do \ + $(OCAMLFIND) ocamlopt $(OCAMLOPTFLAGS) $(PP) -p \ + -package unix -linkpkg -I . bitstring.cmxa $$f.ml -o $$f.opt.p; \ + if [ $$? -ne 0 ]; then exit 1; fi; \ + rm -f gmon.out; \ + $$f.opt.p; \ + if [ $$? -ne 0 ]; then exit 1; fi; \ + gprof $$f.opt.p > $$f.profile; \ + if [ $$? -ne 0 ]; then exit 1; fi; \ + echo "Wrote profile of $$f"; \ + echo " to $$f.profile"; \ + rm -f gmon.out; \ + done +endif + +endif + # Clean. clean: rm -f core *~ *.cmi *.cmo *.cmx *.cma *.cmxa *.a *.o - rm -f tests/*~ tests/*.cmi tests/*.cmo $(TESTS) + rm -f tests/*~ tests/*.cmi tests/*.cmo tests/*.opt rm -f examples/*~ examples/*.cmi examples/*.cmo $(EXAMPLES) + rm -f benchmarks/*~ benchmarks/*.cmi benchmarks/*.cmo + rm -f benchmarks/*.opt benchmarks/*.opt.p benchmarks/*.profile @for d in $(SUBDIRS); do $(MAKE) -C $$d $@; done distclean: clean @@ -171,7 +261,7 @@ endif # Install. install: - ocamlfind install bitstring META *.mli *.cmx *.cma *.cmxa *.a \ + ocamlfind install bitstring META *.mli *.cmx *.cma *.cmxa *.a *.so \ bitstring.cmi \ bitstring_persistent.cmi \ pa_bitstring.cmo @@ -227,6 +317,6 @@ check-manifest: exit $$rv .PHONY: depend dist check-manifest dpkg doc \ - print-examples print-tests examples test + print-examples print-tests examples test benchmarks .SUFFIXES: .cmo .cmi .cmx .ml .mli .mll