From 3ce6dd6cbc777e3b8cccdf1118e81cc21a9592ff Mon Sep 17 00:00:00 2001 From: Nick Treleaven Date: Tue, 4 Aug 2020 19:09:58 +0100 Subject: [PATCH] hash: use match expression with ranges (#6046) --- vlib/hash/wyhash.v | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/vlib/hash/wyhash.v b/vlib/hash/wyhash.v index 4ca53e780f..46b18b76b0 100644 --- a/vlib/hash/wyhash.v +++ b/vlib/hash/wyhash.v @@ -51,26 +51,26 @@ fn wyhash64(key byteptr, len, seed_ u64) u64 { mut p := key mut seed := seed_ mut i := len & 63 - unsafe { - if i < 4 { - seed = wymum(wyr3(p, i) ^ seed ^ wyp0, seed ^ wyp1) + seed = unsafe{match i { + 0...3 { + wymum(wyr3(p, i) ^ seed ^ wyp0, seed ^ wyp1) } - else if i <= 8 { - seed = wymum(wyr4(p) ^ seed ^ wyp0, wyr4(p + i - 4) ^ seed ^ wyp1) + 4...8 { + wymum(wyr4(p) ^ seed ^ wyp0, wyr4(p + i - 4) ^ seed ^ wyp1) } - else if i <= 16 { - seed = wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + i - 8) ^ seed ^ wyp1) + 9...16 { + wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + i - 8) ^ seed ^ wyp1) } - else if i <= 24 { - seed = wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + 8) ^ seed ^ wyp1) ^ wymum(wyr8(p + i - 8) ^ seed ^ wyp2, seed ^ wyp3) + 17...24 { + wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + 8) ^ seed ^ wyp1) ^ wymum(wyr8(p + i - 8) ^ seed ^ wyp2, seed ^ wyp3) } - else if i <= 32 { - seed = wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + 8) ^ seed ^ wyp1) ^ wymum(wyr8(p + 16) ^ seed ^ wyp2, wyr8(p + i - 8) ^ seed ^ wyp3) + 25...32 { + wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + 8) ^ seed ^ wyp1) ^ wymum(wyr8(p + 16) ^ seed ^ wyp2, wyr8(p + i - 8) ^ seed ^ wyp3) } else { - seed = wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + 8) ^ seed ^ wyp1) ^ wymum(wyr8(p + 16) ^ seed ^ wyp2, wyr8(p + 24) ^ seed ^ wyp3) ^ wymum(wyr8(p + i - 32) ^ seed ^ wyp1, wyr8(p + i - 24) ^ seed ^ wyp2) ^ wymum(wyr8(p + i - 16) ^ seed ^ wyp3, wyr8(p + i - 8) ^ seed ^ wyp0) + wymum(wyr8(p) ^ seed ^ wyp0, wyr8(p + 8) ^ seed ^ wyp1) ^ wymum(wyr8(p + 16) ^ seed ^ wyp2, wyr8(p + 24) ^ seed ^ wyp3) ^ wymum(wyr8(p + i - 32) ^ seed ^ wyp1, wyr8(p + i - 24) ^ seed ^ wyp2) ^ wymum(wyr8(p + i - 16) ^ seed ^ wyp3, wyr8(p + i - 8) ^ seed ^ wyp0) } - } + }} if i == len { return wymum(seed, len ^ wyp4) }