.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
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 distclean
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
%.class: %.java
javac $<
-%.native$(EXE): %.cmx %.depx
- if test -f $@".flags"; then
- FLAGS=`cat $@".flags"`
- fi
- objects=`cat $*.depx | xargs | sed 's/[.]depx/.cmx/g'`
+%.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
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