本文整理汇总了C#中TrackingCollection.Listen方法的典型用法代码示例。如果您正苦于以下问题:C# TrackingCollection.Listen方法的具体用法?C# TrackingCollection.Listen怎么用?C# TrackingCollection.Listen使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类TrackingCollection
的用法示例。
在下文中一共展示了TrackingCollection.Listen方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Run2
void Run2()
{
var count = 10;
var col = new TrackingCollection<Thing>();
col.ProcessingDelay = TimeSpan.FromMilliseconds(20);
col.NewerComparer = OrderedComparer<Thing>.OrderByDescending(x => x.UpdatedAt).Compare;
list.ItemsSource = col;
var source = Observable.Merge(
Observable.Generate(0, i => i < count, i => i + 1, i => i, i => TimeSpan.FromMilliseconds(5))
.Select(i => GetThing(i, i, i, "Run 1")),
Observable.Generate(0, i => i < count, i => i + 1, i => i, i => TimeSpan.FromMilliseconds(7))
.Select(i => GetThing(i, i, i + 1, "Run 2"))
);
col.Listen(source);
col.Subscribe();
}
示例2: ListeningTwiceWorks
public void ListeningTwiceWorks()
{
var count = 10;
ITrackingCollection<Thing> col = new TrackingCollection<Thing>();
col.NewerComparer = OrderedComparer<Thing>.OrderByDescending(x => x.UpdatedAt).Compare;
col.ProcessingDelay = TimeSpan.Zero;
var list1 = new List<Thing>(Enumerable.Range(1, count).Select(i => GetThing(i, i, count - i, "Run 1")).ToList());
var list2 = new List<Thing>(Enumerable.Range(1, count).Select(i => GetThing(i, i, i + count, "Run 2")).ToList());
var subj = new ReplaySubject<Unit>();
subj.OnNext(Unit.Default);
var disp = col.OriginalCompleted.Subscribe(x => subj.OnCompleted());
col.Listen(list1.ToObservable());
col.Subscribe();
subj.Wait();
disp.Dispose();
col.Listen(list2.ToObservable());
subj = new ReplaySubject<Unit>();
subj.OnNext(Unit.Default);
disp = col.OriginalCompleted.Subscribe(x => subj.OnCompleted());
col.Subscribe();
subj.Wait();
disp.Dispose();
CollectionAssert.AreEqual(list2, col);
}
示例3: GetPullRequests
public ITrackingCollection<IPullRequestModel> GetPullRequests(ISimpleRepositoryModel repo)
{
// Since the api to list pull requests returns all the data for each pr, cache each pr in its own entry
// and also cache an index that contains all the keys for each pr. This way we can fetch prs in bulk
// but also individually without duplicating information. We store things in a custom observable collection
// that checks whether an item is being updated (coming from the live stream after being retrieved from cache)
// and replaces it instead of appending, so items get refreshed in-place as they come in.
var keyobs = GetUserFromCache()
.Select(user => string.Format(CultureInfo.InvariantCulture, "{0}|{1}|pr", user.Login, repo.Name));
var col = new TrackingCollection<IPullRequestModel>();
var source = Observable.Defer(() => keyobs
.SelectMany(key =>
hostCache.GetAndFetchLatestFromIndex(key, () =>
apiClient.GetPullRequestsForRepository(repo.CloneUrl.Owner, repo.CloneUrl.RepositoryName)
.Select(PullRequestCacheItem.Create),
item => col.RemoveItem(Create(item)),
TimeSpan.FromMinutes(5),
TimeSpan.FromDays(1))
)
.Select(Create)
);
col.Listen(source);
return col;
}