Maintenance was done long time ago hence no need to wait for the updatepull/87/head
parent
e9c5a2238e
commit
be56739a53
6 changed files with 42 additions and 18 deletions
@ -0,0 +1,31 @@ |
||||
library quiver.hashcode; |
||||
|
||||
/// Generates a hash code for multiple [objects]. |
||||
int hashObjects(Iterable objects) => |
||||
_finish(objects.fold(0, (h, i) => _combine(h, i.hashCode))); |
||||
|
||||
/// Generates a hash code for two objects. |
||||
int hash2(a, b) => _finish(_combine(_combine(0, a.hashCode), b.hashCode)); |
||||
|
||||
/// Generates a hash code for three objects. |
||||
int hash3(a, b, c) => _finish( |
||||
_combine(_combine(_combine(0, a.hashCode), b.hashCode), c.hashCode)); |
||||
|
||||
/// Generates a hash code for four objects. |
||||
int hash4(a, b, c, d) => _finish(_combine( |
||||
_combine(_combine(_combine(0, a.hashCode), b.hashCode), c.hashCode), |
||||
d.hashCode)); |
||||
|
||||
// Jenkins hash functions |
||||
|
||||
int _combine(int hash, int value) { |
||||
hash = 0x1fffffff & (hash + value); |
||||
hash = 0x1fffffff & (hash + ((0x0007ffff & hash) << 10)); |
||||
return hash ^ (hash >> 6); |
||||
} |
||||
|
||||
int _finish(int hash) { |
||||
hash = 0x1fffffff & (hash + ((0x03ffffff & hash) << 3)); |
||||
hash = hash ^ (hash >> 11); |
||||
return 0x1fffffff & (hash + ((0x00003fff & hash) << 15)); |
||||
} |
Loading…
Reference in new issue