public static ProbabilisticSamplingStrategy FromThrift(this global::Jaeger.Thrift.Agent.ProbabilisticSamplingStrategy thriftInstance)
 {
     return(new ProbabilisticSamplingStrategy
     {
         SamplingRate = thriftInstance.SamplingRate
     });
 }
        public async global::System.Threading.Tasks.Task ReadAsync(TProtocol iprot, CancellationToken cancellationToken)
        {
            iprot.IncrementRecursionDepth();
            try
            {
                bool   isset_strategyType = false;
                TField field;
                await iprot.ReadStructBeginAsync(cancellationToken);

                while (true)
                {
                    field = await iprot.ReadFieldBeginAsync(cancellationToken);

                    if (field.Type == TType.Stop)
                    {
                        break;
                    }

                    switch (field.ID)
                    {
                    case 1:
                        if (field.Type == TType.I32)
                        {
                            StrategyType = (global::Jaeger.Thrift.Agent.SamplingStrategyType) await iprot.ReadI32Async(cancellationToken);

                            isset_strategyType = true;
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    case 2:
                        if (field.Type == TType.Struct)
                        {
                            ProbabilisticSampling = new global::Jaeger.Thrift.Agent.ProbabilisticSamplingStrategy();
                            await ProbabilisticSampling.ReadAsync(iprot, cancellationToken);
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    case 3:
                        if (field.Type == TType.Struct)
                        {
                            RateLimitingSampling = new global::Jaeger.Thrift.Agent.RateLimitingSamplingStrategy();
                            await RateLimitingSampling.ReadAsync(iprot, cancellationToken);
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    case 4:
                        if (field.Type == TType.Struct)
                        {
                            OperationSampling = new global::Jaeger.Thrift.Agent.PerOperationSamplingStrategies();
                            await OperationSampling.ReadAsync(iprot, cancellationToken);
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    default:
                        await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);

                        break;
                    }

                    await iprot.ReadFieldEndAsync(cancellationToken);
                }

                await iprot.ReadStructEndAsync(cancellationToken);

                if (!isset_strategyType)
                {
                    throw new TProtocolException(TProtocolException.INVALID_DATA);
                }
            }
            finally
            {
                iprot.DecrementRecursionDepth();
            }
        }
Пример #3
0
 public OperationSamplingStrategy(string operation, global::Jaeger.Thrift.Agent.ProbabilisticSamplingStrategy probabilisticSampling) : this()
 {
     this.Operation             = operation;
     this.ProbabilisticSampling = probabilisticSampling;
 }