Objectively
Ultra-lightweight object oriented framework for GNU C.
Loading...
Searching...
No Matches
Hash.c
Go to the documentation of this file.
1/*
2 * Objectively: Ultra-lightweight object oriented framework for GNU C.
3 * Copyright (C) 2014 Jay Dolan <jay@jaydolan.com>
4 *
5 * This software is provided 'as-is', without any express or implied
6 * warranty. In no event will the authors be held liable for any damages
7 * arising from the use of this software.
8 *
9 * Permission is granted to anyone to use this software for any purpose,
10 * including commercial applications, and to alter it and redistribute it
11 * freely, subject to the following restrictions:
12 *
13 * 1. The origin of this software must not be misrepresented; you must not
14 * claim that you wrote the original software. If you use this software
15 * in a product, an acknowledgment in the product documentation would be
16 * appreciated but is not required.
17 *
18 * 2. Altered source versions must be plainly marked as such, and must not be
19 * misrepresented as being the original software.
20 *
21 * 3. This notice may not be removed or altered from any source distribution.
22 */
23
24#include <string.h>
25
26#include "Hash.h"
27
28int HashForBytes(int hash, const uint8_t *bytes, const Range range) {
29
30 unsigned int uhash = (unsigned int) hash;
31
32 for (size_t i = range.location; i < range.location + range.length; i++) {
33
34 int shift;
35 if (i & 1) {
36 shift = 16 + (i % 16);
37 } else {
38 shift = (i % 16);
39 }
40
41 uhash += 31U * ((unsigned int) bytes[i]) << shift;
42 }
43
44 return (int) uhash;
45}
46
47int HashForCharacters(int hash, const char *chars, const Range range) {
48 return HashForBytes(hash, (const uint8_t *) chars, range);
49}
50
51int HashForCString(int hash, const char *string) {
52
53 if (string) {
54 return HashForCharacters(hash, string, (Range) { 0, strlen(string) });
55 }
56
57 return 0;
58}
59
60int HashForDecimal(int hash, const double decimal) {
61 unsigned int uhash = (unsigned int) hash;
62 uhash += 31U * (unsigned int) decimal;
63 return (int) uhash;
64}
65
66int HashForInteger(int hash, const long integer) {
67 unsigned int uhash = (unsigned int) hash;
68 uhash += 31U * (unsigned int) integer;
69 return (int) uhash;
70}
71
72int HashForObject(int hash, const ident obj) {
73
74 if (obj) {
75 unsigned int uhash = (unsigned int) hash;
76 uhash += 31U * (unsigned int) $(cast(Object, obj), hash);
77 return (int) uhash;
78 }
79
80 return 0;
81}
static int hash(const Object *self)
Definition Array.c:129
#define obj
#define cast(type, obj)
Safely cast obj to type.
Definition Class.h:182
int HashForInteger(int hash, const long integer)
Accumulates the hash value of integer into hash.
Definition Hash.c:66
int HashForObject(int hash, const ident obj)
Accumulates the hash value of object into hash.
Definition Hash.c:72
int HashForCString(int hash, const char *string)
Accumulates the hash value of the null-terminated string into hash.
Definition Hash.c:51
int HashForDecimal(int hash, const double decimal)
Accumulates the hash value of decimal into hash.
Definition Hash.c:60
int HashForBytes(int hash, const uint8_t *bytes, const Range range)
Accumulates the hash value of bytes into hash.
Definition Hash.c:28
int HashForCharacters(int hash, const char *chars, const Range range)
Accumulates the hash value of chars into hash.
Definition Hash.c:47
Utilities for calculating hash values.
UTF-8 strings.
void * ident
The identity type, similar to Objective-C id.
Definition Types.h:49
Object is the root Class of The Objectively Class hierarchy.
Definition Object.h:46
A location and length into contiguous collections.
Definition Types.h:54
ssize_t location
The location.
Definition Types.h:59
size_t length
The length.
Definition Types.h:64