X-Git-Url: http://git.nguyen.vg/gitweb/?p=tatoo.git;a=blobdiff_plain;f=Remakefile.in;h=f8552fe32185270f60a771c6eccb677e0893f653;hp=3f16f267f2ed9bb66f8d8209ca745892df3ae124;hb=aade6d9ba2e2b65e021de8a1c3a2d3874aa5742e;hpb=acd23a33d837d03c813212ec3896a86edef16e87 diff --git a/Remakefile.in b/Remakefile.in index 3f16f26..f8552fe 100644 --- a/Remakefile.in +++ b/Remakefile.in @@ -5,14 +5,24 @@ OCAMLFINDINCLUDES = $(addprefix "-I ", src) OCAMLFINDFLAGS = -syntax $(OCAMLFINDSYNTAX) -package $(OCAMLFINDPACKAGES) \ $(OCAMLFINDPPOPTS) $(OCAMLFINDINCLUDES) OCAMLFINDLINKFLAGS = -linkpkg -ODEP=tools/odeps.sh @OCAMLDEP@ -PACKAGE=@PACKAGE_TARNAME@ -BIN=src/@PACKAGE_TARNAME@.native@EXE@ -EXE=@EXE@ +PACKAGE = @PACKAGE_TARNAME@ +SRC = src +BIN = src/@PACKAGE_TARNAME@.native@EXE@ +EXE = @EXE@ + +REMAKE = @REMAKE@ +OCAMLDEP = @OCAMLDEP@ +ODEPS = tools/odeps.sh $(OCAMLDEP) +OCAMLC = @OCAMLC@ +OCAMLOPT = @OCAMLOPT@ +OCAMLFLAGS = @OCAMLFLAGS@ +OCAMLOPTFLAGS = @OCAMLOPTFLAGS@ +OCAMLCFLAGS = @OCAMLCFLAGS@ +OCAMLYACC = @OCAMLYACC@ all: $(BIN) -tools: tools/xml_diff.native@EXE@ tools/XPathEval.class +tools: tools/xml_diff.native$(EXE) tools/XPathEval.class tools/split_path.native$(EXE) Remakefile: Remakefile.in config.status ./config.status Remakefile @@ -25,7 +35,7 @@ clean: for dir in src tools; do find $dir -name '*.cm*' -o -name '*.o' -o -name '*.byte' -o \ -name '*.native' -o -name '*.mll' -o -name '*.mly' -o \ - -name '*.class' | while read file; do + -name '*.class' -o -name '*.dep' | while read file; do case "$file" in *.mll) rm -f "${file%.mll}.ml" @@ -41,144 +51,84 @@ clean: done distclean: clean test_clean - rm -rf config.status configure config.log autom4te.cache .remake Remakefile remake + rm -rf config.status configure config.log autom4te.cache .remake Remakefile remake Makefile %.class: %.java - javac ${1%.class}.java - -%.native@EXE@: - base=${1%.native} - src=${base}.ml - obj=${base}.cmx - dir=$(dirname $1) - @REMAKE@ -v OCAMLDEPNATIVE=-native "$obj" - SRCS=$(ls "$dir"/*.cmx | sed 's/\.cmx/.ml/g') - OBJS=$(@OCAMLDEP@ $OCAMLDEPNATIVE $OCAMLFINDFLAGS -modules $SRCS | tools/osort.sh cmx) - @OCAMLOPT@ -o "$1" @OCAMLFLAGS@ @OCAMLOPTFLAGS@ $OCAMLFINDLINKFLAGS $OCAMLFINDFLAGS $OBJS - -%.byte@EXE@: - base=${1%.byte} - src=${base}.ml - obj=${base}.cmo - dir=$(dirname $1) - @REMAKE@ "$obj" - OBJS="" - for i in "$dir"/*.cmi; do - ibase=${i%.cmi} - if test -f "${ibase}.ml" -o -d "${ibase}" -o -f "${ibase}.mly" -o -f "${ibase}.mll"; then - OBJS="$OBJS ${ibase}.cmo" - fi - done - @REMAKE@ $OBJS - SRCS=$(ls "$dir"/*.cmo | sed 's/\.cmo/.ml/g') - SORTED_OBJS=$(@OCAMLDEP@ $OCAMLFINDFLAGS -modules $SRCS | tools/osort.sh cmo) - @OCAMLC@ -o "$1" @OCAMLFLAGS@ @OCAMLCFLAGS@ $OCAMLFINDLINKFLAGS $OCAMLFINDFLAGS $SORTED_OBJS - -%.cmx: - target="$1" - base="${target%.cmx}" - src="${base}.ml" - if [ -f "$src" ]; then - @REMAKE@ "$src" - DEPS=$( $ODEP -native $OCAMLFINDFLAGS $PACKINCLUDE "$src" ) - echo "$DEPS" | @REMAKE@ -v PACKINCLUDE="$PACKINCLUDE" -v OCAMLDEPNATIVE=-native -v OCAMLFORPACK="$OCAMLFORPACK" -r "$target" - @OCAMLOPT@ -o "$target" -c @OCAMLFLAGS@ @OCAMLOPTFLAGS@ $OCAMLFORPACK $OCAMLFINDFLAGS $PACKINCLUDE "$src" - elif [ -d "$base" ]; then - modname=$(basename "$base") - packname=$(echo "$modname" | sed 's/\(.*\)/\u\1/') - OBJS=$(ls "$base"/*.ml | sed 's/\.ml/.cmx/g') - @REMAKE@ -v PACKINCLUDE="-I $base" -v OCAMLFORPACK="-for-pack $packname" $OBJS - SORTED_OBJS=$(@OCAMLDEP@ -native $OCAMLFINDFLAGS -I $base -modules "$base"/*.ml | tools/osort.sh cmx) - @OCAMLOPT@ -o "$target" -pack $SORTED_OBJS - elif [ -f "$base".mly ]; then - @REMAKE@ "$base".mly - @OCAMLYACC@ "$base".mly - $ODEP $OCAMLDEPNATIVE $OCAMLFINDFLAGS "$src" | \ - @REMAKE@ -v PACKINCLUDE="$PACKINCLUDE" -v OCAMLDEPNATIVE=-native -v OCAMLFORPACK="$OCAMLFORPACK" -r "$target" - @OCAMLOPT@ -o "$target" -c @OCAMLFLAGS@ @OCAMLOPTFLAGS@ $OCAMLFORPACK $OCAMLFINDFLAGS $PACKINCLUDE "$src" - fi + javac $< +%.native$(EXE): %.cmx %.dep + objects=`cat $*.dep | xargs | sed 's/[.]dep/.cmx/g'` + $(OCAMLOPT) -o $@ $(OCAMLFLAGS) $(OCAMLOPTFLAGS) $(OCAMLFINDLINKFLAGS) $(OCAMLFINDFLAGS) $objects $< -%.cmo: - target="$1" - base="${target%.cmo}" - src="${base}.ml" - if [ -f "$src" ]; then - @REMAKE@ "$src" - DEPS=$( $ODEP $OCAMLFINDFLAGS $PACKINCLUDE "$src" ) - echo "$DEPS" | @REMAKE@ -v PACKINCLUDE="$PACKINCLUDE" -r "$target" - @OCAMLC@ -o "$target" -c @OCAMLFLAGS@ @OCAMLCFLAGS@ $OCAMLFINDFLAGS $PACKINCLUDE "$src" - elif [ -d "$base" ]; then - modname=$(basename "$base") - packname=$(echo "$modname" | sed 's/\(.*\)/\u\1/') - OBJS=$(ls "$base"/*.ml | sed 's/\.ml/.cmo/g') - @REMAKE@ -v PACKINCLUDE="-I $base" $OBJS - SORTED_OBJS=$(@OCAMLDEP@ $OCAMLFINDFLAGS -I $base -modules "$base"/*.ml | tools/osort.sh cmo) - @OCAMLC@ -o "$target" -pack $SORTED_OBJS - elif [ -f "$base".mly ]; then - @REMAKE@ "$base".mly - @OCAMLYACC@ "$base".mly - $ODEP $OCAMLFINDFLAGS $PACKINCLUDE "$src" | @REMAKE@ -v PACKINCLUDE="$PACKINCLUDE" -r "$target" - @OCAMLC@ -o "$target" -c @OCAMLFLAGS@ @OCAMLCFLAGS@ $OCAMLFINDFLAGS $PACKINCLUDE "$src" - fi +%.byte$(EXE): %.cmo %.dep + objects=`cat $*.dep | xargs | sed 's/[.]dep/.cmo/g'` + $(OCAMLC) -o $@ $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFINDLINKFLAGS) $(OCAMLFINDFLAGS) $objects $< +%.ml: + if test -f $*.mly; then + $(OCAMLYACC) $*.mly + elif test -f $*.mll; then + $(OCAMLLEX) $*.mll + fi +%.cmx %.dep: + base=$* + target=$@ + NATIVE=-native + REMAKE="$(REMAKE) -v OCAMLNATIVE=$NATIVE" + OCAMLDEP="$(OCAMLDEP) $(OCAMLFINDFLAGS)" + SRC=$(SRC) + COMPILE="$(OCAMLOPT) $(OCAMLFLAGS) $(OCAMLOPTFLAGS) $(OCAMLFINDFLAGS)" + . tools/ocamldriver.sh + +%.cmo %.dep: + base=$* + target=$@ + NATIVE= + REMAKE="$(REMAKE) -v OCAMLNATIVE=$NATIVE" + OCAMLDEP="$(OCAMLDEP) $(OCAMLFINDFLAGS)" + SRC=$(SRC) + COMPILE="$(OCAMLC) $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFINDFLAGS)" + . tools/ocamldriver.sh %.cmi: - target="$1" - base=${target%.cmi} - if test -f "$base".mli; then - @REMAKE@ "$base".mli - src=${base}.mli - DEPS=$($ODEP $OCAMLDEPNATIVE $OCAMLFINDFLAGS $PACKINCLUDE "$src") - echo "$DEPS" | @REMAKE@ -v PACKINCLUDE="$PACKINCLUDE" -v OCAMLDEPNATIVE="$OCAMLDEPNATIVE" -v OCAMLFORPACK="$OCAMLFORPACK" -r "$target" - if test -z "$OCAMLDEPNATIVE"; then - @OCAMLC@ -o "$target" -c @OCAMLFLAGS@ @OCAMLCFLAGS@ $OCAMLFINDFLAGS $PACKINCLUDE "$src" - else - @OCAMLOPT@ -o "$target" -c @OCAMLFLAGS@ @OCAMLOPTFLAGS@ $OCAMLFINDFLAGS $PACKINCLUDE "$src" - fi + base=$* + target=$@ + NATIVE=$(OCAMLNATIVE) + REMAKE="$(REMAKE) -v OCAMLNATIVE=$NATIVE" + OCAMLDEP="$(OCAMLDEP) $(OCAMLFINDFLAGS)" + SRC=$(SRC) + if test -z "$NATIVE"; then + COMPILE="$(OCAMLC) $(OCAMLFLAGS) $(OCAMLCFLAGS) $(OCAMLFINDFLAGS)" else - if test -z "$OCAMLDEPNATIVE"; then - obj=${base}.cmo - else - obj=${base}.cmx - fi - @REMAKE@ -v PACKINCLUDE="$PACKINCLUDE" -v OCAMLDEPNATIVE="$OCAMLDEPNATIVE" -v OCAMLFORPACK="$OCAMLFORPACK" "$obj" + COMPILE="$(OCAMLOPT) $(OCAMLFLAGS) $(OCAMLOPTFLAGS) $(OCAMLFINDFLAGS)" fi + . tools/ocamldriver.sh ## Tests test: for i in tests/*.xml do - @REMAKE@ "$i".summary + for j in 1 2 3 + do + $(REMAKE) "$i".test"$j".summary + done done test_clean: - rm -rf tests/*.summary tests/*.results/*_"$PACKAGE".* - -%.summary: - base="${1%.xml.summary}" - @REMAKE@ "$base".xml "$base".xml.queries tools "$BIN" - rm -f "$1" - cat "$base".xml.queries | grep -v '^#' | while read q query; do - echo -n "$base"".xml $q $query ... " - REF="$base".xml.results/"$q"_jaxp.xml - @REMAKE@ "$REF" - OUTPUT="$base".xml.results/"$q"_"$PACKAGE".xml - LOG="$base".xml.results/"$q"_"$PACKAGE".log - src/@PACKAGE_TARNAME@.native@EXE@ -s "$base".xml \ - "$query" "$OUTPUT" > "$LOG" 2>&1 - echo "Query: $q : $query" >> "$1" - cat "$LOG" | grep '^STATS' >> "$1" - echo -n "Diff: " >> "$1" - if tools/xml_diff.native "$REF" "$OUTPUT" >/dev/null 2>&1; then - echo ok - echo ok >> "$1" - else - echo failed - echo failed >> "$1" - exit 1 - fi - echo '-------------------------------------------' >> "$1" - done + rm -rf tests/*.summary tests/*.results/*_"$(PACKAGE)"_*.* + +%.summary: tools $(BIN) + target=$@ + base=$* + test=${base#*.xml.} + xml=${base%.$test} + REMAKE=$(REMAKE) + BIN=$(BIN) + SPLIT=tools/split_path.native$(EXE) + XMLDIFF=tools/xml_diff.native$(EXE) + PACKAGE=$(PACKAGE) + $REMAKE $xml ${xml}.queries tests/${test}.sh + rm -f "$target" + . tests/${test}.sh