HedgingController<T>
using Polly.Hedging.Controller;
using Polly.Telemetry;
using Polly.Utils;
using System;
using System.Runtime.CompilerServices;
using System.Threading;
namespace Polly.Hedging.Utils
{
    [NullableContext(1)]
    [Nullable(0)]
    internal sealed class HedgingController<[Nullable(2)] T>
    {
        private readonly ObjectPool<HedgingExecutionContext<T>> _contextPool;
        private readonly ObjectPool<TaskExecution<T>> _executionPool;
        private int _rentedContexts;
        private int _rentedExecutions;
        public int RentedContexts => _rentedContexts;
        public int RentedExecutions => _rentedExecutions;
        public HedgingController(ResilienceStrategyTelemetry telemetry, TimeProvider provider, HedgingHandler<T> handler, int maxAttempts)
        {
            CancellationTokenSourcePool pool = CancellationTokenSourcePool.Create(provider);
            _executionPool = new ObjectPool<TaskExecution<T>>(delegate {
                Interlocked.Increment(ref _rentedExecutions);
                return new TaskExecution<T>(handler, pool, provider, telemetry);
            }, delegate {
                Interlocked.Decrement(ref _rentedExecutions);
                return true;
            });
            Action<HedgingExecutionContext<T>> onReset = null;
            _contextPool = new ObjectPool<HedgingExecutionContext<T>>(delegate {
                Interlocked.Increment(ref _rentedContexts);
                return new HedgingExecutionContext<T>(_executionPool, provider, maxAttempts, onReset);
            }, delegate {
                Interlocked.Decrement(ref _rentedContexts);
                return true;
            });
            onReset = _contextPool.Return;
        }
        public HedgingExecutionContext<T> GetContext(ResilienceContext context)
        {
            HedgingExecutionContext<T> hedgingExecutionContext = _contextPool.Get();
            hedgingExecutionContext.Initialize(context);
            return hedgingExecutionContext;
        }
    }
}