Sha256: 200dfabf77474e62971e464d8cab61f77fc649b440141c9bfa0e41e4a554e760
Contents?: true
Size: 1.64 KB
Versions: 1
Compression:
Stored size: 1.64 KB
Contents
// Copyright 2024 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. #ifndef GRPC_SRC_CORE_CLIENT_CHANNEL_LOAD_BALANCED_CALL_DESTINATION_H #define GRPC_SRC_CORE_CLIENT_CHANNEL_LOAD_BALANCED_CALL_DESTINATION_H #include "absl/functional/any_invocable.h" #include "src/core/client_channel/client_channel.h" #include "src/core/lib/promise/context.h" #include "src/core/lib/transport/call_destination.h" #include "src/core/load_balancing/lb_policy.h" namespace grpc_core { // Context type for LB on_commit callback. // TODO(ctiller): make this a struct, so we don't accidentally alias context // types using LbOnCommit = absl::AnyInvocable<void()>; template <> struct ContextType<LbOnCommit> {}; class LoadBalancedCallDestination final : public UnstartedCallDestination { public: explicit LoadBalancedCallDestination(ClientChannel::PickerObservable picker) : picker_(std::move(picker)) {} void Orphaned() override {} void StartCall(UnstartedCallHandler unstarted_handler) override; private: ClientChannel::PickerObservable picker_; }; } // namespace grpc_core #endif // GRPC_SRC_CORE_CLIENT_CHANNEL_LOAD_BALANCED_CALL_DESTINATION_H
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
grpc-1.68.1 | src/core/client_channel/load_balanced_call_destination.h |