diff options
-rw-r--r-- | src/java/com/healthmarketscience/jackcess/PageChannel.java | 4 | ||||
-rw-r--r-- | test/src/java/com/healthmarketscience/jackcess/CodecHandlerTest.java | 2 |
2 files changed, 5 insertions, 1 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/PageChannel.java b/src/java/com/healthmarketscience/jackcess/PageChannel.java index 8759fcf..ae30ba7 100644 --- a/src/java/com/healthmarketscience/jackcess/PageChannel.java +++ b/src/java/com/healthmarketscience/jackcess/PageChannel.java @@ -243,10 +243,12 @@ public class PageChannel implements Channel, Flushable { // re-encode page encodedPage = _codecHandler.encodePage(page, pageNumber, pageOffset); + + // reset position/limit in case they were affected by encoding + encodedPage.position(pageOffset).limit(pageOffset + writeLen); } try { - encodedPage.position(pageOffset); _channel.write(encodedPage, (getPageOffset(pageNumber) + pageOffset)); if(_autoSync) { flush(); diff --git a/test/src/java/com/healthmarketscience/jackcess/CodecHandlerTest.java b/test/src/java/com/healthmarketscience/jackcess/CodecHandlerTest.java index 119a6e3..c525efa 100644 --- a/test/src/java/com/healthmarketscience/jackcess/CodecHandlerTest.java +++ b/test/src/java/com/healthmarketscience/jackcess/CodecHandlerTest.java @@ -235,6 +235,7 @@ public class CodecHandlerTest extends TestCase throws IOException { ByteBuffer bb = _bufH.getPageBuffer(_channel); + bb.clear(); simpleEncode(page.array(), bb.array(), pageNumber, pageOffset, page.limit()); return bb; @@ -268,6 +269,7 @@ public class CodecHandlerTest extends TestCase assertEquals(_channel.getFormat().PAGE_SIZE, page.limit()); ByteBuffer bb = _bufH.getPageBuffer(_channel); + bb.clear(); fullEncode(page.array(), bb.array(), pageNumber); return bb; } |