X-Git-Url: http://git.nguyen.vg/gitweb/?p=tatoo.git;a=blobdiff_plain;f=Remakefile.in;h=5c3fe428aab6129020a08a4255504dadc081115e;hp=1ff0b30e9bb87d633734e1b1839309291d4b4955;hb=d7019c01a47613e258fccb127e6085cb91d26546;hpb=c6a89f390d6171f99d98f794427c1cce42fbf40c diff --git a/Remakefile.in b/Remakefile.in index 1ff0b30..5c3fe42 100644 --- a/Remakefile.in +++ b/Remakefile.in @@ -1,10 +1,11 @@ .OPTIONS = variable-propagation + OCAMLFINDPACKAGES = "ulex,unix,expat,camlp4.macro,bigarray" OCAMLFINDSYNTAX = camlp4o OCAMLFINDPPOPTS = $(addprefix "-ppopt ", @CAMLP4FLAGS@ -I include) OCAMLFINDINCLUDES = $(addprefix "-I ", src) -OCAMLFINDFLAGS = -syntax $(OCAMLFINDSYNTAX) -package $(OCAMLFINDPACKAGES) \ - $(OCAMLFINDPPOPTS) $(OCAMLFINDINCLUDES) +OCAMLFINDFLAGSNOSYNTAX = -package $(OCAMLFINDPACKAGES) $(OCAMLFINDPPOPTS) $(OCAMLFINDINCLUDES) +OCAMLFINDFLAGS = -syntax $(OCAMLFINDSYNTAX) $(OCAMLFINDFLAGSNOSYNTAX) OCAMLFINDLINKFLAGS = -linkpkg PACKAGE = @PACKAGE_TARNAME@ SRC = src @@ -13,17 +14,21 @@ BYTE = src/@PACKAGE_TARNAME@.byte@EXE@ EXE = @EXE@ REMAKE = @REMAKE@ -OCAMLDEP = @OCAMLDEP@ -ODEPS = tools/odeps.sh $(OCAMLDEP) OCAMLC = @OCAMLC@ OCAMLOPT = @OCAMLOPT@ -OCAMLFLAGS = @OCAMLFLAGS@ +OCAMLDEP = @OCAMLDEP@ +OCAMLFLAGS = @OCAMLFLAGS@ OCAMLOPTFLAGS = @OCAMLOPTFLAGS@ OCAMLCFLAGS = @OCAMLCFLAGS@ -OCAMLYACC = @OCAMLYACC@ +MENHIR = @MENHIR@ + +.PHONY:clean real_test test_native test all: $(BIN) +src/xpath/xpath_internal_parser.cmx: OCAMLFINDFLAGS = $(OCAMLFINDFLAGSNOSYNTAX) +src/xpath/xpath_internal_parser.cmo: OCAMLFINDFLAGS = $(OCAMLFINDFLAGSNOSYNTAX) + tools: tools/xml_diff.native$(EXE) tools/XPathEval.class tools/split_path.native$(EXE) Remakefile: Remakefile.in config.status @@ -61,23 +66,23 @@ distclean: clean test_clean %.class: %.java javac $< -%.native$(EXE): %.cmx %.depx - if test -f $@".flags"; then - FLAGS=`cat $@".flags"` - fi +%.native$(EXE): + $(REMAKE) OCAMLNATIVE="-native" $*.cmx $*.depx objects=`cat $*.depx | xargs | sed 's/[.]depx/.cmx/g'` $(REMAKE) OCAMLNATIVE="-native" $objects #ensure all objects have been built - $(OCAMLOPT) -o $@ $(OCAMLFLAGS) $(OCAMLOPTFLAGS) $(OCAMLFINDLINKFLAGS) $(OCAMLFINDFLAGS) $FLAGS $objects $< + $(OCAMLOPT) -o $@ $(OCAMLFLAGS) $(OCAMLOPTFLAGS) $(OCAMLFINDLINKFLAGS) $(OCAMLFINDFLAGS) $objects $*.cmx + -%.byte$(EXE): %.cmo %.depo +%.byte$(EXE): + $(REMAKE) OCAMLNATIVE="" $*.cmo $*.depo objects=`cat $*.depo | xargs | sed 's/[.]depo/.cmo/g'` $(REMAKE) OCAMLNATIVE="" $objects #ensure all objects have been built - $(OCAMLC) -o $@ $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFINDLINKFLAGS) $(OCAMLFINDFLAGS) $objects $< + $(OCAMLC) -o $@ $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFINDLINKFLAGS) $(OCAMLFINDFLAGS) $objects $*.cmo %.ml: if test -f $*.mly; then $(REMAKE) $*.mly - $(OCAMLYACC) $*.mly + $(MENHIR) $*.mly elif test -f $*.mll; then $(REMAKE) $*.mll $(OCAMLLEX) $*.mll @@ -93,35 +98,33 @@ distclean: clean test_clean base=$* target=$@ DEPEXT=depx - NATIVE=-native - REMAKE="$(REMAKE) OCAMLNATIVE=$NATIVE" + REMAKE="$(REMAKE)" OCAMLDEP="$(OCAMLDEP) $(OCAMLFINDFLAGS)" + OCAMLNATIVE=$(OCAMLNATIVE) SRC=$(SRC) - if test -f "$base".flags; then - FLAGS=`cat "$base".flags` - fi - COMPILE="$(OCAMLOPT) $(OCAMLFLAGS) $(OCAMLOPTFLAGS) $(OCAMLFINDFLAGS) $FLAGS" + COMPILE="$(OCAMLOPT) $(OCAMLFLAGS) $(OCAMLOPTFLAGS) $(OCAMLFINDFLAGS)" . tools/ocamldriver.sh + %.cmo %.depo: base=$* target=$@ DEPEXT=depo - NATIVE="" - REMAKE="$(REMAKE) OCAMLNATIVE=$NATIVE" + REMAKE="$(REMAKE)" OCAMLDEP="$(OCAMLDEP) $(OCAMLFINDFLAGS)" + OCAMLNATIVE=$(OCAMLNATIVE) SRC=$(SRC) - COMPILE="$(OCAMLC) $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFINDFLAGS)" + COMPILE="$(OCAMLC) $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFIND_EXTRAFLAGS) " . tools/ocamldriver.sh %.cmi: base=$* target=$@ - NATIVE=$(OCAMLNATIVE) - REMAKE="$(REMAKE) OCAMLNATIVE=$NATIVE" + REMAKE="$(REMAKE)" OCAMLDEP="$(OCAMLDEP) $(OCAMLFINDFLAGS)" SRC=$(SRC) - if test -z "$NATIVE"; then + OCAMLNATIVE=$(OCAMLNATIVE) + if test -z "$OCAMLNATIVE"; then DEPEXT=.depo COMPILE="$(OCAMLC) $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFINDFLAGS)" else @@ -132,15 +135,9 @@ distclean: clean test_clean ## Tests -test_byte: tools $(BYTE) - $(REMAKE) TEST=$(BYTE) real_test - -test_native: tools $(BIN) - $(REMAKE) TEST=$(BIN) real_test - -test: test_native real_test: + echo $(TEST) for i in tests/*.xml do for j in 1 2 3 @@ -149,10 +146,18 @@ real_test: done done +test_byte: + $(REMAKE) TEST=$(BYTE) real_test +test_native: + $(REMAKE) TEST=$(BIN) real_test + +test: test_native + test_clean: rm -rf tests/*.summary tests/*.results/*_"$(PACKAGE)"_*.* %.summary: + $(REMAKE) tools $(TEST) target=$@ base=$* test=${base#*.xml.}