Free cookie consent management tool by TermsFeed Policy Generator

source: branches/PersistenceOverhaul/HeuristicLab.ExtLibs/HeuristicLab.ProtobufCS/2.4.1/ProtobufCS/src/ProtocolBuffers/Collections/Lists.cs @ 13957

Last change on this file since 13957 was 8295, checked in by abeham, 12 years ago

#1897:

  • Removed protocol buffers 0.9.1
  • Added protocol buffers 2.4.1
  • Updated proto processing command
File size: 4.0 KB
Line 
1// Protocol Buffers - Google's data interchange format
2// Copyright 2008 Google Inc.  All rights reserved.
3// http://github.com/jskeet/dotnet-protobufs/
4// Original C++/Java/Python code:
5// http://code.google.com/p/protobuf/
6//
7// Redistribution and use in source and binary forms, with or without
8// modification, are permitted provided that the following conditions are
9// met:
10//
11//     * Redistributions of source code must retain the above copyright
12// notice, this list of conditions and the following disclaimer.
13//     * Redistributions in binary form must reproduce the above
14// copyright notice, this list of conditions and the following disclaimer
15// in the documentation and/or other materials provided with the
16// distribution.
17//     * Neither the name of Google Inc. nor the names of its
18// contributors may be used to endorse or promote products derived from
19// this software without specific prior written permission.
20//
21// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32using System.Collections.Generic;
33using System.Collections.ObjectModel;
34
35namespace Google.ProtocolBuffers.Collections
36{
37    /// <summary>
38    /// Utility non-generic class for calling into Lists{T} using type inference.
39    /// </summary>
40    public static class Lists
41    {
42        /// <summary>
43        /// Returns a read-only view of the specified list.
44        /// </summary>
45        public static IList<T> AsReadOnly<T>(IList<T> list)
46        {
47            return Lists<T>.AsReadOnly(list);
48        }
49
50        public static bool Equals<T>(IList<T> left, IList<T> right)
51        {
52            if (left == right)
53            {
54                return true;
55            }
56            if (left == null || right == null)
57            {
58                return false;
59            }
60            if (left.Count != right.Count)
61            {
62                return false;
63            }
64            IEqualityComparer<T> comparer = EqualityComparer<T>.Default;
65            for (int i = 0; i < left.Count; i++)
66            {
67                if (!comparer.Equals(left[i], right[i]))
68                {
69                    return false;
70                }
71            }
72            return true;
73        }
74
75        public static int GetHashCode<T>(IList<T> list)
76        {
77            int hash = 31;
78            foreach (T element in list)
79            {
80                hash = hash*29 + element.GetHashCode();
81            }
82            return hash;
83        }
84    }
85
86    /// <summary>
87    /// Utility class for dealing with lists.
88    /// </summary>
89    public static class Lists<T>
90    {
91        private static readonly ReadOnlyCollection<T> empty = new ReadOnlyCollection<T>(new T[0]);
92
93        /// <summary>
94        /// Returns an immutable empty list.
95        /// </summary>
96        public static ReadOnlyCollection<T> Empty
97        {
98            get { return empty; }
99        }
100
101        /// <summary>
102        /// Returns either the original reference if it's already read-only,
103        /// or a new ReadOnlyCollection wrapping the original list.
104        /// </summary>
105        public static IList<T> AsReadOnly(IList<T> list)
106        {
107            return list.IsReadOnly ? list : new ReadOnlyCollection<T>(list);
108        }
109    }
110}
Note: See TracBrowser for help on using the repository browser.