summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/com/healthmarketscience/jackcess/PageChannel.java4
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/CodecHandlerTest.java2
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;
}