mirror of
https://github.com/kwsch/PKHeX
synced 2025-01-08 02:28:47 +00:00
7cfdb8a466
Fixes #3455 by adding bool for insular sea, and adjusting overall progress values as listed. Closes #3456 (supersedes) Updates SCBlockAccessor to eliminate bounds check (integer overflow, which isn't possible with our array size), adds some overloads, and xmldoc. Co-Authored-By: Jonathan Herbert <3344332+foohyfooh@users.noreply.github.com>
45 lines
1.3 KiB
C#
45 lines
1.3 KiB
C#
using System;
|
||
|
||
namespace PKHeX.Core;
|
||
|
||
/// <summary>
|
||
/// Fowler–Noll–Vo non-cryptographic hash
|
||
/// </summary>
|
||
/// <remarks>https://en.wikipedia.org/wiki/Fowler%E2%80%93Noll%E2%80%93Vo_hash_function</remarks>
|
||
public static class FnvHash
|
||
{
|
||
private const ulong kFnvPrime_64 = 0x00000100000001b3;
|
||
private const ulong kOffsetBasis_64 = 0xCBF29CE484222645;
|
||
|
||
/// <summary>
|
||
/// Gets the hash code of the input sequence via the alternative Fnv1 method.
|
||
/// </summary>
|
||
/// <param name="input">Input sequence</param>
|
||
/// <param name="hash">Initial hash value</param>
|
||
/// <returns>Computed hash code</returns>
|
||
public static ulong HashFnv1a_64(ReadOnlySpan<char> input, ulong hash = kOffsetBasis_64)
|
||
{
|
||
foreach (var c in input)
|
||
{
|
||
hash ^= c;
|
||
hash *= kFnvPrime_64;
|
||
}
|
||
return hash;
|
||
}
|
||
|
||
/// <summary>
|
||
/// Gets the hash code of the input sequence via the alternative Fnv1 method.
|
||
/// </summary>
|
||
/// <param name="input">Input sequence</param>
|
||
/// <param name="hash">Initial hash value</param>
|
||
/// <returns>Computed hash code</returns>
|
||
public static ulong HashFnv1a_64(ReadOnlySpan<byte> input, ulong hash = kOffsetBasis_64)
|
||
{
|
||
foreach (var c in input)
|
||
{
|
||
hash ^= c;
|
||
hash *= kFnvPrime_64;
|
||
}
|
||
return hash;
|
||
}
|
||
}
|