Use bit shifts rather than multiplication in block position encoding
This commit is contained in:
parent
54ffe2e5de
commit
a2003b0d55
@ -32,9 +32,9 @@ static inline s16 unsigned_to_signed(u16 i, u16 max_positive)
|
|||||||
|
|
||||||
s64 Database::getBlockAsInteger(const v3s16 pos) const
|
s64 Database::getBlockAsInteger(const v3s16 pos) const
|
||||||
{
|
{
|
||||||
return (u64) pos.Z * 0x1000000 +
|
return (((u64) pos.Z) << 24) +
|
||||||
(u64) pos.Y * 0x1000 +
|
(((u64) pos.Y) << 12) +
|
||||||
(u64) pos.X;
|
((u64) pos.X);
|
||||||
}
|
}
|
||||||
|
|
||||||
v3s16 Database::getIntegerAsBlock(const s64 i) const
|
v3s16 Database::getIntegerAsBlock(const s64 i) const
|
||||||
|
Loading…
x
Reference in New Issue
Block a user