2 /* -----------------------------------------------------------------------
\r
3 * <copyright file="SnapshotDifferencer.cs" company="GRNet">
\r
5 * Copyright 2011-2012 GRNET S.A. All rights reserved.
\r
7 * Redistribution and use in source and binary forms, with or
\r
8 * without modification, are permitted provided that the following
\r
9 * conditions are met:
\r
11 * 1. Redistributions of source code must retain the above
\r
12 * copyright notice, this list of conditions and the following
\r
15 * 2. Redistributions in binary form must reproduce the above
\r
16 * copyright notice, this list of conditions and the following
\r
17 * disclaimer in the documentation and/or other materials
\r
18 * provided with the distribution.
\r
21 * THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
\r
22 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
\r
23 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
\r
24 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
\r
25 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
\r
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
\r
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
\r
28 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
\r
29 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
\r
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
\r
31 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
\r
32 * POSSIBILITY OF SUCH DAMAGE.
\r
34 * The views and conclusions contained in the software and
\r
35 * documentation are those of the authors and should not be
\r
36 * interpreted as representing official policies, either expressed
\r
37 * or implied, of GRNET S.A.
\r
39 * -----------------------------------------------------------------------
\r
42 using System.Collections.Concurrent;
\r
43 using Pithos.Interfaces;
\r
44 using Pithos.Network;
\r
46 namespace Pithos.Core.Agents
\r
49 using System.Collections.Generic;
\r
54 /// TODO: Update summary.
\r
56 public class SnapshotDifferencer
\r
58 private IEnumerable<ObjectInfo> _previous;
\r
59 private IEnumerable<ObjectInfo> _current;
\r
60 private static ObjectInfo[] _empty = new ObjectInfo[0];
\r
61 private ObjectInfoComparer _comparer = new ObjectInfoComparer();
\r
63 public SnapshotDifferencer()
\r
65 _previous = new List<ObjectInfo>();
\r
66 _current= new List<ObjectInfo>();
\r
70 public SnapshotDifferencer(IEnumerable<ObjectInfo> previous,IEnumerable<ObjectInfo> current )
\r
72 _previous = previous ?? new List<ObjectInfo>();
\r
73 _current= current ?? new List<ObjectInfo>();
\r
75 public SnapshotDifferencer Post(IEnumerable<ObjectInfo> list)
\r
77 _previous = _current;
\r
78 _current = list ?? new List<ObjectInfo>();
\r
82 public IEnumerable<ObjectInfo> Deleted
\r
84 get { return _previous.Except(_current,_comparer); }
\r
86 public IEnumerable<ObjectInfo> Created
\r
88 get { return _current.Except(_previous,_comparer); }
\r
90 public IEnumerable<ObjectInfo> Changed
\r
94 var changes = from newItem in _current
\r
95 let oldItem=_previous.FirstOrDefault(old=>_comparer.Equals(old,newItem))
\r
96 where oldItem !=null &&
\r
97 newItem.Hash != oldItem.Hash
\r
102 public IEnumerable<ObjectInfo> Unchanged
\r
106 var unChanged = from newItem in _current
\r
107 let oldItem = _previous.FirstOrDefault(old => _comparer.Equals(old, newItem))
\r
108 where oldItem != null &&
\r
109 newItem.Hash == oldItem.Hash
\r
116 public class AccountsDifferencer
\r
118 ConcurrentDictionary<string, SnapshotDifferencer> _differencers = new ConcurrentDictionary<string, SnapshotDifferencer>();
\r
120 public ConcurrentDictionary<string, SnapshotDifferencer> Differencers { get { return _differencers; } }
\r
122 public SnapshotDifferencer PostSnapshot(AccountInfo accountInfo, List<ObjectInfo> cleanRemotes)
\r
124 SnapshotDifferencer differencer;
\r
125 if (!_differencers.TryGetValue(accountInfo.UserName, out differencer))
\r
127 differencer = new SnapshotDifferencer();
\r
128 _differencers[accountInfo.UserName] = differencer;
\r
130 differencer.Post(cleanRemotes);
\r
131 return differencer;
\r