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