summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/changes/changes.xml6
-rw-r--r--src/java/com/healthmarketscience/jackcess/Column.java6
-rw-r--r--src/java/com/healthmarketscience/jackcess/JetFormat.java5
3 files changed, 13 insertions, 4 deletions
diff --git a/src/changes/changes.xml b/src/changes/changes.xml
index bff2c96..7f3d746 100644
--- a/src/changes/changes.xml
+++ b/src/changes/changes.xml
@@ -5,6 +5,12 @@
<author email="jahlborn@users.sf.net">James Ahlborn</author>
</properties>
<body>
+ <release version="1.1.15" date="TBD">
+ <action dev="jahlborn" type="fix" issue="1998225">
+ Fix writing of large memo/ole fields. Apparently Access does not like
+ long value fields longer than 4076 bytes.
+ </action>
+ </release>
<release version="1.1.14" date="2008-04-29">
<action dev="jahlborn" type="fix" issue="1924705">
Need to store auto-number values back into row so that indexes can be
diff --git a/src/java/com/healthmarketscience/jackcess/Column.java b/src/java/com/healthmarketscience/jackcess/Column.java
index dde0985..5987ae3 100644
--- a/src/java/com/healthmarketscience/jackcess/Column.java
+++ b/src/java/com/healthmarketscience/jackcess/Column.java
@@ -754,9 +754,7 @@ public class Column implements Comparable<Column> {
&& (value.length <= getFormat().MAX_INLINE_LONG_VALUE_SIZE)) {
type = LONG_VALUE_TYPE_THIS_PAGE;
lvalDefLen += value.length;
- } else if(Table.getRowSpaceUsage(value.length, getFormat()) <=
- getFormat().MAX_ROW_SIZE)
- {
+ } else if(value.length <= getFormat().MAX_LONG_VALUE_ROW_SIZE) {
type = LONG_VALUE_TYPE_OTHER_PAGE;
} else {
type = LONG_VALUE_TYPE_OTHER_PAGES;
@@ -802,7 +800,7 @@ public class Column implements Comparable<Column> {
writeLongValueHeader(lvalPage);
// figure out how much we will put in this page
- int chunkLength = Math.min(getFormat().MAX_ROW_SIZE - 4,
+ int chunkLength = Math.min(getFormat().MAX_LONG_VALUE_ROW_SIZE - 4,
remainingLen);
nextLvalPageNum = ((chunkLength < remainingLen) ?
getPageChannel().allocateNewPage() : 0);
diff --git a/src/java/com/healthmarketscience/jackcess/JetFormat.java b/src/java/com/healthmarketscience/jackcess/JetFormat.java
index b8b7fea..0b2b994 100644
--- a/src/java/com/healthmarketscience/jackcess/JetFormat.java
+++ b/src/java/com/healthmarketscience/jackcess/JetFormat.java
@@ -115,6 +115,7 @@ public abstract class JetFormat {
public final int SIZE_ROW_LOCATION;
public final int SIZE_LONG_VALUE_DEF;
public final int MAX_INLINE_LONG_VALUE_SIZE;
+ public final int MAX_LONG_VALUE_ROW_SIZE;
public final int SIZE_TDEF_HEADER;
public final int SIZE_TDEF_TRAILER;
public final int SIZE_COLUMN_DEF_BLOCK;
@@ -200,6 +201,7 @@ public abstract class JetFormat {
SIZE_ROW_LOCATION = defineSizeRowLocation();
SIZE_LONG_VALUE_DEF = defineSizeLongValueDef();
MAX_INLINE_LONG_VALUE_SIZE = defineMaxInlineLongValueSize();
+ MAX_LONG_VALUE_ROW_SIZE = defineMaxLongValueRowSize();
SIZE_TDEF_HEADER = defineSizeTdefHeader();
SIZE_TDEF_TRAILER = defineSizeTdefTrailer();
SIZE_COLUMN_DEF_BLOCK = defineSizeColumnDefBlock();
@@ -264,6 +266,7 @@ public abstract class JetFormat {
protected abstract int defineSizeRowLocation();
protected abstract int defineSizeLongValueDef();
protected abstract int defineMaxInlineLongValueSize();
+ protected abstract int defineMaxLongValueRowSize();
protected abstract int defineSizeTdefHeader();
protected abstract int defineSizeTdefTrailer();
protected abstract int defineSizeColumnDefBlock();
@@ -385,6 +388,8 @@ public abstract class JetFormat {
@Override
protected int defineMaxInlineLongValueSize() { return 64; }
@Override
+ protected int defineMaxLongValueRowSize() { return 4076; }
+ @Override
protected int defineSizeTdefHeader() { return 63; }
@Override
protected int defineSizeTdefTrailer() { return 2; }