tracef(CDebug, "building %d alwayses: %v", len(seen), seen)
errs := make(chan error, len(seen))
for tgt := range seen {
- if err := runScript(tgt, errs, false); err != nil {
+ if err := runScript(tgt, errs, false, false); err != nil {
tracef(CErr, "always run error: %s, skipping dependants", err)
return nil
}
if !ood {
continue
}
- if err := runScript(tgt, errs, false); err != nil {
+ if err := runScript(tgt, errs, false, false); err != nil {
tracef(CErr, "dependant error: %s, skipping dependants", err)
return nil
}
tracef(CDebug, "%s is source, not redoing", tgt)
continue
}
- if err = runScript(tgt, errs, traced); err != nil {
+ if err = runScript(tgt, errs, forced, traced); err != nil {
return false, err
}
jobs++
return err
}
-func runScript(tgtOrig string, errs chan error, traced bool) error {
+func runScript(tgtOrig string, errs chan error, forced, traced bool) error {
cwd, tgt := cwdAndTgt(tgtOrig)
redoDir := path.Join(cwd, RedoDir)
if err := mkdirs(redoDir); err != nil {
return nil
}
+ // Check if it was already built in parallel
+ if !forced {
+ if fdDep, err := os.Open(path.Join(redoDir, tgt+DepSuffix)); err == nil {
+ depInfo, err := depRead(fdDep)
+ fdDep.Close()
+ if err == nil && depInfo.build == BuildUUID {
+ lockRelease()
+ errs <- nil
+ return nil
+ }
+ }
+ }
+
// Check if target is not modified externally
modified, inodePrev, hshPrev, err := isModified(cwd, redoDir, tgt)
if err != nil {