mirror of https://github.com/perkeep/perkeep.git
camweb: make syncing to github concurrent
Camweb is in charge of syncing the commits from the gerrit repository to our mirror on github. It also sends the commits as e-mails to the Camlistore mailing-list. The former was only happening after the latter did, but there was no reason to do it that way, as these tasks are independent. Moreover, when sending e-mails is problematic (issue #980), it delays syncing to github. This change therefore makes syncing to github concurrent with sending the e-mails. Change-Id: I63a2b3f5b49df58ca30ec5153ce65eafb44b5b28
This commit is contained in:
parent
a91a98c58a
commit
31389f8ab2
|
@ -229,6 +229,15 @@ func pollCommits(dir string) {
|
||||||
latestHash.Lock()
|
latestHash.Lock()
|
||||||
latestHash.s = hashes[0]
|
latestHash.s = hashes[0]
|
||||||
latestHash.Unlock()
|
latestHash.Unlock()
|
||||||
|
githubSyncC := make(chan bool, 1)
|
||||||
|
go func() {
|
||||||
|
if githubSSHKey != "" {
|
||||||
|
if err := syncToGithub(dir, hashes[0]); err != nil {
|
||||||
|
log.Printf("Failed to push commit %v to github: %v", hashes[0], err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
githubSyncC <- true
|
||||||
|
}()
|
||||||
for _, commit := range hashes {
|
for _, commit := range hashes {
|
||||||
if knownCommit[commit] {
|
if knownCommit[commit] {
|
||||||
continue
|
continue
|
||||||
|
@ -254,11 +263,7 @@ func pollCommits(dir string) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if githubSSHKey != "" {
|
<-githubSyncC
|
||||||
if err := syncToGithub(dir, hashes[0]); err != nil {
|
|
||||||
log.Printf("Failed to push commit %v to github: %v", hashes[0], err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func recentCommits(dir string) (hashes []string, err error) {
|
func recentCommits(dir string) (hashes []string, err error) {
|
||||||
|
|
Loading…
Reference in New Issue