summaryrefslogtreecommitdiff
path: root/util/mongoutils/hash.h
blob: 0a87a2a52ba65fa886ad6928f47cda3512258028 (plain)
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
38
39
40
41
/** @file hash.h */

/*    Copyright 2009 10gen Inc.
 *
 *    Licensed under the Apache License, Version 2.0 (the "License");
 *    you may not use this file except in compliance with the License.
 *    You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 *    Unless required by applicable law or agreed to in writing, software
 *    distributed under the License is distributed on an "AS IS" BASIS,
 *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *    See the License for the specific language governing permissions and
 *    limitations under the License.
 */

#pragma once

namespace mongoutils {

    /** @return hash of a pointer to an unsigned. so you get a 32 bit hash out, regardless of whether 
                pointers are 32 or 64 bit on the particular platform.

        is there a faster way to impl this that hashes just as well?
    */
    inline unsigned hashPointer(void *v) {
        unsigned x = 0;
        unsigned char *p = (unsigned char *) &v;
        for( unsigned i = 0; i < sizeof(void*); i++ ) {
            x = x * 131 + p[i];
        }
        return x;
    }

    inline unsigned hash(unsigned u) {
        unsigned char *p = (unsigned char *) &u;
        return (((((p[3] * 131) + p[2]) * 131) + p[1]) * 131) + p[0];
    }

}