summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/com/healthmarketscience/jackcess/Column.java14
-rw-r--r--src/java/com/healthmarketscience/jackcess/Database.java8
-rw-r--r--src/java/com/healthmarketscience/jackcess/Index.java43
-rw-r--r--src/java/com/healthmarketscience/jackcess/PageChannel.java3
-rw-r--r--src/java/com/healthmarketscience/jackcess/Table.java26
-rw-r--r--src/java/com/healthmarketscience/jackcess/UsageMap.java10
6 files changed, 44 insertions, 60 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/Column.java b/src/java/com/healthmarketscience/jackcess/Column.java
index 899ba2d..cef17cc 100644
--- a/src/java/com/healthmarketscience/jackcess/Column.java
+++ b/src/java/com/healthmarketscience/jackcess/Column.java
@@ -36,7 +36,6 @@ import java.nio.CharBuffer;
import java.sql.SQLException;
import java.util.Calendar;
import java.util.Date;
-import java.util.Iterator;
import java.util.List;
import java.util.TimeZone;
import java.util.regex.Matcher;
@@ -120,6 +119,9 @@ public class Column implements Comparable<Column> {
* Only used by unit tests
*/
Column(boolean testing) {
+ if(!testing) {
+ throw new IllegalArgumentException();
+ }
_format = JetFormat.VERSION_4;
_pageChannel = new PageChannel(testing);
}
@@ -337,15 +339,15 @@ public class Column implements Comparable<Column> {
if (_type == DataType.BOOLEAN) {
throw new IOException("Tried to read a boolean from data instead of null mask.");
} else if (_type == DataType.BYTE) {
- return new Byte(buffer.get());
+ return Byte.valueOf(buffer.get());
} else if (_type == DataType.INT) {
- return new Short(buffer.getShort());
+ return Short.valueOf(buffer.getShort());
} else if (_type == DataType.LONG) {
- return new Integer(buffer.getInt());
+ return Integer.valueOf(buffer.getInt());
} else if (_type == DataType.DOUBLE) {
- return new Double(buffer.getDouble());
+ return Double.valueOf(buffer.getDouble());
} else if (_type == DataType.FLOAT) {
- return new Float(buffer.getFloat());
+ return Float.valueOf(buffer.getFloat());
} else if (_type == DataType.SHORT_DATE_TIME) {
return readDateValue(buffer);
} else if (_type == DataType.BINARY) {
diff --git a/src/java/com/healthmarketscience/jackcess/Database.java b/src/java/com/healthmarketscience/jackcess/Database.java
index 450d51a..58dc6fe 100644
--- a/src/java/com/healthmarketscience/jackcess/Database.java
+++ b/src/java/com/healthmarketscience/jackcess/Database.java
@@ -427,7 +427,7 @@ public class Database
_format);
//Add this table to our internal list.
- addTable(name, new Integer(tdefPageNumber));
+ addTable(name, Integer.valueOf(tdefPageNumber));
//Add this table to system tables
addToSystemCatalog(name, tdefPageNumber);
@@ -446,7 +446,7 @@ public class Database
for (iter = _systemCatalog.getColumns().iterator(); iter.hasNext(); idx++) {
Column col = (Column) iter.next();
if (COL_ID.equals(col.getName())) {
- catalogRow[idx] = new Integer(pageNumber);
+ catalogRow[idx] = Integer.valueOf(pageNumber);
} else if (COL_NAME.equals(col.getName())) {
catalogRow[idx] = name;
} else if (COL_TYPE.equals(col.getName())) {
@@ -458,7 +458,7 @@ public class Database
} else if (COL_PARENT_ID.equals(col.getName())) {
catalogRow[idx] = _tableParentId;
} else if (COL_FLAGS.equals(col.getName())) {
- catalogRow[idx] = new Integer(0);
+ catalogRow[idx] = Integer.valueOf(0);
} else if (COL_OWNER.equals(col.getName())) {
byte[] owner = new byte[2];
catalogRow[idx] = owner;
@@ -484,7 +484,7 @@ public class Database
} else if (col.getName().equals(COL_F_INHERITABLE)) {
aceRow[idx] = Boolean.FALSE;
} else if (col.getName().equals(COL_OBJECT_ID)) {
- aceRow[idx] = new Integer(pageNumber);
+ aceRow[idx] = Integer.valueOf(pageNumber);
} else if (col.getName().equals(COL_SID)) {
aceRow[idx] = SID;
}
diff --git a/src/java/com/healthmarketscience/jackcess/Index.java b/src/java/com/healthmarketscience/jackcess/Index.java
index 9512a4e..0cd6689 100644
--- a/src/java/com/healthmarketscience/jackcess/Index.java
+++ b/src/java/com/healthmarketscience/jackcess/Index.java
@@ -57,10 +57,6 @@ public class Index implements Comparable<Index> {
private static final short COLUMN_UNUSED = -1;
- private static final int NEW_ENTRY_COLUMN_INDEX = -1;
-
- private static final byte REVERSE_ORDER_FLAG = (byte)0x01;
-
private static final byte INDEX_NODE_PAGE_TYPE = (byte)0x03;
private static final byte INDEX_LEAF_PAGE_TYPE = (byte)0x04;
@@ -222,6 +218,10 @@ public class Index implements Comparable<Index> {
_rowCount = rowCount;
}
+ public int getRowCount() {
+ return _rowCount;
+ }
+
/**
* Note, there may still be some issues around the name of an index, this
* information may not be correct. I've done a variety of testing comparing
@@ -349,7 +349,7 @@ public class Index implements Comparable<Index> {
{
for (int i = 0; i < MAX_COLUMNS; i++) {
short columnNumber = tableBuffer.getShort();
- Byte flags = new Byte(tableBuffer.get());
+ Byte flags = Byte.valueOf(tableBuffer.get());
if (columnNumber != COLUMN_UNUSED) {
_columns.put(availableColumns.get(columnNumber), flags);
}
@@ -472,9 +472,9 @@ public class Index implements Comparable<Index> {
int length = i * 8 + j - lastStart;
indexPage.position(entryPos + lastStart);
if(isLeaf) {
- entries.add(new Entry(indexPage, length, valuePrefix));
+ entries.add(new Entry(indexPage, valuePrefix));
} else {
- nodeEntries.add(new NodeEntry(indexPage, length, valuePrefix));
+ nodeEntries.add(new NodeEntry(indexPage, valuePrefix));
}
// read any shared "compressed" bytes
@@ -553,10 +553,11 @@ public class Index implements Comparable<Index> {
(col.getType() == DataType.MEMO));
}
- private static boolean isFloatingPointColumn(Column col) {
- return((col.getType() == DataType.FLOAT) ||
- (col.getType() == DataType.DOUBLE));
- }
+ // FIXME
+// private static boolean isFloatingPointColumn(Column col) {
+// return((col.getType() == DataType.FLOAT) ||
+// (col.getType() == DataType.DOUBLE));
+// }
/**
* Converts an index value for a fixed column into the index bytes
@@ -576,10 +577,10 @@ public class Index implements Comparable<Index> {
// Column column = entryCol._column;
// // if (value instanceof Integer) {
-// // value = new Integer((int) (((Integer) value).longValue() -
+// // value = Integer.valueOf((int) (((Integer) value).longValue() -
// // ((long) Integer.MAX_VALUE + 1L)));
// // } else if (value instanceof Short) {
-// // value = new Short((short) (((Short) value).longValue() -
+// // value = Short.valueOf((short) (((Short) value).longValue() -
// // ((long) Integer.MAX_VALUE + 1L)));
// // }
@@ -694,7 +695,7 @@ public class Index implements Comparable<Index> {
/**
* Read an existing entry in from a buffer
*/
- public Entry(ByteBuffer buffer, int length, byte[] valuePrefix)
+ public Entry(ByteBuffer buffer, byte[] valuePrefix)
throws IOException
{
for(Map.Entry<Column, Byte> entry : _columns.entrySet()) {
@@ -886,8 +887,6 @@ public class Index implements Comparable<Index> {
// FIXME, reverse is 0x80, reverse null is 0xFF
if (flag != (byte) 0) {
byte[] data = new byte[_column.getType().getFixedSize()];
- int numPrefixBytes = ((valuePrefix == null) ? 0 :
- (valuePrefix.length - 1));
int dataOffset = 0;
if((valuePrefix != null) && (valuePrefix.length > 1)) {
System.arraycopy(valuePrefix, 1, data, 0,
@@ -899,10 +898,10 @@ public class Index implements Comparable<Index> {
//ints and shorts are stored in index as value + 2147483648
if (_value instanceof Integer) {
- _value = new Integer((int) (((Integer) _value).longValue() +
+ _value = Integer.valueOf((int) (((Integer) _value).longValue() +
(long) Integer.MAX_VALUE + 1L));
} else if (_value instanceof Short) {
- _value = new Short((short) (((Short) _value).longValue() +
+ _value = Short.valueOf((short) (((Short) _value).longValue() +
(long) Integer.MAX_VALUE + 1L));
}
}
@@ -923,10 +922,10 @@ public class Index implements Comparable<Index> {
buffer.put((byte) 0x7F);
Comparable value = _value;
if (value instanceof Integer) {
- value = new Integer((int) (((Integer) value).longValue() -
+ value = Integer.valueOf((int) (((Integer) value).longValue() -
((long) Integer.MAX_VALUE + 1L)));
} else if (value instanceof Short) {
- value = new Short((short) (((Short) value).longValue() -
+ value = Short.valueOf((short) (((Short) value).longValue() -
((long) Integer.MAX_VALUE + 1L)));
}
buffer.put(_column.write(value, 0, ByteOrder.BIG_ENDIAN));
@@ -1114,10 +1113,10 @@ public class Index implements Comparable<Index> {
/**
* Read an existing node entry in from a buffer
*/
- public NodeEntry(ByteBuffer buffer, int length, byte[] valuePrefix)
+ public NodeEntry(ByteBuffer buffer, byte[] valuePrefix)
throws IOException
{
- super(buffer, length, valuePrefix);
+ super(buffer, valuePrefix);
_subPageNumber = ByteUtil.getInt(buffer, ByteOrder.BIG_ENDIAN);
}
diff --git a/src/java/com/healthmarketscience/jackcess/PageChannel.java b/src/java/com/healthmarketscience/jackcess/PageChannel.java
index dcd31a6..0c823c8 100644
--- a/src/java/com/healthmarketscience/jackcess/PageChannel.java
+++ b/src/java/com/healthmarketscience/jackcess/PageChannel.java
@@ -85,6 +85,9 @@ public class PageChannel implements Channel, Flushable {
* Only used by unit tests
*/
PageChannel(boolean testing) {
+ if(!testing) {
+ throw new IllegalArgumentException();
+ }
_channel = null;
_format = JetFormat.VERSION_4;
_autoSync = false;
diff --git a/src/java/com/healthmarketscience/jackcess/Table.java b/src/java/com/healthmarketscience/jackcess/Table.java
index 968ad95..bb392b0 100644
--- a/src/java/com/healthmarketscience/jackcess/Table.java
+++ b/src/java/com/healthmarketscience/jackcess/Table.java
@@ -29,7 +29,6 @@ package com.healthmarketscience.jackcess;
import java.io.IOException;
import java.nio.ByteBuffer;
-import java.nio.ByteOrder;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
@@ -120,6 +119,9 @@ public class Table
* Only used by unit tests
*/
Table(boolean testing) throws IOException {
+ if(!testing) {
+ throw new IllegalArgumentException();
+ }
_pageChannel = new PageChannel(testing);
}
@@ -325,7 +327,6 @@ public class Table
Map<String, Object> rtn = new LinkedHashMap<String, Object>(
columns.size());
for(Column column : columns) {
- Object value = null;
if((columnNames == null) || (columnNames.contains(column.getName()))) {
// Add the value to the row data
rtn.put(column.getName(), getRowColumn(rowBuffer, nullMask, column));
@@ -345,7 +346,7 @@ public class Table
{
boolean isNull = nullMask.isNull(column.getColumnNumber());
if(column.getType() == DataType.BOOLEAN) {
- return new Boolean(!isNull); //Boolean values are stored in the null mask
+ return Boolean.valueOf(!isNull); //Boolean values are stored in the null mask
} else if(isNull) {
// well, that's easy!
return null;
@@ -571,7 +572,6 @@ public class Table
for(Column col : columns) {
// we add the number of bytes for the column name and 2 bytes for the
// length of the column name
- ByteBuffer cName = format.CHARSET.encode(col.getName());
int nameByteLen = (col.getName().length() *
JetFormat.TEXT_FIELD_UNIT_SIZE);
totalTableDefSize += nameByteLen + 2;
@@ -938,24 +938,6 @@ public class Table
// reset to end of index info
tableBuffer.position(idxEndOffset);
}
-
- /**
- * Sets up the _varColumns list, assuming the _columns has already been set
- * up.
- */
- private void setupVariableColumns()
- {
- // pull out the variable length columns into a separate list
- for(Column col : _columns) {
- if(col.isVariableLength()) {
- _varColumns.add(col);
- }
- }
-
- // lastly sort these columns based on their index into the variable length
- // offset table, because we will write the columns in this order
- Collections.sort(_varColumns, VAR_LEN_COLUMN_COMPARATOR);
- }
/**
* Writes the given page data to the given page number, clears any other
diff --git a/src/java/com/healthmarketscience/jackcess/UsageMap.java b/src/java/com/healthmarketscience/jackcess/UsageMap.java
index bf19fb4..ec3bc36 100644
--- a/src/java/com/healthmarketscience/jackcess/UsageMap.java
+++ b/src/java/com/healthmarketscience/jackcess/UsageMap.java
@@ -473,17 +473,15 @@ public class UsageMap
if(_assumeOutOfRangeBitsOn) {
// we are using an inline map and assuming that anything not
- // within the current range is "on"
+ // within the current range is "on". so, if we attempt to set a
+ // bit which is before the current page, ignore it, we are not
+ // going back for it.
if((firstPage == PageChannel.INVALID_PAGE_NUMBER) ||
(pageNumber > lastPage)) {
// move to new start page, filling in as we move
moveToNewStartPageForRemove(firstPage, lastPage, pageNumber);
- } else {
-
- // umm, we are removing an already passed bit. whatever, we are
- // not going back for it
}
} else {
@@ -661,7 +659,7 @@ public class UsageMap
mapPageBuffer.put((byte) 0x01); //Unknown
mapPageBuffer.putShort((short) 0); //Unknown
for(int i = 0; i < mapPageBuffer.limit(); ++i) {
- byte b = mapPageBuffer.get(i);
+ mapPageBuffer.get(i);
}
int mapPageNum = _mapPageHolder.getPageNumber();
getTableBuffer().putInt(calculateMapPagePointerOffset(pageIndex),