StopAllParallel stops all the given services in parallel and waits until they've all stopped successfully.
(services ...Service)
| 294 | // StopAllParallel stops all the given services in parallel and waits until |
| 295 | // they've all stopped successfully. |
| 296 | func StopAllParallel(services ...Service) { |
| 297 | var wg sync.WaitGroup |
| 298 | wg.Add(len(services)) |
| 299 | |
| 300 | for i := range services { |
| 301 | service := services[i] |
| 302 | go func() { |
| 303 | defer wg.Done() |
| 304 | service.Stop() |
| 305 | }() |
| 306 | } |
| 307 | |
| 308 | wg.Wait() |
| 309 | } |
| 310 | |
| 311 | // WaitAllStarted waits until all the given services are started (or stopped in |
| 312 | // a degenerate start scenario, like if context is cancelled while starting up). |
searching dependent graphs…