File: String%2BHashing.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (37 lines) | stat: -rw-r--r-- 1,175 bytes parent folder | download
1
2
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
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2021 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See https://swift.org/LICENSE.txt for license information
 See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

import Foundation

extension String {
    
    /// Returns an FNV1 hashed value of the string.
    internal func fnv1() -> UInt32 {
        
        // Magic number for FNV hashing.
        let prime: UInt32 = 16777619
        
        // Start with the FNV-1 init value and keep hashing into it;
        // the hash value will overflow.
        return utf8.reduce(2166136261) { (hash, byte) -> UInt32 in
            var hval = hash &* prime
            hval ^= UInt32(byte)
            return hval
        }
    }
    
    /// FNV-1 hash string, folded to fit 24 bits, and then base36 encoded;
    /// - note: The FNV-1 algorithm is public domain.
    var stableHashString: String {
        let fnv = fnv1()
        // Fold to 24 bits and encode in base 36.
        return String((fnv >> 24) ^ (fnv & 0xffffff), radix: 36, uppercase: false)
    }
}