| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 
 | // <copyright>
// Copyright (c) Microsoft Corporation.  All rights reserved.
// </copyright>
namespace System.ServiceModel
{
    internal static class StringUtil
    {
        private static readonly bool randomizedStringHashingEnabled;
        static StringUtil()
        {
            // StringComparer.InvariantCultureIgnoreCase.GetHashCode is a stable hash between 32 and 64 bits. 
            // Test the result of this GetHashCode against a known test vector to see if randomized hashing is enabled.
            randomizedStringHashingEnabled = StringComparer.InvariantCultureIgnoreCase.GetHashCode("The quick brown fox jumps over the lazy dog.") != 0x703e662e;
        }
        // This should be used instead of String.GetHashCode if the value should be
        // stable even if UseRandomizedStringHashing is enabled.
        internal static int GetNonRandomizedHashCode(string str)
        {
            if (!randomizedStringHashingEnabled)
            {
                return str.GetHashCode();
            }
            return GetStableHashCode(str);
        }
        // This is copied from the 32 bit implementation from String.GetHashCode.
        // Since ServiceModel is compiled for MSIL, we can't have different functionality
        // for 32 and 64 bits.
        [System.Security.SecuritySafeCritical]
        private static int GetStableHashCode(string str)
        {
            unsafe 
            {
                fixed (char* src = str) 
                {
                    int hash1 = (5381 << 16) + 5381;
                    int hash2 = hash1;
                    // 32 bit machines.
                    int* pint = (int*)src;
                    int len = str.Length;
                    while (len > 2)
                    {
                        hash1 = ((hash1 << 5) + hash1 + (hash1 >> 27)) ^ pint[0];
                        hash2 = ((hash2 << 5) + hash2 + (hash2 >> 27)) ^ pint[1];
                        pint += 2;
                        len  -= 4;
                    }
                    if (len > 0)
                    {
                        hash1 = ((hash1 << 5) + hash1 + (hash1 >> 27)) ^ pint[0];
                    }
                    return hash1 + (hash2 * 1566083941);
                }
            }
        }
    }
}
 |