X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=ocaml%2FMakefile.am;h=12522f24108ffde1a5b904495028da977a94365e;hp=de07b3bef63ba3b4f4880efec09220eee610e2a3;hb=f8f10578093e926f5f36289a6c11615d067fbcad;hpb=5828e17afdc2fe22947ca68f879e2071359f5f81 diff --git a/ocaml/Makefile.am b/ocaml/Makefile.am index de07b3b..12522f2 100644 --- a/ocaml/Makefile.am +++ b/ocaml/Makefile.am @@ -17,32 +17,76 @@ EXTRA_DIST = \ guestfs.mli guestfs.ml \ - guestfs_internal.ml \ guestfs_c.c guestfs_c.h guestfs_c_actions.c \ - .depend META.in + .depend META.in \ + bindtests.ml \ + run-bindtests \ + t/*.ml + +SUBDIRS = examples + +CLEANFILES = *.cmi *.cmo *.cmx *.cma *.cmxa *.o *.a *.so +CLEANFILES += t/*.cmi t/*.cmo t/*.cmx t/*.o t/*.a t/*.so if HAVE_OCAML noinst_DATA = mlguestfs.cma mlguestfs.cmxa META -mlguestfs.cma: guestfs_c.o guestfs_c_actions.o guestfs_internal.cmo guestfs.cmo - $(OCAMLMKLIB) -o mlguestfs $^ -lguestfs +mlguestfs.cma: guestfs_c.o guestfs_c_actions.o guestfs.cmo + $(OCAMLMKLIB) -o mlguestfs $^ -L$(top_builddir)/src/.libs -lguestfs -mlguestfs.cmxa: guestfs_c.o guestfs_c_actions.o guestfs_internal.cmx guestfs.cmx - $(OCAMLMKLIB) -o mlguestfs $^ -lguestfs +mlguestfs.cmxa: guestfs_c.o guestfs_c_actions.o guestfs.cmx + $(OCAMLMKLIB) -o mlguestfs $^ -L$(top_builddir)/src/.libs -lguestfs guestfs_c.o: guestfs_c.c - $(CC) $(CFLAGS) -I$(OCAMLLIB) -c $< + $(CC) $(CFLAGS) -I$(OCAMLLIB) -I$(top_srcdir)/ocaml -I$(top_srcdir)/src -I$(top_builddir)/src -fPIC -Wall -c $< guestfs_c_actions.o: guestfs_c_actions.c - $(CC) $(CFLAGS) -I$(OCAMLLIB) -c $< + $(CC) $(CFLAGS) -I$(OCAMLLIB) -I$(top_srcdir)/ocaml -I$(top_srcdir)/src -I$(top_builddir)/src -fPIC -Wall -c $< + +TESTS_ENVIRONMENT = \ + LD_LIBRARY_PATH=$(top_builddir)/src/.libs \ + LIBGUESTFS_PATH=$(top_builddir)/appliance \ + $(VG) + +TESTS = run-bindtests \ + t/guestfs_005_load t/guestfs_010_launch t/guestfs_050_lvcreate \ + t/guestfs_060_readdir +noinst_DATA += bindtests \ + t/guestfs_005_load t/guestfs_010_launch t/guestfs_050_lvcreate \ + t/guestfs_060_readdir + +bindtests: bindtests.cmx mlguestfs.cmxa + mkdir -p t + $(OCAMLFIND) ocamlopt -cclib -L$(top_builddir)/src/.libs -I . unix.cmxa mlguestfs.cmxa $< -o $@ + +t/guestfs_005_load: t/guestfs_005_load.cmx mlguestfs.cmxa + mkdir -p t + $(OCAMLFIND) ocamlopt -cclib -L$(top_builddir)/src/.libs -I . unix.cmxa mlguestfs.cmxa $< -o $@ + +t/guestfs_010_launch: t/guestfs_010_launch.cmx mlguestfs.cmxa + mkdir -p t + $(OCAMLFIND) ocamlopt -cclib -L$(top_builddir)/src/.libs -I . unix.cmxa mlguestfs.cmxa $< -o $@ + +t/guestfs_050_lvcreate: t/guestfs_050_lvcreate.cmx mlguestfs.cmxa + mkdir -p t + $(OCAMLFIND) ocamlopt -cclib -L$(top_builddir)/src/.libs -I . unix.cmxa mlguestfs.cmxa $< -o $@ + +t/guestfs_060_readdir: t/guestfs_060_readdir.cmx mlguestfs.cmxa + mkdir -p t + $(OCAMLFIND) ocamlopt -cclib -L$(top_builddir)/src/.libs -I . unix.cmxa mlguestfs.cmxa $< -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 mlguestfs.cmxa + $(OCAMLFIND) ocamlopt -c $< -o $@ .mli.cmi: - $(OCAMLFIND) ocamlc -c $< + $(OCAMLFIND) ocamlc -c $< -o $@ .ml.cmo: - $(OCAMLFIND) ocamlc -c $< + $(OCAMLFIND) ocamlc -c $< -o $@ .ml.cmx: - $(OCAMLFIND) ocamlopt -c $< + $(OCAMLFIND) ocamlopt -c $< -o $@ depend: .depend @@ -56,7 +100,17 @@ SUFFIXES = .cmo .cmi .cmx .ml .mli .mll .mly # Do the installation by hand, because we want to run ocamlfind. install-data-hook: - $(OCAMLFIND) install -destdir $(DESTDIR) guestfs \ + mkdir -p $(DESTDIR)$(OCAMLLIB) + mkdir -p $(DESTDIR)$(OCAMLLIB)/stublibs + $(OCAMLFIND) install \ + -ldconf ignore -destdir $(DESTDIR)$(OCAMLLIB) \ + guestfs \ META *.so *.a *.cma *.cmx *.cmxa *.cmi *.mli -endif \ No newline at end of file +CLEANFILES += $(noinst_DATA) + +endif + +# Tell version 3.79 and up of GNU make to not build goals in this +# directory in parallel. (Possible solution for RHBZ#502309). +.NOTPARALLEL: