Objectively 1.0.0
Ultra-lightweight object oriented framework for GNU C.
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
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 for (size_t i = range.location; i < range.length; i++) {
31
32 int shift;
33 if (i & 1) {
34 shift = 16 + (i % 16);
35 } else {
36 shift = (i % 16);
37 }
38
39 hash += 31 * ((int) bytes[i]) << shift;
40 }
41
42 return hash;
43}
44
45int HashForCharacters(int hash, const char *chars, const Range range) {
46 return HashForBytes(hash, (const uint8_t *) chars, range);
47}
48
49int HashForCString(int hash, const char *string) {
50
51 if (string) {
52 return HashForCharacters(hash, string, (Range) { 0, strlen(string) });
53 }
54
55 return 0;
56}
57
58int HashForDecimal(int hash, const double decimal) {
59 return hash + 31 * (int) decimal;
60}
61
62int HashForInteger(int hash, const long integer) {
63 return hash + 31 * (int) integer;
64}
65
66int HashForObject(int hash, const ident obj) {
67
68 if (obj) {
69 return hash + 31 * $(cast(Object, obj), hash);
70 }
71
72 return 0;
73}
#define obj
#define cast(type, obj)
Safely cast obj to type.
Definition: Class.h:165
int HashForInteger(int hash, const long integer)
Accumulates the hash value of integer into hash.
Definition: Hash.c:62
int HashForObject(int hash, const ident obj)
Accumulates the hash value of object into hash.
Definition: Hash.c:66
int HashForCString(int hash, const char *string)
Accumulates the hash value of the null-terminated string into hash.
Definition: Hash.c:49
int HashForDecimal(int hash, const double decimal)
Accumulates the hash value of decimal into hash.
Definition: Hash.c:58
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:45
Utilities for calculating hash values.
Immutable 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
int hash(const Object *self)
Definition: Array.c:80
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