Source File
	callback_serializer.go
Belonging Package
	google.golang.org/grpc/internal/grpcsync
/*** Copyright 2022 gRPC authors.** Licensed 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 grpcsyncimport ()// CallbackSerializer provides a mechanism to schedule callbacks in a// synchronized manner. It provides a FIFO guarantee on the order of execution// of scheduled callbacks. New callbacks can be scheduled by invoking the// Schedule() method.//// This type is safe for concurrent access.type CallbackSerializer struct {// done is closed once the serializer is shut down completely, i.e all// scheduled callbacks are executed and the serializer has deallocated all// its resources.done chan struct{}callbacks *buffer.Unbounded}// NewCallbackSerializer returns a new CallbackSerializer instance. The provided// context will be passed to the scheduled callbacks. Users should cancel the// provided context to shutdown the CallbackSerializer. It is guaranteed that no// callbacks will be added once this context is canceled, and any pending un-run// callbacks will be executed before the serializer is shut down.func ( context.Context) *CallbackSerializer {:= &CallbackSerializer{done: make(chan struct{}),callbacks: buffer.NewUnbounded(),}go .run()return}// TrySchedule tries to schedule the provided callback function f to be// executed in the order it was added. This is a best-effort operation. If the// context passed to NewCallbackSerializer was canceled before this method is// called, the callback will not be scheduled.//// Callbacks are expected to honor the context when performing any blocking// operations, and should return early when the context is canceled.func ( *CallbackSerializer) ( func( context.Context)) {.callbacks.Put()}// ScheduleOr schedules the provided callback function f to be executed in the// order it was added. If the context passed to NewCallbackSerializer has been// canceled before this method is called, the onFailure callback will be// executed inline instead.//// Callbacks are expected to honor the context when performing any blocking// operations, and should return early when the context is canceled.func ( *CallbackSerializer) ( func( context.Context), func()) {if .callbacks.Put() != nil {()}}func ( *CallbackSerializer) ( context.Context) {defer close(.done)// TODO: when Go 1.21 is the oldest supported version, this loop and Close// can be replaced with://// context.AfterFunc(ctx, cs.callbacks.Close)for .Err() == nil {select {case <-.Done():// Do nothing here. Next iteration of the for loop will not happen,// since ctx.Err() would be non-nil.case := <-.callbacks.Get():.callbacks.Load().(func(context.Context))()}}// Close the buffer to prevent new callbacks from being added..callbacks.Close()// Run all pending callbacks.for := range .callbacks.Get() {.callbacks.Load().(func(context.Context))()}}// Done returns a channel that is closed after the context passed to// NewCallbackSerializer is canceled and all callbacks have been executed.func ( *CallbackSerializer) () <-chan struct{} {return .done}
The pages are generated with Golds v0.7.6. (GOOS=linux GOARCH=amd64)