Skip to content

Commit

Permalink
support multiple byteWidth in writeLongToArrowBuf()
Browse files Browse the repository at this point in the history
  • Loading branch information
kiszk committed Nov 3, 2020
1 parent 0d696fa commit aa14a87
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 16 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -364,7 +364,7 @@ public void set(int index, BigDecimal value) {
*/
public void set(int index, long value) {
BitVectorHelper.setBit(validityBuffer, index);
DecimalUtility.writeLongToArrowBuf(value, valueBuffer, index);
DecimalUtility.writeLongToArrowBuf(value, valueBuffer, index, TYPE_WIDTH);
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -132,17 +132,25 @@ public static void writeBigDecimalToArrowBuf(BigDecimal value, ArrowBuf bytebuf,

/**
* Write the given long to the ArrowBuf at the given value index.
* This routine extends the original sign bit to a new upper 64-bit in 128-bit.
* This routine extends the original sign bit to a new upper area in 128-bit or 256-bit.
*/
public static void writeLongToArrowBuf(long value, ArrowBuf bytebuf, int index) {
public static void writeLongToArrowBuf(long value, ArrowBuf bytebuf, int index, int byteWidth) {
if (byteWidth != 16 && byteWidth != 32) {
throw new UnsupportedOperationException("DeciimalUtility.writeLongToArrowBuf() currently supports " +
"128-bit or 256-bit width data");
}
final long addressOfValue = bytebuf.memoryAddress() + (long) index * DECIMAL_BYTE_LENGTH;
final long padValue = Long.signum(value) == -1 ? -1L : 0L;
if (LITTLE_ENDIAN) {
PlatformDependent.putLong(addressOfValue, value);
PlatformDependent.putLong(addressOfValue + Long.BYTES, padValue);
for (int i = 1; i <= (byteWidth - 8) / 8; i++) {
PlatformDependent.putLong(addressOfValue + Long.BYTES * i, padValue);
}
} else {
PlatformDependent.putLong(addressOfValue, padValue);
PlatformDependent.putLong(addressOfValue + Long.BYTES, value);
for (int i = 0; i < (byteWidth - 8) / 8; i++) {
PlatformDependent.putLong(addressOfValue + Long.BYTES * i, padValue);
}
PlatformDependent.putLong(addressOfValue + Long.BYTES * (byteWidth - 8) / 8, value);
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,16 +34,19 @@ public class DecimalUtilityTest {

@Test
public void testSetLongInDecimalArrowBuf() {
try (BufferAllocator allocator = new RootAllocator(128);
ArrowBuf buf = allocator.buffer(16);
) {
int [] intValues = new int [] {Integer.MAX_VALUE, Integer.MIN_VALUE, 0};
for (int val : intValues) {
buf.clear();
DecimalUtility.writeLongToArrowBuf((long) val, buf, 0);
BigDecimal actual = DecimalUtility.getBigDecimalFromArrowBuf(buf, 0, 0);
BigDecimal expected = BigDecimal.valueOf(val);
Assert.assertEquals(expected, actual);
int[] byteLengths = new int[]{16, 32};
for (int x = 0; x < 2; x++) {
try (BufferAllocator allocator = new RootAllocator(128);
ArrowBuf buf = allocator.buffer(byteLengths[x]);
) {
int [] intValues = new int [] {Integer.MAX_VALUE, Integer.MIN_VALUE, 0};
for (int val : intValues) {
buf.clear();
DecimalUtility.writeLongToArrowBuf((long) val, buf, 0, byteLengths[x]);
BigDecimal actual = DecimalUtility.getBigDecimalFromArrowBuf(buf, 0, 0, byteLengths[x]);
BigDecimal expected = BigDecimal.valueOf(val);
Assert.assertEquals(expected, actual);
}
}
}
}
Expand Down

0 comments on commit aa14a87

Please sign in to comment.