)
}
-func writeDeps(fdDep *os.File, tgts []string) error {
+func writeDeps(fdDep *os.File, tgts []string) (err error) {
if fdDep == nil {
trace(CDebug, "no opened fdDep: %s", tgts)
return nil
}
for _, tgt := range tgts {
- if _, err := os.Stat(tgt); err == nil {
- tgtAbs, err := filepath.Abs(tgt)
- if err != nil {
- panic(err)
- }
- tgtDir := path.Join(Cwd, DirPrefix)
- tgtRel, err := filepath.Rel(tgtDir, tgtAbs)
- if err != nil {
- panic(err)
- }
- if err = writeDep(fdDep, tgtDir, tgtRel); err != nil {
- return err
- }
+ tgtAbs, err := filepath.Abs(tgt)
+ if err != nil {
+ panic(err)
+ }
+ tgtDir := path.Join(Cwd, DirPrefix)
+ tgtRel, err := filepath.Rel(tgtDir, tgtAbs)
+ if err != nil {
+ panic(err)
+ }
+ if _, errStat := os.Stat(tgt); errStat == nil {
+ err = writeDep(fdDep, tgtDir, tgtRel)
} else {
- trace(CDebug, "skipping dep record, can not stat: %s", tgt)
+ trace(CDebug, "ifchange: %s <- %s (unexisting)", fdDep.Name(), tgtRel)
+ err = recfileWrite(
+ fdDep,
+ recfile.Field{Name: "Type", Value: DepTypeIfchange},
+ recfile.Field{Name: "Target", Value: tgtRel},
+ recfile.Field{Name: "Ctime", Value: "0.0"},
+ )
}
}
- return nil
+ return
}
type DepInfo struct {
--- /dev/null
+#!/bin/sh
+
+testname=`basename "$0"`
+test_description="Check that empty target is a dependency and always OOD"
+. $SHARNESS_TEST_SRCDIR/sharness.sh
+
+tmp=`mktemp -d`
+trap "rm -fr $tmp" HUP PIPE INT QUIT TERM EXIT
+cd $tmp
+
+echo > foo.do
+cat > bar.do <<EOF
+redo-ifchange foo
+echo bar
+EOF
+export REDO_NO_PROGRESS=1
+redo-ifchange bar
+stat1=`stat bar`
+redo-ifchange bar
+stat2=`stat bar`
+
+test_expect_success "bar rebuilds" '[ "$stat1" != "$stat2" ]'
+
+test_done