summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/com/healthmarketscience/jackcess/Relationship.java18
-rw-r--r--src/java/com/healthmarketscience/jackcess/RowId.java107
-rw-r--r--src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java20
-rw-r--r--src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java2
-rw-r--r--src/java/com/healthmarketscience/jackcess/impl/IndexData.java43
-rw-r--r--src/java/com/healthmarketscience/jackcess/impl/IndexImpl.java4
-rw-r--r--src/java/com/healthmarketscience/jackcess/impl/RowIdImpl.java138
-rw-r--r--src/java/com/healthmarketscience/jackcess/impl/TableImpl.java40
-rw-r--r--src/java/com/healthmarketscience/jackcess/impl/UsageMap.java21
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/CursorTest.java18
-rw-r--r--test/src/java/com/healthmarketscience/jackcess/IndexTest.java12
11 files changed, 233 insertions, 190 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/Relationship.java b/src/java/com/healthmarketscience/jackcess/Relationship.java
index 7f5cb49..66ff0a2 100644
--- a/src/java/com/healthmarketscience/jackcess/Relationship.java
+++ b/src/java/com/healthmarketscience/jackcess/Relationship.java
@@ -31,8 +31,6 @@ import java.util.Collections;
import java.util.List;
import java.util.ArrayList;
-import com.healthmarketscience.jackcess.impl.ColumnImpl;
-
/**
* Information about a relationship between two tables in the database.
*
@@ -61,10 +59,10 @@ public class Relationship {
private final Table _toTable;
/** the columns in the "from" table in this relationship (aligned w/
toColumns list) */
- private List<ColumnImpl> _toColumns;
+ private final List<Column> _toColumns;
/** the columns in the "to" table in this relationship (aligned w/
toColumns list) */
- private List<ColumnImpl> _fromColumns;
+ private final List<Column> _fromColumns;
/** the various flags describing this relationship */
private final int _flags;
@@ -73,11 +71,11 @@ public class Relationship {
{
_name = name;
_fromTable = fromTable;
- _fromColumns = new ArrayList<ColumnImpl>(
- Collections.nCopies(numCols, (ColumnImpl)null));
+ _fromColumns = new ArrayList<Column>(
+ Collections.nCopies(numCols, (Column)null));
_toTable = toTable;
- _toColumns = new ArrayList<ColumnImpl>(
- Collections.nCopies(numCols, (ColumnImpl)null));
+ _toColumns = new ArrayList<Column>(
+ Collections.nCopies(numCols, (Column)null));
_flags = flags;
}
@@ -89,7 +87,7 @@ public class Relationship {
return _fromTable;
}
- public List<ColumnImpl> getFromColumns() {
+ public List<Column> getFromColumns() {
return _fromColumns;
}
@@ -97,7 +95,7 @@ public class Relationship {
return _toTable;
}
- public List<ColumnImpl> getToColumns() {
+ public List<Column> getToColumns() {
return _toColumns;
}
diff --git a/src/java/com/healthmarketscience/jackcess/RowId.java b/src/java/com/healthmarketscience/jackcess/RowId.java
index 1217538..b5b20f6 100644
--- a/src/java/com/healthmarketscience/jackcess/RowId.java
+++ b/src/java/com/healthmarketscience/jackcess/RowId.java
@@ -1,5 +1,5 @@
/*
-Copyright (c) 2007 Health Market Science, Inc.
+Copyright (c) 2013 James Ahlborn
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
@@ -15,119 +15,16 @@ You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
USA
-
-You can contact Health Market Science at info@healthmarketscience.com
-or at the following address:
-
-Health Market Science
-2700 Horizon Drive
-Suite 200
-King of Prussia, PA 19406
*/
package com.healthmarketscience.jackcess;
-import org.apache.commons.lang.builder.CompareToBuilder;
-
-
/**
* Uniquely identifies a row of data within the access database.
*
* @author James Ahlborn
*/
-public class RowId implements Comparable<RowId>
+public interface RowId extends Comparable<RowId>
{
- /** special page number which will sort before any other valid page
- number */
- public static final int FIRST_PAGE_NUMBER = -1;
- /** special page number which will sort after any other valid page
- number */
- public static final int LAST_PAGE_NUMBER = -2;
-
- /** special row number representing an invalid row number */
- public static final int INVALID_ROW_NUMBER = -1;
-
- /** type attributes for RowIds which simplify comparisons */
- public enum Type {
- /** comparable type indicating this RowId should always compare less than
- normal RowIds */
- ALWAYS_FIRST,
- /** comparable type indicating this RowId should always compare
- normally */
- NORMAL,
- /** comparable type indicating this RowId should always compare greater
- than normal RowIds */
- ALWAYS_LAST;
- }
-
- /** special rowId which will sort before any other valid rowId */
- public static final RowId FIRST_ROW_ID = new RowId(
- FIRST_PAGE_NUMBER, INVALID_ROW_NUMBER);
-
- /** special rowId which will sort after any other valid rowId */
- public static final RowId LAST_ROW_ID = new RowId(
- LAST_PAGE_NUMBER, INVALID_ROW_NUMBER);
-
- private final int _pageNumber;
- private final int _rowNumber;
- private final Type _type;
-
- /**
- * Creates a new <code>RowId</code> instance.
- *
- */
- public RowId(int pageNumber,int rowNumber) {
- _pageNumber = pageNumber;
- _rowNumber = rowNumber;
- _type = ((_pageNumber == FIRST_PAGE_NUMBER) ? Type.ALWAYS_FIRST :
- ((_pageNumber == LAST_PAGE_NUMBER) ? Type.ALWAYS_LAST :
- Type.NORMAL));
- }
-
- public int getPageNumber() {
- return _pageNumber;
- }
-
- public int getRowNumber() {
- return _rowNumber;
- }
-
- /**
- * Returns {@code true} if this rowId potentially represents an actual row
- * of data, {@code false} otherwise.
- */
- public boolean isValid() {
- return((getRowNumber() >= 0) && (getPageNumber() >= 0));
- }
-
- public Type getType() {
- return _type;
- }
-
- public int compareTo(RowId other) {
- return new CompareToBuilder()
- .append(getType(), other.getType())
- .append(getPageNumber(), other.getPageNumber())
- .append(getRowNumber(), other.getRowNumber())
- .toComparison();
- }
-
- @Override
- public int hashCode() {
- return getPageNumber() ^ getRowNumber();
- }
- @Override
- public boolean equals(Object o) {
- return ((this == o) ||
- ((o != null) && (getClass() == o.getClass()) &&
- (getPageNumber() == ((RowId)o).getPageNumber()) &&
- (getRowNumber() == ((RowId)o).getRowNumber())));
- }
-
- @Override
- public String toString() {
- return getPageNumber() + ":" + getRowNumber();
- }
-
}
diff --git a/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java b/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java
index e995f5d..fd5db70 100644
--- a/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java
+++ b/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java
@@ -73,10 +73,10 @@ public abstract class CursorImpl implements Cursor
/** first position for the TableScanCursor */
private static final ScanPosition FIRST_SCAN_POSITION =
- new ScanPosition(RowId.FIRST_ROW_ID);
+ new ScanPosition(RowIdImpl.FIRST_ROW_ID);
/** last position for the TableScanCursor */
private static final ScanPosition LAST_SCAN_POSITION =
- new ScanPosition(RowId.LAST_ROW_ID);
+ new ScanPosition(RowIdImpl.LAST_ROW_ID);
/** identifier for this cursor */
private final IdImpl _id;
@@ -1136,7 +1136,7 @@ public abstract class CursorImpl implements Cursor
// figure out how many rows are left on this page so we can find the
// next row
- RowId curRowId = curPos.getRowId();
+ RowIdImpl curRowId = curPos.getRowId();
TableImpl.positionAtRowHeader(rowState, curRowId);
int currentRowNumber = curRowId.getRowNumber();
@@ -1144,14 +1144,14 @@ public abstract class CursorImpl implements Cursor
while(true) {
currentRowNumber = handler.getAnotherRowNumber(currentRowNumber);
- curRowId = new RowId(curRowId.getPageNumber(), currentRowNumber);
+ curRowId = new RowIdImpl(curRowId.getPageNumber(), currentRowNumber);
TableImpl.positionAtRowHeader(rowState, curRowId);
if(!rowState.isValid()) {
// load next page
- curRowId = new RowId(handler.getAnotherPageNumber(),
- RowId.INVALID_ROW_NUMBER);
+ curRowId = new RowIdImpl(handler.getAnotherPageNumber(),
+ RowIdImpl.INVALID_ROW_NUMBER);
TableImpl.positionAtRowHeader(rowState, curRowId);
if(!rowState.isHeaderPageNumberValid()) {
@@ -1293,7 +1293,7 @@ public abstract class CursorImpl implements Cursor
/**
* Returns the unique RowId of the position of the cursor.
*/
- public abstract RowId getRowId();
+ public abstract RowIdImpl getRowId();
/**
* Returns {@code true} if the subclass specific info in a Position is
@@ -1344,14 +1344,14 @@ public abstract class CursorImpl implements Cursor
*/
private static final class ScanPosition extends PositionImpl
{
- private final RowId _rowId;
+ private final RowIdImpl _rowId;
- private ScanPosition(RowId rowId) {
+ private ScanPosition(RowIdImpl rowId) {
_rowId = rowId;
}
@Override
- public RowId getRowId() {
+ public RowIdImpl getRowId() {
return _rowId;
}
diff --git a/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java b/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java
index a501c9d..d262e2a 100644
--- a/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java
+++ b/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java
@@ -502,7 +502,7 @@ public class IndexCursorImpl extends CursorImpl implements IndexCursor
}
@Override
- public RowId getRowId() {
+ public RowIdImpl getRowId() {
return getEntry().getRowId();
}
diff --git a/src/java/com/healthmarketscience/jackcess/impl/IndexData.java b/src/java/com/healthmarketscience/jackcess/impl/IndexData.java
index 2262420..4533fa5 100644
--- a/src/java/com/healthmarketscience/jackcess/impl/IndexData.java
+++ b/src/java/com/healthmarketscience/jackcess/impl/IndexData.java
@@ -60,11 +60,11 @@ public class IndexData {
/** special entry which is less than any other entry */
public static final Entry FIRST_ENTRY =
- createSpecialEntry(RowId.FIRST_ROW_ID);
+ createSpecialEntry(RowIdImpl.FIRST_ROW_ID);
/** special entry which is greater than any other entry */
public static final Entry LAST_ENTRY =
- createSpecialEntry(RowId.LAST_ROW_ID);
+ createSpecialEntry(RowIdImpl.LAST_ROW_ID);
/** special object which will always be greater than any other value, when
searching for an index entry range in a multi-value index */
@@ -529,7 +529,7 @@ public class IndexData {
* @param row Row to add
* @param rowId rowId of the row to be added
*/
- public void addRow(Object[] row, RowId rowId)
+ public void addRow(Object[] row, RowIdImpl rowId)
throws IOException
{
int nullCount = countNullValues(row);
@@ -603,7 +603,7 @@ public class IndexData {
* @param row Row to remove
* @param rowId rowId of the row to be removed
*/
- public void deleteRow(Object[] row, RowId rowId)
+ public void deleteRow(Object[] row, RowIdImpl rowId)
throws IOException
{
int nullCount = countNullValues(row);
@@ -700,7 +700,7 @@ public class IndexData {
startEntryBytes = createEntryBytes(startRow);
startEntry = new Entry(startEntryBytes,
(startInclusive ?
- RowId.FIRST_ROW_ID : RowId.LAST_ROW_ID));
+ RowIdImpl.FIRST_ROW_ID : RowIdImpl.LAST_ROW_ID));
}
Entry endEntry = LAST_ENTRY;
if(endRow != null) {
@@ -711,7 +711,7 @@ public class IndexData {
createEntryBytes(endRow));
endEntry = new Entry(endEntryBytes,
(endInclusive ?
- RowId.LAST_ROW_ID : RowId.FIRST_ROW_ID));
+ RowIdImpl.LAST_ROW_ID : RowIdImpl.FIRST_ROW_ID));
}
return new EntryCursor(findEntryPosition(startEntry),
findEntryPosition(endEntry));
@@ -1184,7 +1184,7 @@ public class IndexData {
/**
* Creates one of the special index entries.
*/
- private static Entry createSpecialEntry(RowId rowId) {
+ private static Entry createSpecialEntry(RowIdImpl rowId) {
return new Entry((byte[])null, rowId);
}
@@ -1241,16 +1241,17 @@ public class IndexData {
/**
* Returns the EntryType based on the given entry info.
*/
- private static EntryType determineEntryType(byte[] entryBytes, RowId rowId)
+ private static EntryType determineEntryType(byte[] entryBytes,
+ RowIdImpl rowId)
{
if(entryBytes != null) {
- return ((rowId.getType() == RowId.Type.NORMAL) ?
+ return ((rowId.getType() == RowIdImpl.Type.NORMAL) ?
EntryType.NORMAL :
- ((rowId.getType() == RowId.Type.ALWAYS_FIRST) ?
+ ((rowId.getType() == RowIdImpl.Type.ALWAYS_FIRST) ?
EntryType.FIRST_VALID : EntryType.LAST_VALID));
} else if(!rowId.isValid()) {
// this is a "special" entry (first/last)
- return ((rowId.getType() == RowId.Type.ALWAYS_FIRST) ?
+ return ((rowId.getType() == RowIdImpl.Type.ALWAYS_FIRST) ?
EntryType.ALWAYS_FIRST : EntryType.ALWAYS_LAST);
}
throw new IllegalArgumentException("Values was null for valid entry");
@@ -1645,7 +1646,7 @@ public class IndexData {
public static class Entry implements Comparable<Entry>
{
/** page/row on which this row is stored */
- private final RowId _rowId;
+ private final RowIdImpl _rowId;
/** the entry value */
private final byte[] _entryBytes;
/** comparable type for the entry */
@@ -1657,7 +1658,7 @@ public class IndexData {
* @param rowId rowId in which the row is stored
* @param type the type of the entry
*/
- private Entry(byte[] entryBytes, RowId rowId, EntryType type) {
+ private Entry(byte[] entryBytes, RowIdImpl rowId, EntryType type) {
_rowId = rowId;
_entryBytes = entryBytes;
_type = type;
@@ -1668,7 +1669,7 @@ public class IndexData {
* @param entryBytes encoded bytes for this index entry
* @param rowId rowId in which the row is stored
*/
- private Entry(byte[] entryBytes, RowId rowId)
+ private Entry(byte[] entryBytes, RowIdImpl rowId)
{
this(entryBytes, rowId, determineEntryType(entryBytes, rowId));
}
@@ -1699,11 +1700,11 @@ public class IndexData {
int page = ByteUtil.get3ByteInt(buffer, ENTRY_BYTE_ORDER);
int row = ByteUtil.getUnsignedByte(buffer);
- _rowId = new RowId(page, row);
+ _rowId = new RowIdImpl(page, row);
_type = EntryType.NORMAL;
}
- public RowId getRowId() {
+ public RowIdImpl getRowId() {
return _rowId;
}
@@ -1857,7 +1858,7 @@ public class IndexData {
* @param type the type of the entry
* @param subPageNumber the sub-page to which this node entry refers
*/
- private NodeEntry(byte[] entryBytes, RowId rowId, EntryType type,
+ private NodeEntry(byte[] entryBytes, RowIdImpl rowId, EntryType type,
Integer subPageNumber) {
super(entryBytes, rowId, type);
_subPageNumber = subPageNumber;
@@ -2006,8 +2007,8 @@ public class IndexData {
public void beforeEntry(Object[] row)
throws IOException
{
- restorePosition(
- new Entry(IndexData.this.createEntryBytes(row), RowId.FIRST_ROW_ID));
+ restorePosition(new Entry(IndexData.this.createEntryBytes(row),
+ RowIdImpl.FIRST_ROW_ID));
}
/**
@@ -2017,8 +2018,8 @@ public class IndexData {
public void afterEntry(Object[] row)
throws IOException
{
- restorePosition(
- new Entry(IndexData.this.createEntryBytes(row), RowId.LAST_ROW_ID));
+ restorePosition(new Entry(IndexData.this.createEntryBytes(row),
+ RowIdImpl.LAST_ROW_ID));
}
/**
diff --git a/src/java/com/healthmarketscience/jackcess/impl/IndexImpl.java b/src/java/com/healthmarketscience/jackcess/impl/IndexImpl.java
index 12d61af..1fd560b 100644
--- a/src/java/com/healthmarketscience/jackcess/impl/IndexImpl.java
+++ b/src/java/com/healthmarketscience/jackcess/impl/IndexImpl.java
@@ -253,7 +253,7 @@ public class IndexImpl implements Index, Comparable<IndexImpl>
* @param row Row to add
* @param rowId rowId of the row to be added
*/
- public void addRow(Object[] row, RowId rowId)
+ public void addRow(Object[] row, RowIdImpl rowId)
throws IOException
{
getIndexData().addRow(row, rowId);
@@ -267,7 +267,7 @@ public class IndexImpl implements Index, Comparable<IndexImpl>
* @param row Row to remove
* @param rowId rowId of the row to be removed
*/
- public void deleteRow(Object[] row, RowId rowId)
+ public void deleteRow(Object[] row, RowIdImpl rowId)
throws IOException
{
getIndexData().deleteRow(row, rowId);
diff --git a/src/java/com/healthmarketscience/jackcess/impl/RowIdImpl.java b/src/java/com/healthmarketscience/jackcess/impl/RowIdImpl.java
new file mode 100644
index 0000000..7524f1c
--- /dev/null
+++ b/src/java/com/healthmarketscience/jackcess/impl/RowIdImpl.java
@@ -0,0 +1,138 @@
+/*
+Copyright (c) 2007 Health Market Science, Inc.
+
+This library is free software; you can redistribute it and/or
+modify it under the terms of the GNU Lesser General Public
+License as published by the Free Software Foundation; either
+version 2.1 of the License, or (at your option) any later version.
+
+This library is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+Lesser General Public License for more details.
+
+You should have received a copy of the GNU Lesser General Public
+License along with this library; if not, write to the Free Software
+Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+USA
+
+You can contact Health Market Science at info@healthmarketscience.com
+or at the following address:
+
+Health Market Science
+2700 Horizon Drive
+Suite 200
+King of Prussia, PA 19406
+*/
+
+package com.healthmarketscience.jackcess.impl;
+
+import org.apache.commons.lang.builder.CompareToBuilder;
+import com.healthmarketscience.jackcess.RowId;
+
+
+/**
+ * Uniquely identifies a row of data within the access database.
+ *
+ * @author James Ahlborn
+ */
+public class RowIdImpl implements RowId
+{
+ /** special page number which will sort before any other valid page
+ number */
+ public static final int FIRST_PAGE_NUMBER = -1;
+ /** special page number which will sort after any other valid page
+ number */
+ public static final int LAST_PAGE_NUMBER = -2;
+
+ /** special row number representing an invalid row number */
+ public static final int INVALID_ROW_NUMBER = -1;
+
+ /** type attributes for RowIds which simplify comparisons */
+ public enum Type {
+ /** comparable type indicating this RowId should always compare less than
+ normal RowIds */
+ ALWAYS_FIRST,
+ /** comparable type indicating this RowId should always compare
+ normally */
+ NORMAL,
+ /** comparable type indicating this RowId should always compare greater
+ than normal RowIds */
+ ALWAYS_LAST;
+ }
+
+ /** special rowId which will sort before any other valid rowId */
+ public static final RowIdImpl FIRST_ROW_ID = new RowIdImpl(
+ FIRST_PAGE_NUMBER, INVALID_ROW_NUMBER);
+
+ /** special rowId which will sort after any other valid rowId */
+ public static final RowIdImpl LAST_ROW_ID = new RowIdImpl(
+ LAST_PAGE_NUMBER, INVALID_ROW_NUMBER);
+
+ private final int _pageNumber;
+ private final int _rowNumber;
+ private final Type _type;
+
+ /**
+ * Creates a new <code>RowId</code> instance.
+ *
+ */
+ public RowIdImpl(int pageNumber,int rowNumber) {
+ _pageNumber = pageNumber;
+ _rowNumber = rowNumber;
+ _type = ((_pageNumber == FIRST_PAGE_NUMBER) ? Type.ALWAYS_FIRST :
+ ((_pageNumber == LAST_PAGE_NUMBER) ? Type.ALWAYS_LAST :
+ Type.NORMAL));
+ }
+
+ public int getPageNumber() {
+ return _pageNumber;
+ }
+
+ public int getRowNumber() {
+ return _rowNumber;
+ }
+
+ /**
+ * Returns {@code true} if this rowId potentially represents an actual row
+ * of data, {@code false} otherwise.
+ */
+ public boolean isValid() {
+ return((getRowNumber() >= 0) && (getPageNumber() >= 0));
+ }
+
+ public Type getType() {
+ return _type;
+ }
+
+ public int compareTo(RowId other) {
+ return compareTo((RowIdImpl)other);
+ }
+
+ public int compareTo(RowIdImpl other) {
+ return new CompareToBuilder()
+ .append(getType(), other.getType())
+ .append(getPageNumber(), other.getPageNumber())
+ .append(getRowNumber(), other.getRowNumber())
+ .toComparison();
+ }
+
+ @Override
+ public int hashCode() {
+ return getPageNumber() ^ getRowNumber();
+ }
+
+ @Override
+ public boolean equals(Object o) {
+ return ((this == o) ||
+ ((o != null) && (getClass() == o.getClass()) &&
+ (getPageNumber() == ((RowIdImpl)o).getPageNumber()) &&
+ (getRowNumber() == ((RowIdImpl)o).getRowNumber())));
+ }
+
+ @Override
+ public String toString() {
+ return getPageNumber() + ":" + getRowNumber();
+ }
+
+}
diff --git a/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java b/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java
index 326de2c..5d7f05d 100644
--- a/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java
+++ b/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java
@@ -473,7 +473,9 @@ public class TableImpl implements Table
* allows for more complex table interactions.
* @usage _advanced_method_
*/
- public void deleteRow(RowState rowState, RowId rowId) throws IOException {
+ public void deleteRow(RowState rowState, RowIdImpl rowId)
+ throws IOException
+ {
requireValidRowId(rowId);
// ensure that the relevant row state is up-to-date
@@ -534,7 +536,8 @@ public class TableImpl implements Table
* e.g. {@link Cursor#getCurrentRowValue}.
* @usage _advanced_method_
*/
- public Object getRowValue(RowState rowState, RowId rowId, ColumnImpl column)
+ public Object getRowValue(RowState rowState, RowIdImpl rowId,
+ ColumnImpl column)
throws IOException
{
if(this != column.getTable()) {
@@ -556,7 +559,7 @@ public class TableImpl implements Table
* @usage _advanced_method_
*/
public Map<String, Object> getRow(
- RowState rowState, RowId rowId, Collection<String> columnNames)
+ RowState rowState, RowIdImpl rowId, Collection<String> columnNames)
throws IOException
{
requireValidRowId(rowId);
@@ -759,7 +762,8 @@ public class TableImpl implements Table
* @return a ByteBuffer of the relevant page, or null if row was invalid
* @usage _advanced_method_
*/
- public static ByteBuffer positionAtRowHeader(RowState rowState, RowId rowId)
+ public static ByteBuffer positionAtRowHeader(RowState rowState,
+ RowIdImpl rowId)
throws IOException
{
ByteBuffer rowBuffer = rowState.setHeaderRow(rowId);
@@ -803,7 +807,8 @@ public class TableImpl implements Table
* invalid or deleted
* @usage _advanced_method_
*/
- public static ByteBuffer positionAtRowData(RowState rowState, RowId rowId)
+ public static ByteBuffer positionAtRowData(RowState rowState,
+ RowIdImpl rowId)
throws IOException
{
positionAtRowHeader(rowState, rowId);
@@ -850,7 +855,7 @@ public class TableImpl implements Table
int overflowRowNum = ByteUtil.getUnsignedByte(rowBuffer, rowStart);
int overflowPageNum = ByteUtil.get3ByteInt(rowBuffer, rowStart + 1);
rowBuffer = rowState.setOverflowRow(
- new RowId(overflowPageNum, overflowRowNum));
+ new RowIdImpl(overflowPageNum, overflowRowNum));
rowNum = overflowRowNum;
} else {
@@ -1347,7 +1352,7 @@ public class TableImpl implements Table
dataPage.put(rowData[i]);
// update the indexes
- RowId rowId = new RowId(pageNumber, rowNum);
+ RowIdImpl rowId = new RowIdImpl(pageNumber, rowNum);
for(IndexData indexData : _indexDatas) {
indexData.addRow(row, rowId);
}
@@ -1368,7 +1373,7 @@ public class TableImpl implements Table
* {@link Cursor#setCurrentRowValue} and {@link Cursor#updateCurrentRow}.
* @usage _advanced_method_
*/
- public void updateRow(RowState rowState, RowId rowId, Object... row)
+ public void updateRow(RowState rowState, RowIdImpl rowId, Object... row)
throws IOException
{
requireValidRowId(rowId);
@@ -1453,7 +1458,7 @@ public class TableImpl implements Table
PageChannel.INVALID_PAGE_NUMBER);
pageNumber = _addRowBufferH.getPageNumber();
- RowId headerRowId = rowState.getHeaderRowId();
+ RowIdImpl headerRowId = rowState.getHeaderRowId();
ByteBuffer headerPage = rowState.getHeaderPage();
if(pageNumber == headerRowId.getPageNumber()) {
// new row is on the same page as header row, share page
@@ -1945,7 +1950,7 @@ public class TableImpl implements Table
/**
* @throws IllegalStateException if the given rowId is invalid
*/
- private static void requireValidRowId(RowId rowId) {
+ private static void requireValidRowId(RowIdImpl rowId) {
if(!rowId.isValid()) {
throw new IllegalArgumentException("Given rowId is invalid: " + rowId);
}
@@ -1954,7 +1959,8 @@ public class TableImpl implements Table
/**
* @throws IllegalStateException if the given row is invalid or deleted
*/
- private static void requireNonDeletedRow(RowState rowState, RowId rowId) {
+ private static void requireNonDeletedRow(RowState rowState, RowIdImpl rowId)
+ {
if(!rowState.isValid()) {
throw new IllegalArgumentException(
"Given rowId is invalid for this table: " + rowId);
@@ -2084,7 +2090,7 @@ public class TableImpl implements Table
/** Buffer used for reading the header row data pages */
private final TempPageHolder _headerRowBufferH;
/** the header rowId */
- private RowId _headerRowId = RowId.FIRST_ROW_ID;
+ private RowIdImpl _headerRowId = RowIdImpl.FIRST_ROW_ID;
/** the number of rows on the header page */
private int _rowsOnHeaderPage;
/** the rowState status */
@@ -2099,7 +2105,7 @@ public class TableImpl implements Table
private ByteBuffer _finalRowBuffer;
/** the rowId which contains the final data (after following any overflow
pointers) */
- private RowId _finalRowId = null;
+ private RowIdImpl _finalRowId = null;
/** true if the row values array has data */
private boolean _haveRowValues;
/** values read from the last row */
@@ -2171,7 +2177,7 @@ public class TableImpl implements Table
return _finalRowBuffer;
}
- public RowId getFinalRowId() {
+ public RowIdImpl getFinalRowId() {
if(_finalRowId == null) {
_finalRowId = getHeaderRowId();
}
@@ -2239,7 +2245,7 @@ public class TableImpl implements Table
_varColOffsets = varColOffsets;
}
- public RowId getHeaderRowId() {
+ public RowIdImpl getHeaderRowId() {
return _headerRowId;
}
@@ -2254,7 +2260,7 @@ public class TableImpl implements Table
return _headerRowBufferH.getPage(getPageChannel());
}
- private ByteBuffer setHeaderRow(RowId rowId)
+ private ByteBuffer setHeaderRow(RowIdImpl rowId)
throws IOException
{
checkForModification();
@@ -2289,7 +2295,7 @@ public class TableImpl implements Table
return _finalRowBuffer;
}
- private ByteBuffer setOverflowRow(RowId rowId)
+ private ByteBuffer setOverflowRow(RowIdImpl rowId)
throws IOException
{
// this should never see modifications because it only happens within
diff --git a/src/java/com/healthmarketscience/jackcess/impl/UsageMap.java b/src/java/com/healthmarketscience/jackcess/impl/UsageMap.java
index 9361c87..ffc3904 100644
--- a/src/java/com/healthmarketscience/jackcess/impl/UsageMap.java
+++ b/src/java/com/healthmarketscience/jackcess/impl/UsageMap.java
@@ -198,13 +198,14 @@ public class UsageMap
}
protected int getFirstPageNumber() {
- return bitIndexToPageNumber(getNextBitIndex(-1), RowId.LAST_PAGE_NUMBER);
+ return bitIndexToPageNumber(getNextBitIndex(-1),
+ RowIdImpl.LAST_PAGE_NUMBER);
}
protected int getNextPageNumber(int curPage) {
return bitIndexToPageNumber(
getNextBitIndex(pageNumberToBitIndex(curPage)),
- RowId.LAST_PAGE_NUMBER);
+ RowIdImpl.LAST_PAGE_NUMBER);
}
protected int getNextBitIndex(int curIndex) {
@@ -213,13 +214,13 @@ public class UsageMap
protected int getLastPageNumber() {
return bitIndexToPageNumber(getPrevBitIndex(_pageNumbers.length()),
- RowId.FIRST_PAGE_NUMBER);
+ RowIdImpl.FIRST_PAGE_NUMBER);
}
protected int getPrevPageNumber(int curPage) {
return bitIndexToPageNumber(
getPrevBitIndex(pageNumberToBitIndex(curPage)),
- RowId.FIRST_PAGE_NUMBER);
+ RowIdImpl.FIRST_PAGE_NUMBER);
}
protected int getPrevBitIndex(int curIndex) {
@@ -912,9 +913,9 @@ public class UsageMap
private int updatePosition(int pageNumber) {
if(pageNumber < UsageMap.this.getFirstPageNumber()) {
- pageNumber = RowId.FIRST_PAGE_NUMBER;
+ pageNumber = RowIdImpl.FIRST_PAGE_NUMBER;
} else if(pageNumber > UsageMap.this.getLastPageNumber()) {
- pageNumber = RowId.LAST_PAGE_NUMBER;
+ pageNumber = RowIdImpl.LAST_PAGE_NUMBER;
}
return pageNumber;
}
@@ -949,11 +950,11 @@ public class UsageMap
}
@Override
public int getBeginningPageNumber() {
- return RowId.FIRST_PAGE_NUMBER;
+ return RowIdImpl.FIRST_PAGE_NUMBER;
}
@Override
public int getEndPageNumber() {
- return RowId.LAST_PAGE_NUMBER;
+ return RowIdImpl.LAST_PAGE_NUMBER;
}
}
@@ -970,11 +971,11 @@ public class UsageMap
}
@Override
public int getBeginningPageNumber() {
- return RowId.LAST_PAGE_NUMBER;
+ return RowIdImpl.LAST_PAGE_NUMBER;
}
@Override
public int getEndPageNumber() {
- return RowId.FIRST_PAGE_NUMBER;
+ return RowIdImpl.FIRST_PAGE_NUMBER;
}
}
diff --git a/test/src/java/com/healthmarketscience/jackcess/CursorTest.java b/test/src/java/com/healthmarketscience/jackcess/CursorTest.java
index ac83a5e..575e51f 100644
--- a/test/src/java/com/healthmarketscience/jackcess/CursorTest.java
+++ b/test/src/java/com/healthmarketscience/jackcess/CursorTest.java
@@ -42,6 +42,7 @@ import com.healthmarketscience.jackcess.util.RowFilterTest;
import static com.healthmarketscience.jackcess.impl.JetFormatTest.*;
import junit.framework.TestCase;
import com.healthmarketscience.jackcess.impl.JetFormatTest;
+import com.healthmarketscience.jackcess.impl.RowIdImpl;
import com.healthmarketscience.jackcess.util.ColumnMatcher;
import com.healthmarketscience.jackcess.util.SimpleColumnMatcher;
import com.healthmarketscience.jackcess.util.CaseInsensitiveColumnMatcher;
@@ -186,16 +187,17 @@ public class CursorTest extends TestCase {
public void testRowId() throws Exception {
// test special cases
- RowId rowId1 = new RowId(1, 2);
- RowId rowId2 = new RowId(1, 3);
- RowId rowId3 = new RowId(2, 1);
+ RowIdImpl rowId1 = new RowIdImpl(1, 2);
+ RowIdImpl rowId2 = new RowIdImpl(1, 3);
+ RowIdImpl rowId3 = new RowIdImpl(2, 1);
- List<RowId> sortedRowIds = new ArrayList<RowId>(new TreeSet<RowId>(
- Arrays.asList(rowId1, rowId2, rowId3, RowId.FIRST_ROW_ID,
- RowId.LAST_ROW_ID)));
+ List<RowIdImpl> sortedRowIds =
+ new ArrayList<RowIdImpl>(new TreeSet<RowIdImpl>(
+ Arrays.asList(rowId1, rowId2, rowId3, RowIdImpl.FIRST_ROW_ID,
+ RowIdImpl.LAST_ROW_ID)));
- assertEquals(Arrays.asList(RowId.FIRST_ROW_ID, rowId1, rowId2, rowId3,
- RowId.LAST_ROW_ID),
+ assertEquals(Arrays.asList(RowIdImpl.FIRST_ROW_ID, rowId1, rowId2, rowId3,
+ RowIdImpl.LAST_ROW_ID),
sortedRowIds);
}
diff --git a/test/src/java/com/healthmarketscience/jackcess/IndexTest.java b/test/src/java/com/healthmarketscience/jackcess/IndexTest.java
index fda8ac5..8eb7cd1 100644
--- a/test/src/java/com/healthmarketscience/jackcess/IndexTest.java
+++ b/test/src/java/com/healthmarketscience/jackcess/IndexTest.java
@@ -36,16 +36,16 @@ import java.util.Map;
import java.util.SortedSet;
import java.util.TreeSet;
-import junit.framework.TestCase;
-
import static com.healthmarketscience.jackcess.Database.*;
import static com.healthmarketscience.jackcess.DatabaseTest.*;
-import static com.healthmarketscience.jackcess.impl.JetFormatTest.*;
-import com.healthmarketscience.jackcess.impl.IndexImpl;
import com.healthmarketscience.jackcess.impl.ByteUtil;
+import com.healthmarketscience.jackcess.impl.IndexCodesTest;
import com.healthmarketscience.jackcess.impl.IndexData;
+import com.healthmarketscience.jackcess.impl.IndexImpl;
+import static com.healthmarketscience.jackcess.impl.JetFormatTest.*;
+import com.healthmarketscience.jackcess.impl.RowIdImpl;
import com.healthmarketscience.jackcess.impl.TableImpl;
-import com.healthmarketscience.jackcess.impl.IndexCodesTest;
+import junit.framework.TestCase;
/**
* @author James Ahlborn
@@ -334,7 +334,7 @@ public class IndexTest extends TestCase {
IOException failure = null;
try {
- ((IndexImpl)index).addRow(row, new RowId(400 + i, 0));
+ ((IndexImpl)index).addRow(row, new RowIdImpl(400 + i, 0));
} catch(IOException e) {
failure = e;
}