|
|
@ -12,8 +12,7 @@ const debug debugging = true |
|
|
|
|
|
|
|
|
|
|
|
type debugging bool |
|
|
|
type debugging bool |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func (d debugging) log(format string, args ...interface{}) { |
|
|
|
func (d debugging) log(format string, args ...interface{}){ |
|
|
|
|
|
|
|
if d { |
|
|
|
if d { |
|
|
|
log.Printf(format, args...) |
|
|
|
log.Printf(format, args...) |
|
|
|
} |
|
|
|
} |
|
|
@ -45,12 +44,11 @@ func SCORSHerr(err int) error { |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func FindMatchingWorkers(master *SCORSHmaster, msg *SCORSHmsg) []*SCORSHworker { |
|
|
|
func FindMatchingWorkers(master *SCORSHmaster, msg *SCORSHmsg) []*SCORSHworker { |
|
|
|
|
|
|
|
|
|
|
|
var ret []*SCORSHworker |
|
|
|
var ret []*SCORSHworker |
|
|
|
|
|
|
|
|
|
|
|
for idx,w := range master.Workers { |
|
|
|
for idx, w := range master.Workers { |
|
|
|
if w.Matches(msg.Repo, msg.Branch) { |
|
|
|
if w.Matches(msg.Repo, msg.Branch) { |
|
|
|
debug.log("--- Worker: %s matches %s:%s\n", w.Name, msg.Repo, msg.Branch) |
|
|
|
debug.log("--- Worker: %s matches %s:%s\n", w.Name, msg.Repo, msg.Branch) |
|
|
|
ret = append(ret, &(master.Workers[idx])) |
|
|
|
ret = append(ret, &(master.Workers[idx])) |
|
|
@ -59,7 +57,6 @@ func FindMatchingWorkers(master *SCORSHmaster, msg *SCORSHmsg) []*SCORSHworker { |
|
|
|
return ret |
|
|
|
return ret |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func Master(master *SCORSHmaster) { |
|
|
|
func Master(master *SCORSHmaster) { |
|
|
|
|
|
|
|
|
|
|
|
// master main loop:
|
|
|
|
// master main loop:
|
|
|
@ -74,7 +71,7 @@ func Master(master *SCORSHmaster) { |
|
|
|
for { |
|
|
|
for { |
|
|
|
select { |
|
|
|
select { |
|
|
|
// - receive stuff from the spooler
|
|
|
|
// - receive stuff from the spooler
|
|
|
|
case push_msg = <- master.Spooler: |
|
|
|
case push_msg = <-master.Spooler: |
|
|
|
|
|
|
|
|
|
|
|
debug.log("[master] received message: %s\n", push_msg) |
|
|
|
debug.log("[master] received message: %s\n", push_msg) |
|
|
|
|
|
|
|
|
|
|
@ -97,14 +94,12 @@ func InitMaster() *SCORSHmaster { |
|
|
|
|
|
|
|
|
|
|
|
master := ReadGlobalConfig(*conf_file) |
|
|
|
master := ReadGlobalConfig(*conf_file) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
master.Repos = make(map[string][]*SCORSHworker) |
|
|
|
master.Repos = make(map[string][]*SCORSHworker) |
|
|
|
master.WorkingMsg = make(map[string]int) |
|
|
|
master.WorkingMsg = make(map[string]int) |
|
|
|
// This is the mutex-channel on which we receive acks from workers
|
|
|
|
// This is the mutex-channel on which we receive acks from workers
|
|
|
|
master.StatusChan = make(chan SCORSHmsg, 1) |
|
|
|
master.StatusChan = make(chan SCORSHmsg, 1) |
|
|
|
master.Spooler = make(chan SCORSHmsg, 1) |
|
|
|
master.Spooler = make(chan SCORSHmsg, 1) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
err_workers := StartWorkers(master) |
|
|
|
err_workers := StartWorkers(master) |
|
|
|
if err_workers != nil { |
|
|
|
if err_workers != nil { |
|
|
|
log.Fatal("Error starting workers: ", err_workers) |
|
|
|
log.Fatal("Error starting workers: ", err_workers) |
|
|
@ -119,7 +114,6 @@ func InitMaster() *SCORSHmaster { |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func main() { |
|
|
|
func main() { |
|
|
|
|
|
|
|
|
|
|
|
flag.Parse() |
|
|
|
flag.Parse() |
|
|
@ -128,6 +122,6 @@ func main() { |
|
|
|
|
|
|
|
|
|
|
|
go Master(master) |
|
|
|
go Master(master) |
|
|
|
|
|
|
|
|
|
|
|
<- master.StatusChan |
|
|
|
<-master.StatusChan |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|