dartlangeditorflutterflutter-appsflutter-examplesflutter-packageflutter-widgetquillquill-deltaquilljsreactquillrich-textrich-text-editorwysiwygwysiwyg-editor
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
31 lines
995 B
31 lines
995 B
4 years ago
|
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));
|
||
|
}
|