summaryrefslogtreecommitdiff
path: root/dmake/tests/misc-15
diff options
context:
space:
mode:
Diffstat (limited to 'dmake/tests/misc-15')
-rwxr-xr-xdmake/tests/misc-1553
1 files changed, 53 insertions, 0 deletions
diff --git a/dmake/tests/misc-15 b/dmake/tests/misc-15
new file mode 100755
index 000000000000..a213c2d885af
--- /dev/null
+++ b/dmake/tests/misc-15
@@ -0,0 +1,53 @@
+#!/bin/sh
+
+# 09.11.2006 Volker Quetschke
+# Check DOS style paths and directory caching with cygwin dmake or just
+# normal paths with other versions.
+# issue 69742, 69943
+
+: ${DMAKEPROG:=dmake}
+file1="mfile1.mk"
+file2="target.abc"
+tmpfiles="$file1 $file2"
+
+trap '{ echo "trapped signal - removing temporary files" ; rm -rf $tmpfiles ; }' 1 2 3 15
+
+# Remove files from prior failed run
+rm -rf $tmpfiles
+
+echo "Something" > $file2
+
+# Remember to quote variables in generated makefiles ( $ -> \$ ).
+# Also quote line continuations ( \<nl> -> \\<nl> ).
+cat > $file1 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+.DIRCACHE=yes
+
+# Test if .SETDIR works with drive letters
+.IF "\$(subst,Cygwin, \$(shell @uname))"!="\$(shell @uname)"
+MYTARGET:=\$(shell @+cygpath -d "\$(PWD)")\target.abc
+.ELSE
+MYTARGET:=\$(PWD)/target.abc
+.ENDIF
+
+"\$(MYTARGET)" :
+ @echo "Building \$@ - \$(MYTARGET)"
+
+EOT
+
+output=`eval ${DMAKEPROG} -vm -r -f $file1`
+result=$?
+
+if echo "$output" | grep "target.abc' is up to date" > /dev/null 2>&1 ; then
+ # OK
+ dummy=1
+else
+ echo "Wrong result: ${output}"
+ result=1
+fi
+
+test $result -eq 0 && echo "Success - Cleaning up" && rm -f ${tmpfiles}
+test $result -ne 0 && echo "Failure!"
+exit $result