Statistics
| Branch: | Revision:

root / trunk / Pithos.Core / Agents / CollectionExtensions.cs @ b9f5b594

History | View | Annotate | Download (3.3 kB)

1
// -----------------------------------------------------------------------
2
// <copyright file="CollectionExtensions.cs" company="GRNET">
3
// Copyright 2011 GRNET S.A. All rights reserved.
4
// 
5
// Redistribution and use in source and binary forms, with or
6
// without modification, are permitted provided that the following
7
// conditions are met:
8
// 
9
//   1. Redistributions of source code must retain the above
10
//      copyright notice, this list of conditions and the following
11
//      disclaimer.
12
// 
13
//   2. Redistributions in binary form must reproduce the above
14
//      copyright notice, this list of conditions and the following
15
//      disclaimer in the documentation and/or other materials
16
//      provided with the distribution.
17
// 
18
// THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
19
// OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
22
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
25
// USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
26
// AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27
// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
28
// ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29
// POSSIBILITY OF SUCH DAMAGE.
30
// 
31
// The views and conclusions contained in the software and
32
// documentation are those of the authors and should not be
33
// interpreted as representing official policies, either expressed
34
// or implied, of GRNET S.A.
35
// </copyright>
36
// -----------------------------------------------------------------------
37

    
38
using System.Collections.Concurrent;
39

    
40
namespace Pithos.Core.Agents
41
{
42
    using System;
43
    using System.Collections.Generic;
44
    using System.Linq;
45
    using System.Text;
46

    
47
    /// <summary>
48
    /// Extension methods for collections
49
    /// </summary>
50
    public static class CollectionExtensions
51
    {
52
        /// <summary>
53
        /// Remove the first message in a queue that matches the predicate
54
        /// </summary>
55
        /// <param name="predicate">The condition to match</param>
56
        /// <remarks>Removes the first message that matches the predicate by dequeing all 
57
        /// messages and re-enqueing all except the first matching message</remarks>
58
        public static void RemoveFirst<TMessage>(this ConcurrentQueue<TMessage> queue, Func<TMessage, bool> predicate)
59
        {
60
            //Can this work? Dequeue all items 
61
            //and then enqueue everything except the filtered items
62

    
63
            //Possible problems: 
64
            //* A matching item may be dequeued between one TryDequeue and the next
65
            var temp = new Queue<TMessage>();
66
            TMessage message;
67
            var alreadyFound = false;
68
            while (queue.TryDequeue(out message))
69
            {
70
                if (!predicate(message) || alreadyFound)
71
                    temp.Enqueue(message);
72
                else
73
                {
74
                    alreadyFound = true;
75
                }
76
            }
77

    
78
            queue.AddFromEnumerable(temp);
79
        }
80
    }
81
}