X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;ds=sidebyside;f=ocaml%2FMakefile.am;h=ca4c111f1f47dbf7130e7a6315b1f2b572e3cb7e;hb=534a0aed6e40818bb2cb354bcf2fd3b587bce2cd;hp=fee3b88c927ba7bc8f777e56d666b8e4151f3225;hpb=5cf4fc2caa34ccb3a1e01bbec912158127dcd169;p=hivex.git diff --git a/ocaml/Makefile.am b/ocaml/Makefile.am index fee3b88..ca4c111 100644 --- a/ocaml/Makefile.am +++ b/ocaml/Makefile.am @@ -63,42 +63,16 @@ TESTS = \ t/hivex_300_fold noinst_DATA += $(TESTS) -t/hivex_005_load: t/hivex_005_load.cmo mlhivex.cma - mkdir -p t - $(OCAMLFIND) ocamlc -cclib -L$(top_builddir)/lib/.libs -I . -package unix -linkpkg mlhivex.cma $< -o $@ - -t/hivex_010_open: t/hivex_010_open.cmo mlhivex.cma - mkdir -p t - $(OCAMLFIND) ocamlc -cclib -L$(top_builddir)/lib/.libs -I . -package unix -linkpkg mlhivex.cma $< -o $@ - -t/hivex_020_root: t/hivex_020_root.cmo mlhivex.cma - mkdir -p t - $(OCAMLFIND) ocamlc -cclib -L$(top_builddir)/lib/.libs -I . -package unix -linkpkg mlhivex.cma $< -o $@ - -t/hivex_100_errors: t/hivex_100_errors.cmo mlhivex.cma - mkdir -p t - $(OCAMLFIND) ocamlc -cclib -L$(top_builddir)/lib/.libs -I . -package unix -linkpkg mlhivex.cma $< -o $@ - -t/hivex_110_gc_handle: t/hivex_110_gc_handle.cmo mlhivex.cma - mkdir -p t - $(OCAMLFIND) ocamlc -cclib -L$(top_builddir)/lib/.libs -I . -package unix -linkpkg mlhivex.cma $< -o $@ - -t/hivex_200_write: t/hivex_200_write.cmo mlhivex.cma - mkdir -p t - $(OCAMLFIND) ocamlc -cclib -L$(top_builddir)/lib/.libs -I . -package unix -linkpkg mlhivex.cma $< -o $@ - -t/hivex_300_fold: t/hivex_300_fold.cmo mlhivex.cma - mkdir -p t - $(OCAMLFIND) ocamlc -cclib -L$(top_builddir)/lib/.libs -I . -package unix -linkpkg mlhivex.cma $< -o $@ - -# Need to rebuild the tests from source if the main library has -# changed at all, otherwise we get inconsistent assumptions. -t/%.cmx: t/%.ml mlhivex.cmxa - $(OCAMLFIND) ocamlopt -package unix -linkpkg -c $< -o $@ +# https://www.redhat.com/archives/libguestfs/2011-May/thread.html#00015 +t/%: t/%.cmo mlhivex.cma + $(LIBTOOL) --mode=execute -dlopen $(top_builddir)/lib/libhivex.la \ + $(OCAMLFIND) ocamlc -dllpath $(abs_builddir) -package unix \ + -linkpkg mlhivex.cma $< -o $@ .mli.cmi: $(OCAMLFIND) ocamlc -package unix -c $< -o $@ .ml.cmo: + mkdir -p `dirname $@` $(OCAMLFIND) ocamlc -package unix -c $< -o $@ .ml.cmx: $(OCAMLFIND) ocamlopt -package unix -c $< -o $@ @@ -115,13 +89,19 @@ include .depend SUFFIXES = .cmo .cmi .cmx .ml .mli .mll .mly # Do the installation by hand, because we want to run ocamlfind. +install_files = META *.so *.a *.cma *.cmi $(srcdir)/*.mli + +if HAVE_OCAMLOPT +install_files += *.cmx *.cmxa +endif + install-data-hook: mkdir -p $(DESTDIR)$(OCAMLLIB) mkdir -p $(DESTDIR)$(OCAMLLIB)/stublibs $(OCAMLFIND) install \ -ldconf ignore -destdir $(DESTDIR)$(OCAMLLIB) \ - hivex \ - META *.so *.a *.cma *.cmx *.cmxa *.cmi *.mli + $(PACKAGE_NAME) \ + $(install_files) CLEANFILES += $(noinst_DATA)