Esempio n. 1
0
 public SubstreamSubscription(IActorRef parent, SubstreamKey substream)
 {
     if (ReferenceEquals(parent, null))
     {
         throw new ArgumentNullException(nameof(parent), "Parent actor ref cannot be null");
     }
     Parent    = parent;
     Substream = substream;
 }
Esempio n. 2
0
        protected SubstreamOutput CreateSubstreamOutput()
        {
            var id          = new SubstreamKey(NextId());
            var cancellable = ScheduleSubscriptionTimeout(Self, new SubstreamSubscriptionTimeout(id));
            var output      = new SubstreamOutput(id, Self, this, cancellable);

            _substreamOutputs.Add(output.Key, output);
            return(output);
        }
Esempio n. 3
0
        protected override void InvalidateSubstreamOutput(SubstreamKey substream)
        {
            if (!ReferenceEquals(_pendingSubstreamOutput, null) && substream == _pendingSubstreamOutput.Key)
            {
                _pendingSubstreamOutput = null;
                NextPhase(_waitNext);
            }

            base.InvalidateSubstreamOutput(substream);
        }
Esempio n. 4
0
        protected void CompleteSubstreamOutput(SubstreamKey substream)
        {
            SubstreamOutput output;

            if (_substreamOutputs.TryGetValue(substream, out output))
            {
                output.Complete();
                _substreamOutputs.Remove(substream);
            }
        }
Esempio n. 5
0
        protected void CancelSubstreamOutput(SubstreamKey substream)
        {
            SubstreamOutput output;

            if (_substreamOutputs.TryGetValue(substream, out output))
            {
                output.Cancel();
                _substreamOutputs.Remove(substream);
            }
        }
Esempio n. 6
0
 public SubstreamSubscriptionTimeout(SubstreamKey substream)
 {
     Substream = substream;
 }
Esempio n. 7
0
 public SubstreamSubscribe(SubstreamKey substream, ISubscriber <T> subscriber)
 {
     Substream  = substream;
     Subscriber = subscriber;
 }
Esempio n. 8
0
 public SubstreamCancel(SubstreamKey substream)
 {
     Substream = substream;
 }
Esempio n. 9
0
 public SubstreamRequestMore(SubstreamKey substream, long demand)
 {
     Substream = substream;
     Demand    = demand;
 }
Esempio n. 10
0
 protected virtual void InvalidateSubstreamOutput(SubstreamKey substream)
 {
     CancelSubstreamOutput(substream);
     Pump();
 }
Esempio n. 11
0
 public SubstreamOutput(SubstreamKey key, IActorRef actor, IPump pump, ICancelable subscriptionTimeout) : base(actor, pump)
 {
     Key = key;
     SubscriptionTimeout = subscriptionTimeout;
     _subscription       = new SubstreamSubscription(actor, key);
 }