Passed
Push — main ( e49f5b...ddf3a0 )
by Eric
04:22
created

Murmur3Hasher   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 15
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 2
dl 0
loc 15
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
wmc 1

1 Method

Rating   Name   Duplication   Size   Complexity  
A hash() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * This file is part of Esi\ConsistentHash.
7
 *
8
 * (c) Eric Sizemore <[email protected]>
9
 * (c) Paul Annesley <[email protected]>
10
 *
11
 * This source file is subject to the MIT license. For the full copyright and
12
 * license information, please view the LICENSE file that was distributed with
13
 * this source code.
14
 */
15
16
namespace Esi\ConsistentHash\Hasher;
17
18
/**
19
 * Uses MurmurHash3 to hash a value into a 32bit int.
20
 *
21
 * Note: specifically uses the 'murmur3a' algo in PHP's hash().
22
 *
23
 * @todo Look into murmur3c (128-bit hash on x86 architecture) and murmur3f (128-bit hash on x64 architecture)
24
 *
25
 * @see https://github.com/aappleby/smhasher
26
 */
27
class Murmur3Hasher implements HasherInterface
28
{
29
    /**
30
     * {@inheritDoc}
31
     *
32
     * 8 hexits = 32bit, which also allows us to forego having to check whether
33
     * it is over PHP_INT_MAX.
34
     *
35
     * The substring is converted to an int since hex strings sometimes get
36
     * treated as ints if all digits are ints and this results in unexpected
37
     * sorting order.
38
     */
39 2
    public function hash(string $string): int
40
    {
41 2
        return (int) hexdec(substr(hash('murmur3a', $string), 0, 8));
42
    }
43
}
44