Free cookie consent management tool by TermsFeed Policy Generator

source: trunk/sources/HeuristicLab.ExtLibs/HeuristicLab.ProtobufCS/2.4.1/ProtobufCS/src/ProtocolBuffers/Collections/Dictionaries.cs @ 15529

Last change on this file since 15529 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: 5.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;
33using System.Collections;
34using System.Collections.Generic;
35
36namespace Google.ProtocolBuffers.Collections
37{
38    /// <summary>
39    /// Utility class for dictionaries.
40    /// </summary>
41    public static class Dictionaries
42    {
43        /// <summary>
44        /// Compares two dictionaries for equality. Each value is compared with equality using Equals
45        /// for non-IEnumerable implementations, and using EnumerableEquals otherwise.
46        /// TODO(jonskeet): This is clearly pretty slow, and involves lots of boxing/unboxing...
47        /// </summary>
48        public static bool Equals<TKey, TValue>(IDictionary<TKey, TValue> left, IDictionary<TKey, TValue> right)
49        {
50            if (left.Count != right.Count)
51            {
52                return false;
53            }
54            foreach (KeyValuePair<TKey, TValue> leftEntry in left)
55            {
56                TValue rightValue;
57                if (!right.TryGetValue(leftEntry.Key, out rightValue))
58                {
59                    return false;
60                }
61
62                IEnumerable leftEnumerable = leftEntry.Value as IEnumerable;
63                IEnumerable rightEnumerable = rightValue as IEnumerable;
64                if (leftEnumerable == null || rightEnumerable == null)
65                {
66                    if (!Equals(leftEntry.Value, rightValue))
67                    {
68                        return false;
69                    }
70                }
71                else
72                {
73                    if (!Enumerables.Equals(leftEnumerable, rightEnumerable))
74                    {
75                        return false;
76                    }
77                }
78            }
79            return true;
80        }
81
82        public static IDictionary<TKey, TValue> AsReadOnly<TKey, TValue>(IDictionary<TKey, TValue> dictionary)
83        {
84            return dictionary.IsReadOnly ? dictionary : new ReadOnlyDictionary<TKey, TValue>(dictionary);
85        }
86
87        /// <summary>
88        /// Creates a hashcode for a dictionary by XORing the hashcodes of all the fields
89        /// and values. (By XORing, we avoid ordering issues.)
90        /// TODO(jonskeet): Currently XORs other stuff too, and assumes non-null values.
91        /// </summary>
92        public static int GetHashCode<TKey, TValue>(IDictionary<TKey, TValue> dictionary)
93        {
94            int ret = 31;
95            foreach (KeyValuePair<TKey, TValue> entry in dictionary)
96            {
97                int hash = entry.Key.GetHashCode() ^ GetDeepHashCode(entry.Value);
98                ret ^= hash;
99            }
100            return ret;
101        }
102
103        /// <summary>
104        /// Determines the hash of a value by either taking it directly or hashing all the elements
105        /// for IEnumerable implementations.
106        /// </summary>
107        private static int GetDeepHashCode(object value)
108        {
109            IEnumerable iterable = value as IEnumerable;
110            if (iterable == null)
111            {
112                return value.GetHashCode();
113            }
114            int hash = 29;
115            foreach (object element in iterable)
116            {
117                hash = hash*37 + element.GetHashCode();
118            }
119            return hash;
120        }
121    }
122}
Note: See TracBrowser for help on using the repository browser.