pkg/run/channel_group_closer.go (31 lines of code) (raw):

// Licensed to Apache Software Foundation (ASF) under one or more contributor // license agreements. See the NOTICE file distributed with // this work for additional information regarding copyright // ownership. Apache Software Foundation (ASF) licenses this file to you under // the Apache License, Version 2.0 (the "License"); you may // not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, // software distributed under the License is distributed on an // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, either express or implied. See the License for the // specific language governing permissions and limitations // under the License. package run import ( "sync" ) // ChannelGroupCloser can close a goroutine group then wait for it to stop. type ChannelGroupCloser struct { group []*ChannelCloser lock sync.RWMutex closed bool } // NewChannelGroupCloser instances a new ChannelGroupCloser. func NewChannelGroupCloser(closer ...*ChannelCloser) *ChannelGroupCloser { return &ChannelGroupCloser{group: closer} } // CloseThenWait closes all closer then waits till they are done. func (c *ChannelGroupCloser) CloseThenWait() { if c == nil { return } c.lock.Lock() c.closed = true c.lock.Unlock() for _, closer := range c.group { closer.CloseThenWait() } } // Closed returns whether the ChannelGroupCloser is closed. func (c *ChannelGroupCloser) Closed() bool { if c == nil { return true } c.lock.RLock() defer c.lock.RUnlock() return c.closed }