From 9ca2a05255024c161c803aa115d9d73bcdacad37 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Guillermo=20D=C3=ADaz?= Date: Tue, 25 Jul 2023 12:21:32 +0200 Subject: [PATCH] fix(libs): reading large float16 values --- contracts/libs/WitnetBuffer.sol | 8 ++++---- test/TestWitnetCBOR.sol | 8 ++++---- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/contracts/libs/WitnetBuffer.sol b/contracts/libs/WitnetBuffer.sol index ba3a8037d..f68ec996e 100644 --- a/contracts/libs/WitnetBuffer.sol +++ b/contracts/libs/WitnetBuffer.sol @@ -235,17 +235,17 @@ library WitnetBuffer { } // Compute `2 ^ exponent ยท (1 + fraction / 1024)` if (exponent >= 0) { - result = int32( + result = int32(int( int(1 << uint256(int256(exponent))) * 10000 * fraction - ) >> 10; + ) >> 10); } else { - result = int32( + result = int32(int( int(fraction) * 10000 / int(1 << uint(int(- exponent))) - ) >> 10; + ) >> 10); } // Make the result negative if the sign bit is not 0 if (sign != 0) { diff --git a/test/TestWitnetCBOR.sol b/test/TestWitnetCBOR.sol index 24fe980c3..5d69e2e53 100644 --- a/test/TestWitnetCBOR.sol +++ b/test/TestWitnetCBOR.sol @@ -4,8 +4,8 @@ pragma solidity >=0.7.0 <0.9.0; pragma experimental ABIEncoderV2; import "truffle/Assert.sol"; +import "../contracts/libs/Witnet.sol"; import "../contracts/libs/WitnetCBOR.sol"; -import "../contracts/libs/WitnetLib.sol"; contract TestWitnetCBOR { @@ -123,7 +123,7 @@ contract TestWitnetCBOR { function testBytes32DecodeValueFrom31bytes() external { bytes memory encoded = hex"581f01020304050607080910111213141516171819202122232425262728293031"; - bytes32 decoded = WitnetLib.toBytes32(WitnetCBOR.readBytes(WitnetCBOR.fromBytes(encoded))); + bytes32 decoded = Witnet.toBytes32(WitnetCBOR.readBytes(WitnetCBOR.fromBytes(encoded))); bytes32 expected = 0x0102030405060708091011121314151617181920212223242526272829303100; Assert.equal( decoded, @@ -134,7 +134,7 @@ contract TestWitnetCBOR { function testBytes32DecodeValueFrom32bytes() external { bytes memory encoded = hex"58200102030405060708091011121314151617181920212223242526272829303132"; - bytes32 decoded = WitnetLib.toBytes32(WitnetCBOR.readBytes(WitnetCBOR.fromBytes(encoded))); + bytes32 decoded = Witnet.toBytes32(WitnetCBOR.readBytes(WitnetCBOR.fromBytes(encoded))); bytes32 expected = 0x0102030405060708091011121314151617181920212223242526272829303132; Assert.equal( decoded, @@ -145,7 +145,7 @@ contract TestWitnetCBOR { function testBytes32DecodeValueFrom33bytes() external { bytes memory encoded = hex"5821010203040506070809101112131415161718192021222324252627282930313233"; - bytes32 decoded = WitnetLib.toBytes32(WitnetCBOR.readBytes(WitnetCBOR.fromBytes(encoded))); + bytes32 decoded = Witnet.toBytes32(WitnetCBOR.readBytes(WitnetCBOR.fromBytes(encoded))); bytes32 expected = 0x0102030405060708091011121314151617181920212223242526272829303132; Assert.equal( decoded,