diff options
author | Grail Finder <wohilas@gmail.com> | 2023-02-18 21:10:50 +0600 |
---|---|---|
committer | Grail Finder <wohilas@gmail.com> | 2023-02-18 21:10:50 +0600 |
commit | 1ec6ff8ec85ea4597b4897f1d2f1a89ec5e1abb1 (patch) | |
tree | ca809686b6c3928b5f3c6879931e70decbe428d1 /main.go | |
parent | df498c756b1cb0e3f045bc88396223272b713a4c (diff) |
Feat: close channel before iterating
Diffstat (limited to 'main.go')
-rw-r--r-- | main.go | 12 |
1 files changed, 9 insertions, 3 deletions
@@ -188,6 +188,7 @@ func main() { // === concurrent === queue := make(chan *Utterance, len(utterances)) geshaft := make(chan *Utterance, len(utterances)) + done := make(chan bool, 1) for _, ut := range utterances { if _, err := os.Stat(ut.OutPath); os.IsNotExist(err) { @@ -204,23 +205,28 @@ func main() { workers := 100 for i := 0; i < workers; i++ { - go worker(queue, i, geshaft) + go worker(queue, done, i, geshaft) } for { if len(queue) == 0 { + fmt.Println("empty queue: sending true to done") + done <- true // give time for workers to finish - time.Sleep(3 * time.Second) + fmt.Println("sleeping for few seconds") + time.Sleep(5 * time.Second) + fmt.Println("closing queue") close(queue) + fmt.Println("breaking from the loop") break } time.Sleep(1 * time.Second) } + close(geshaft) for ut := range geshaft { filteredUtterances = append(filteredUtterances, ut) } - close(geshaft) newMeta := utterancesToFileTextMap(filteredUtterances) writeCSV(mapToCSV(newMeta)) } |