diff options
-rw-r--r-- | src/changes/changes.xml | 3 | ||||
-rw-r--r-- | src/java/com/healthmarketscience/jackcess/JetFormat.java | 7 | ||||
-rw-r--r-- | src/java/com/healthmarketscience/jackcess/Table.java | 6 |
3 files changed, 11 insertions, 5 deletions
diff --git a/src/changes/changes.xml b/src/changes/changes.xml index 7f3d746..05b2d62 100644 --- a/src/changes/changes.xml +++ b/src/changes/changes.xml @@ -10,6 +10,9 @@ Fix writing of large memo/ole fields. Apparently Access does not like long value fields longer than 4076 bytes. </action> + <action dev="jahlborn" type="fix"> + Reduce maximum row size to what Access considers valid. + </action> </release> <release version="1.1.14" date="2008-04-29"> <action dev="jahlborn" type="fix" issue="1924705"> diff --git a/src/java/com/healthmarketscience/jackcess/JetFormat.java b/src/java/com/healthmarketscience/jackcess/JetFormat.java index 0b2b994..d0900f1 100644 --- a/src/java/com/healthmarketscience/jackcess/JetFormat.java +++ b/src/java/com/healthmarketscience/jackcess/JetFormat.java @@ -65,6 +65,7 @@ public abstract class JetFormat { public final long MAX_DATABASE_SIZE; public final int MAX_ROW_SIZE; + public final int PAGE_INITIAL_FREE_SPACE; public final int OFFSET_NEXT_TABLE_DEF_PAGE; public final int OFFSET_NUM_ROWS; @@ -151,6 +152,7 @@ public abstract class JetFormat { MAX_DATABASE_SIZE = defineMaxDatabaseSize(); MAX_ROW_SIZE = defineMaxRowSize(); + PAGE_INITIAL_FREE_SPACE = definePageInitialFreeSpace(); OFFSET_NEXT_TABLE_DEF_PAGE = defineOffsetNextTableDefPage(); OFFSET_NUM_ROWS = defineOffsetNumRows(); @@ -216,6 +218,7 @@ public abstract class JetFormat { protected abstract long defineMaxDatabaseSize(); protected abstract int defineMaxRowSize(); + protected abstract int definePageInitialFreeSpace(); protected abstract int defineOffsetNextTableDefPage(); protected abstract int defineOffsetNumRows(); @@ -296,7 +299,9 @@ public abstract class JetFormat { } @Override - protected int defineMaxRowSize() { return PAGE_SIZE - 16; } + protected int defineMaxRowSize() { return 4060; } + @Override + protected int definePageInitialFreeSpace() { return PAGE_SIZE - 14; } @Override protected int defineOffsetNextTableDefPage() { return 4; } diff --git a/src/java/com/healthmarketscience/jackcess/Table.java b/src/java/com/healthmarketscience/jackcess/Table.java index ad6d9ad..c4976ba 100644 --- a/src/java/com/healthmarketscience/jackcess/Table.java +++ b/src/java/com/healthmarketscience/jackcess/Table.java @@ -904,10 +904,9 @@ public class Table PageChannel pageChannel, JetFormat format) throws IOException { - // USAGE_MAP_DEF_FREE_SPACE = 3940; int usageMapRowLength = format.OFFSET_USAGE_MAP_START + format.USAGE_MAP_TABLE_BYTE_LENGTH; - int freeSpace = getRowSpaceUsage(format.MAX_ROW_SIZE, format) + int freeSpace = format.PAGE_INITIAL_FREE_SPACE - (2 * getRowSpaceUsage(usageMapRowLength, format)); ByteBuffer rtn = pageChannel.createPageBuffer(); @@ -1290,8 +1289,7 @@ public class Table ByteBuffer dataPage = _addRowBufferH.setNewPage(getPageChannel()); dataPage.put(PageTypes.DATA); //Page type dataPage.put((byte) 1); //Unknown - dataPage.putShort((short)getRowSpaceUsage(getFormat().MAX_ROW_SIZE, - getFormat())); //Free space in this page + dataPage.putShort((short)getFormat().PAGE_INITIAL_FREE_SPACE); //Free space in this page dataPage.putInt(_tableDefPageNumber); //Page pointer to table definition dataPage.putInt(0); //Unknown dataPage.putShort((short)0); //Number of rows on this page |