diff options
Diffstat (limited to 'src')
22 files changed, 298 insertions, 195 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/Cursor.java b/src/java/com/healthmarketscience/jackcess/Cursor.java index 622cc27..765685d 100644 --- a/src/java/com/healthmarketscience/jackcess/Cursor.java +++ b/src/java/com/healthmarketscience/jackcess/Cursor.java @@ -43,7 +43,7 @@ import com.healthmarketscience.jackcess.util.ColumnMatcher; * * @author James Ahlborn */ -public interface Cursor extends Iterable<Map<String, Object>> +public interface Cursor extends Iterable<Row> { // FIXME, include iterable and iterator methods? @@ -136,7 +136,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String, Object>> reverseIterable(); + public Iterable<Row> reverseIterable(); /** * Returns an Iterable whose iterator() method calls <code>afterLast</code> @@ -147,7 +147,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String, Object>> reverseIterable( + public Iterable<Row> reverseIterable( Collection<String> columnNames); /** @@ -158,7 +158,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String, Object>> iterator(); + public Iterator<Row> iterator(); /** * Returns an Iterable whose iterator() method returns the result of a call @@ -166,7 +166,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String, Object>> iterable( + public Iterable<Row> iterable( Collection<String> columnNames); /** @@ -177,7 +177,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String, Object>> iterator(Collection<String> columnNames); + public Iterator<Row> iterator(Collection<String> columnNames); /** * Returns an Iterable whose iterator() method returns the result of a call @@ -185,7 +185,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String, Object>> columnMatchIterable( + public Iterable<Row> columnMatchIterable( Column columnPattern, Object valuePattern); /** @@ -197,7 +197,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String, Object>> columnMatchIterator( + public Iterator<Row> columnMatchIterator( Column columnPattern, Object valuePattern); /** @@ -210,7 +210,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String, Object>> columnMatchIterator( + public Iterator<Row> columnMatchIterator( Collection<String> columnNames, Column columnPattern, Object valuePattern); /** @@ -219,7 +219,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String, Object>> rowMatchIterable( + public Iterable<Row> rowMatchIterable( Map<String,?> rowPattern); /** @@ -231,7 +231,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String, Object>> rowMatchIterator( + public Iterator<Row> rowMatchIterator( Map<String,?> rowPattern); /** @@ -240,7 +240,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String, Object>> rowMatchIterable( + public Iterable<Row> rowMatchIterable( Collection<String> columnNames, Map<String,?> rowPattern); @@ -254,7 +254,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String, Object>> rowMatchIterator( + public Iterator<Row> rowMatchIterator( Collection<String> columnNames, Map<String,?> rowPattern); /** @@ -276,7 +276,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @return The next row in this table (Column name -> Column value), or * {@code null} if no next row is found */ - public Map<String, Object> getNextRow() throws IOException; + public Row getNextRow() throws IOException; /** * Moves to the next row in the table and returns it. @@ -284,7 +284,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @return The next row in this table (Column name -> Column value), or * {@code null} if no next row is found */ - public Map<String, Object> getNextRow(Collection<String> columnNames) + public Row getNextRow(Collection<String> columnNames) throws IOException; /** @@ -292,7 +292,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @return The previous row in this table (Column name -> Column value), or * {@code null} if no previous row is found */ - public Map<String, Object> getPreviousRow() throws IOException; + public Row getPreviousRow() throws IOException; /** * Moves to the previous row in the table and returns it. @@ -300,7 +300,7 @@ public interface Cursor extends Iterable<Map<String, Object>> * @return The previous row in this table (Column name -> Column value), or * {@code null} if no previous row is found */ - public Map<String, Object> getPreviousRow(Collection<String> columnNames) + public Row getPreviousRow(Collection<String> columnNames) throws IOException; /** @@ -413,13 +413,13 @@ public interface Cursor extends Iterable<Map<String, Object>> /** * Returns the current row in this cursor (Column name -> Column value). */ - public Map<String, Object> getCurrentRow() throws IOException; + public Row getCurrentRow() throws IOException; /** * Returns the current row in this cursor (Column name -> Column value). * @param columnNames Only column names in this collection will be returned */ - public Map<String, Object> getCurrentRow(Collection<String> columnNames) + public Row getCurrentRow(Collection<String> columnNames) throws IOException; /** diff --git a/src/java/com/healthmarketscience/jackcess/CursorBuilder.java b/src/java/com/healthmarketscience/jackcess/CursorBuilder.java index 985f276..8c4a725 100644 --- a/src/java/com/healthmarketscience/jackcess/CursorBuilder.java +++ b/src/java/com/healthmarketscience/jackcess/CursorBuilder.java @@ -406,7 +406,7 @@ public class CursorBuilder { * @param rowPattern pattern to be used to find the row * @return the matching row or {@code null} if a match could not be found. */ - public static Map<String,Object> findRow(Table table, Map<String,?> rowPattern) + public static Row findRow(Table table, Map<String,?> rowPattern) throws IOException { Cursor cursor = createCursor(table); @@ -457,8 +457,7 @@ public class CursorBuilder { * @param rowPattern pattern to be used to find the row * @return the matching row or {@code null} if a match could not be found. */ - public static Map<String,Object> findRow(Table table, Index index, - Map<String,?> rowPattern) + public static Row findRow(Table table, Index index, Map<String,?> rowPattern) throws IOException { Cursor cursor = createCursor(table, index); diff --git a/src/java/com/healthmarketscience/jackcess/IndexCursor.java b/src/java/com/healthmarketscience/jackcess/IndexCursor.java index b8b4556..ebf1362 100644 --- a/src/java/com/healthmarketscience/jackcess/IndexCursor.java +++ b/src/java/com/healthmarketscience/jackcess/IndexCursor.java @@ -73,7 +73,7 @@ public interface IndexCursor extends Cursor * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String,Object>> entryIterator(Object... entryValues); + public Iterator<Row> entryIterator(Object... entryValues); /** * Returns a modifiable Iterator which will iterate through all the rows of @@ -82,7 +82,7 @@ public interface IndexCursor extends Cursor * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterator<Map<String,Object>> entryIterator( + public Iterator<Row> entryIterator( Collection<String> columnNames, Object... entryValues); /** @@ -91,7 +91,7 @@ public interface IndexCursor extends Cursor * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String,Object>> entryIterable(Object... entryValues); + public Iterable<Row> entryIterable(Object... entryValues); /** * Returns an Iterable whose iterator() method returns the result of a call @@ -99,7 +99,7 @@ public interface IndexCursor extends Cursor * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String,Object>> entryIterable( + public Iterable<Row> entryIterable( Collection<String> columnNames, Object... entryValues); } diff --git a/src/java/com/healthmarketscience/jackcess/Row.java b/src/java/com/healthmarketscience/jackcess/Row.java new file mode 100644 index 0000000..1c5f985 --- /dev/null +++ b/src/java/com/healthmarketscience/jackcess/Row.java @@ -0,0 +1,32 @@ +/* +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 +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 +*/ + +package com.healthmarketscience.jackcess; + +import java.util.Map; + +/** + * A row of data as column->value pairs. + * + * @author James Ahlborn + */ +public interface Row extends Map<String,Object> +{ + +} diff --git a/src/java/com/healthmarketscience/jackcess/Table.java b/src/java/com/healthmarketscience/jackcess/Table.java index d398972..20d9e4f 100644 --- a/src/java/com/healthmarketscience/jackcess/Table.java +++ b/src/java/com/healthmarketscience/jackcess/Table.java @@ -33,7 +33,7 @@ import com.healthmarketscience.jackcess.util.ErrorHandler; * @author James Ahlborn * @usage _general_class_ */ -public interface Table extends Iterable<Map<String, Object>> +public interface Table extends Iterable<Row> { /** * enum which controls the ordering of the columns in a table. @@ -201,7 +201,7 @@ public interface Table extends Iterable<Map<String, Object>> * the default cursor) * @usage _general_method_ */ - public Map<String, Object> getNextRow() throws IOException; + public Row getNextRow() throws IOException; /** * @return a simple Cursor, initialized on demand and held by this table. diff --git a/src/java/com/healthmarketscience/jackcess/complex/AttachmentColumnInfo.java b/src/java/com/healthmarketscience/jackcess/complex/AttachmentColumnInfo.java index 541c6d8..0a07e9d 100644 --- a/src/java/com/healthmarketscience/jackcess/complex/AttachmentColumnInfo.java +++ b/src/java/com/healthmarketscience/jackcess/complex/AttachmentColumnInfo.java @@ -23,9 +23,10 @@ import java.io.IOException; import java.util.Date; import java.util.Map; -import com.healthmarketscience.jackcess.impl.ByteUtil; import com.healthmarketscience.jackcess.Column; +import com.healthmarketscience.jackcess.Row; import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.impl.ByteUtil; /** @@ -131,7 +132,7 @@ public class AttachmentColumnInfo extends ComplexColumnInfo<Attachment> @Override protected AttachmentImpl toValue(ComplexValueForeignKey complexValueFk, - Map<String,Object> rawValue) { + Row rawValue) { int id = (Integer)getPrimaryKeyColumn().getRowValue(rawValue); String url = (String)getFileUrlColumn().getRowValue(rawValue); String name = (String)getFileNameColumn().getRowValue(rawValue); diff --git a/src/java/com/healthmarketscience/jackcess/complex/ComplexColumnInfo.java b/src/java/com/healthmarketscience/jackcess/complex/ComplexColumnInfo.java index 05bd308..376c25a 100644 --- a/src/java/com/healthmarketscience/jackcess/complex/ComplexColumnInfo.java +++ b/src/java/com/healthmarketscience/jackcess/complex/ComplexColumnInfo.java @@ -33,6 +33,7 @@ import com.healthmarketscience.jackcess.DataType; import com.healthmarketscience.jackcess.Database; import com.healthmarketscience.jackcess.IndexCursor; import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.Row; /** * Base class for the additional information tracked for complex columns. @@ -120,13 +121,13 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> .size(); } - public List<Map<String,Object>> getRawValues(int complexValueFk) + public List<Row> getRawValues(int complexValueFk) throws IOException { return getRawValues(complexValueFk, null); } - private Iterator<Map<String,Object>> getComplexValFkIter( + private Iterator<Row> getComplexValFkIter( int complexValueFk, Collection<String> columnNames) throws IOException { @@ -139,17 +140,17 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> return _complexValIdCursor.entryIterator(columnNames, complexValueFk); } - public List<Map<String,Object>> getRawValues(int complexValueFk, - Collection<String> columnNames) + public List<Row> getRawValues(int complexValueFk, + Collection<String> columnNames) throws IOException { - Iterator<Map<String,Object>> entryIter = + Iterator<Row> entryIter = getComplexValFkIter(complexValueFk, columnNames); if(!entryIter.hasNext()) { return Collections.emptyList(); } - List<Map<String,Object>> values = new ArrayList<Map<String,Object>>(); + List<Row> values = new ArrayList<Row>(); while(entryIter.hasNext()) { values.add(entryIter.next()); } @@ -160,7 +161,7 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> public List<V> getValues(ComplexValueForeignKey complexValueFk) throws IOException { - List<Map<String,Object>> rawValues = getRawValues(complexValueFk.get()); + List<Row> rawValues = getRawValues(complexValueFk.get()); if(rawValues.isEmpty()) { return Collections.emptyList(); } @@ -169,18 +170,18 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> } protected List<V> toValues(ComplexValueForeignKey complexValueFk, - List<Map<String,Object>> rawValues) + List<Row> rawValues) throws IOException { List<V> values = new ArrayList<V>(); - for(Map<String,Object> rawValue : rawValues) { + for(Row rawValue : rawValues) { values.add(toValue(complexValueFk, rawValue)); } return values; } - public int addRawValue(Map<String,Object> rawValue) throws IOException { + public int addRawValue(Row rawValue) throws IOException { Object[] row = _flatTable.asRow(rawValue); _flatTable.addRow(row); return (Integer)_pkCol.getRowValue(row); @@ -200,7 +201,7 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> } } - public int updateRawValue(Map<String,Object> rawValue) throws IOException { + public int updateRawValue(Row rawValue) throws IOException { Integer id = (Integer)_pkCol.getRowValue(rawValue); updateRow(id, _flatTable.asUpdateRow(rawValue)); return id; @@ -218,7 +219,7 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> } } - public void deleteRawValue(Map<String,Object> rawValue) throws IOException { + public void deleteRawValue(Row rawValue) throws IOException { deleteRow((Integer)_pkCol.getRowValue(rawValue)); } @@ -233,7 +234,7 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> } public void deleteAllValues(int complexValueFk) throws IOException { - Iterator<Map<String,Object>> entryIter = + Iterator<Row> entryIter = getComplexValFkIter(complexValueFk, Collections.<String>emptySet()); try { while(entryIter.hasNext()) { @@ -325,7 +326,7 @@ public abstract class ComplexColumnInfo<V extends ComplexValue> protected abstract V toValue( ComplexValueForeignKey complexValueFk, - Map<String,Object> rawValues) + Row rawValues) throws IOException; protected static abstract class ComplexValueImpl implements ComplexValue diff --git a/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java b/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java index 80735e3..a4b4d02 100644 --- a/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java +++ b/src/java/com/healthmarketscience/jackcess/complex/ComplexValueForeignKey.java @@ -26,6 +26,7 @@ import java.util.List; import java.util.Map; import com.healthmarketscience.jackcess.Column; +import com.healthmarketscience.jackcess.Row; /** * Value which is returned for a complex column. This value corresponds to a @@ -122,8 +123,7 @@ public class ComplexValueForeignKey extends Number return getComplexInfo().countValues(get()); } - public List<Map<String,Object>> getRawValues() - throws IOException + public List<Row> getRawValues() throws IOException { return getComplexInfo().getRawValues(get()); } diff --git a/src/java/com/healthmarketscience/jackcess/complex/MultiValueColumnInfo.java b/src/java/com/healthmarketscience/jackcess/complex/MultiValueColumnInfo.java index 76f60bd..9add8c7 100644 --- a/src/java/com/healthmarketscience/jackcess/complex/MultiValueColumnInfo.java +++ b/src/java/com/healthmarketscience/jackcess/complex/MultiValueColumnInfo.java @@ -24,6 +24,7 @@ import java.util.Map; import com.healthmarketscience.jackcess.Column; import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.Row; /** * Complex column info for a column holding multiple values per row. @@ -56,7 +57,7 @@ public class MultiValueColumnInfo extends ComplexColumnInfo<SingleValue> @Override protected SingleValueImpl toValue( ComplexValueForeignKey complexValueFk, - Map<String,Object> rawValue) + Row rawValue) { int id = (Integer)getPrimaryKeyColumn().getRowValue(rawValue); Object value = getValueColumn().getRowValue(rawValue); diff --git a/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java b/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java index 03bd8b1..071da06 100644 --- a/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java +++ b/src/java/com/healthmarketscience/jackcess/complex/UnsupportedColumnInfo.java @@ -26,6 +26,8 @@ import java.util.Map; import com.healthmarketscience.jackcess.Column; import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.Row; +import com.healthmarketscience.jackcess.impl.RowImpl; /** * Complex column info for an unsupported complex type. @@ -55,7 +57,7 @@ public class UnsupportedColumnInfo extends ComplexColumnInfo<UnsupportedValue> @Override protected UnsupportedValueImpl toValue( ComplexValueForeignKey complexValueFk, - Map<String,Object> rawValue) + Row rawValue) { int id = (Integer)getPrimaryKeyColumn().getRowValue(rawValue); diff --git a/src/java/com/healthmarketscience/jackcess/complex/VersionHistoryColumnInfo.java b/src/java/com/healthmarketscience/jackcess/complex/VersionHistoryColumnInfo.java index 894e28a..e29dd38 100644 --- a/src/java/com/healthmarketscience/jackcess/complex/VersionHistoryColumnInfo.java +++ b/src/java/com/healthmarketscience/jackcess/complex/VersionHistoryColumnInfo.java @@ -26,8 +26,9 @@ import java.util.List; import java.util.Map; import com.healthmarketscience.jackcess.Column; -import com.healthmarketscience.jackcess.impl.ColumnImpl; +import com.healthmarketscience.jackcess.Row; import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.impl.ColumnImpl; /** * Complex column info for a column which tracking the version history of an @@ -114,7 +115,7 @@ public class VersionHistoryColumnInfo extends ComplexColumnInfo<Version> @Override protected List<Version> toValues(ComplexValueForeignKey complexValueFk, - List<Map<String,Object>> rawValues) + List<Row> rawValues) throws IOException { List<Version> versions = super.toValues(complexValueFk, rawValues); @@ -127,7 +128,7 @@ public class VersionHistoryColumnInfo extends ComplexColumnInfo<Version> @Override protected VersionImpl toValue(ComplexValueForeignKey complexValueFk, - Map<String,Object> rawValue) { + Row rawValue) { int id = (Integer)getPrimaryKeyColumn().getRowValue(rawValue); String value = (String)getValueColumn().getRowValue(rawValue); Date modifiedDate = (Date)getModifiedDateColumn().getRowValue(rawValue); diff --git a/src/java/com/healthmarketscience/jackcess/impl/ComplexColumnSupport.java b/src/java/com/healthmarketscience/jackcess/impl/ComplexColumnSupport.java index 76a9f8f..f427247 100644 --- a/src/java/com/healthmarketscience/jackcess/impl/ComplexColumnSupport.java +++ b/src/java/com/healthmarketscience/jackcess/impl/ComplexColumnSupport.java @@ -26,6 +26,12 @@ import java.util.List; import java.util.Map; import java.util.Set; +import com.healthmarketscience.jackcess.Column; +import com.healthmarketscience.jackcess.CursorBuilder; +import com.healthmarketscience.jackcess.DataType; +import com.healthmarketscience.jackcess.IndexCursor; +import com.healthmarketscience.jackcess.Row; +import com.healthmarketscience.jackcess.Table; import com.healthmarketscience.jackcess.complex.AttachmentColumnInfo; import com.healthmarketscience.jackcess.complex.ComplexColumnInfo; import com.healthmarketscience.jackcess.complex.ComplexValue; @@ -34,11 +40,7 @@ import com.healthmarketscience.jackcess.complex.UnsupportedColumnInfo; import com.healthmarketscience.jackcess.complex.VersionHistoryColumnInfo; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; -import com.healthmarketscience.jackcess.DataType; -import com.healthmarketscience.jackcess.Table; -import com.healthmarketscience.jackcess.IndexCursor; -import com.healthmarketscience.jackcess.CursorBuilder; -import com.healthmarketscience.jackcess.Column; + /** * Utility code for loading complex columns. @@ -77,7 +79,7 @@ public class ComplexColumnSupport "Could not find complex column info for complex column with id " + complexTypeId); } - Map<String,Object> cColRow = cursor.getCurrentRow(); + Row cColRow = cursor.getCurrentRow(); int tableId = (Integer)cColRow.get(COL_TABLE_ID); if(tableId != column.getTable().getTableDefPageNumber()) { throw new IOException( diff --git a/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java b/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java index fd5db70..7583034 100644 --- a/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java +++ b/src/java/com/healthmarketscience/jackcess/impl/CursorImpl.java @@ -42,6 +42,7 @@ import com.healthmarketscience.jackcess.Cursor; import com.healthmarketscience.jackcess.util.ErrorHandler; import com.healthmarketscience.jackcess.util.ColumnMatcher; import com.healthmarketscience.jackcess.Column; +import com.healthmarketscience.jackcess.Row; import com.healthmarketscience.jackcess.RowId; import com.healthmarketscience.jackcess.Index; import com.healthmarketscience.jackcess.util.SimpleColumnMatcher; @@ -195,7 +196,7 @@ public abstract class CursorImpl implements Cursor * @param rowPattern pattern to be used to find the row * @return the matching row or {@code null} if a match could not be found. */ - public static Map<String,Object> findRow(TableImpl table, + public static Row findRow(TableImpl table, Map<String,?> rowPattern) throws IOException { @@ -247,7 +248,7 @@ public abstract class CursorImpl implements Cursor * @param rowPattern pattern to be used to find the row * @return the matching row or {@code null} if a match could not be found. */ - public static Map<String,Object> findRow(TableImpl table, IndexImpl index, + public static Row findRow(TableImpl table, IndexImpl index, Map<String,?> rowPattern) throws IOException { @@ -410,65 +411,65 @@ public abstract class CursorImpl implements Cursor _rowState.reset(); } - public Iterable<Map<String, Object>> reverseIterable() { + public Iterable<Row> reverseIterable() { return reverseIterable(null); } - public Iterable<Map<String, Object>> reverseIterable( + public Iterable<Row> reverseIterable( final Collection<String> columnNames) { - return new Iterable<Map<String, Object>>() { - public Iterator<Map<String, Object>> iterator() { + return new Iterable<Row>() { + public Iterator<Row> iterator() { return new RowIterator(columnNames, MOVE_REVERSE); } }; } - public Iterator<Map<String, Object>> iterator() + public Iterator<Row> iterator() { return iterator(null); } - public Iterable<Map<String, Object>> iterable( + public Iterable<Row> iterable( final Collection<String> columnNames) { - return new Iterable<Map<String, Object>>() { - public Iterator<Map<String, Object>> iterator() { + return new Iterable<Row>() { + public Iterator<Row> iterator() { return CursorImpl.this.iterator(columnNames); } }; } - public Iterator<Map<String, Object>> iterator(Collection<String> columnNames) + public Iterator<Row> iterator(Collection<String> columnNames) { return new RowIterator(columnNames, MOVE_FORWARD); } - public Iterable<Map<String, Object>> columnMatchIterable( + public Iterable<Row> columnMatchIterable( Column columnPattern, Object valuePattern) { return columnMatchIterable((ColumnImpl)columnPattern, valuePattern); } - public Iterable<Map<String, Object>> columnMatchIterable( + public Iterable<Row> columnMatchIterable( ColumnImpl columnPattern, Object valuePattern) { return columnMatchIterable(null, columnPattern, valuePattern); } - public Iterator<Map<String, Object>> columnMatchIterator( + public Iterator<Row> columnMatchIterator( Column columnPattern, Object valuePattern) { return columnMatchIterator((ColumnImpl)columnPattern, valuePattern); } - public Iterator<Map<String, Object>> columnMatchIterator( + public Iterator<Row> columnMatchIterator( ColumnImpl columnPattern, Object valuePattern) { return columnMatchIterator(null, columnPattern, valuePattern); } - public Iterable<Map<String, Object>> columnMatchIterable( + public Iterable<Row> columnMatchIterable( Collection<String> columnNames, Column columnPattern, Object valuePattern) { @@ -476,19 +477,19 @@ public abstract class CursorImpl implements Cursor valuePattern); } - public Iterable<Map<String, Object>> columnMatchIterable( + public Iterable<Row> columnMatchIterable( final Collection<String> columnNames, final ColumnImpl columnPattern, final Object valuePattern) { - return new Iterable<Map<String, Object>>() { - public Iterator<Map<String, Object>> iterator() { + return new Iterable<Row>() { + public Iterator<Row> iterator() { return CursorImpl.this.columnMatchIterator( columnNames, columnPattern, valuePattern); } }; } - public Iterator<Map<String, Object>> columnMatchIterator( + public Iterator<Row> columnMatchIterator( Collection<String> columnNames, Column columnPattern, Object valuePattern) { @@ -496,38 +497,38 @@ public abstract class CursorImpl implements Cursor valuePattern); } - public Iterator<Map<String, Object>> columnMatchIterator( + public Iterator<Row> columnMatchIterator( Collection<String> columnNames, ColumnImpl columnPattern, Object valuePattern) { return new ColumnMatchIterator(columnNames, columnPattern, valuePattern); } - public Iterable<Map<String, Object>> rowMatchIterable( + public Iterable<Row> rowMatchIterable( Map<String,?> rowPattern) { return rowMatchIterable(null, rowPattern); } - public Iterator<Map<String, Object>> rowMatchIterator( + public Iterator<Row> rowMatchIterator( Map<String,?> rowPattern) { return rowMatchIterator(null, rowPattern); } - public Iterable<Map<String, Object>> rowMatchIterable( + public Iterable<Row> rowMatchIterable( final Collection<String> columnNames, final Map<String,?> rowPattern) { - return new Iterable<Map<String, Object>>() { - public Iterator<Map<String, Object>> iterator() { + return new Iterable<Row>() { + public Iterator<Row> iterator() { return CursorImpl.this.rowMatchIterator( columnNames, rowPattern); } }; } - public Iterator<Map<String, Object>> rowMatchIterator( + public Iterator<Row> rowMatchIterator( Collection<String> columnNames, Map<String,?> rowPattern) { return new RowMatchIterator(columnNames, rowPattern); @@ -541,21 +542,21 @@ public abstract class CursorImpl implements Cursor _table.updateRow(_rowState, _curPos.getRowId(), row); } - public Map<String, Object> getNextRow() throws IOException { + public Row getNextRow() throws IOException { return getNextRow(null); } - public Map<String, Object> getNextRow(Collection<String> columnNames) + public Row getNextRow(Collection<String> columnNames) throws IOException { return getAnotherRow(columnNames, MOVE_FORWARD); } - public Map<String, Object> getPreviousRow() throws IOException { + public Row getPreviousRow() throws IOException { return getPreviousRow(null); } - public Map<String, Object> getPreviousRow(Collection<String> columnNames) + public Row getPreviousRow(Collection<String> columnNames) throws IOException { return getAnotherRow(columnNames, MOVE_REVERSE); @@ -570,7 +571,7 @@ public abstract class CursorImpl implements Cursor * "next" may be backwards if moveForward is {@code false}, or * {@code null} if there is not another row in the given direction. */ - private Map<String, Object> getAnotherRow(Collection<String> columnNames, + private Row getAnotherRow(Collection<String> columnNames, boolean moveForward) throws IOException { @@ -784,7 +785,7 @@ public abstract class CursorImpl implements Cursor public boolean currentRowMatches(Map<String,?> rowPattern) throws IOException { - Map<String,Object> row = getCurrentRow(rowPattern.keySet()); + Row row = getCurrentRow(rowPattern.keySet()); if(rowPattern.size() != row.size()) { return false; @@ -872,12 +873,12 @@ public abstract class CursorImpl implements Cursor return numMovedRows; } - public Map<String, Object> getCurrentRow() throws IOException + public Row getCurrentRow() throws IOException { return getCurrentRow(null); } - public Map<String, Object> getCurrentRow(Collection<String> columnNames) + public Row getCurrentRow(Collection<String> columnNames) throws IOException { return _table.getRow(_rowState, _curPos.getRowId(), columnNames); @@ -946,7 +947,7 @@ public abstract class CursorImpl implements Cursor * Base implementation of iterator for this cursor, modifiable. */ protected abstract class BaseIterator - implements Iterator<Map<String, Object>> + implements Iterator<Row> { protected final Collection<String> _columnNames; protected Boolean _hasNext; @@ -969,12 +970,12 @@ public abstract class CursorImpl implements Cursor return _hasNext; } - public Map<String, Object> next() { + public Row next() { if(!hasNext()) { throw new NoSuchElementException(); } try { - Map<String, Object> rtn = getCurrentRow(_columnNames); + Row rtn = getCurrentRow(_columnNames); _hasNext = null; return rtn; } catch(IOException e) { diff --git a/src/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java b/src/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java index 75cd01d..2083c47 100644 --- a/src/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java +++ b/src/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java @@ -57,23 +57,25 @@ import java.util.Set; import java.util.TimeZone; import java.util.TreeSet; -import com.healthmarketscience.jackcess.query.Query; -import org.apache.commons.lang.builder.ToStringBuilder; -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; -import com.healthmarketscience.jackcess.Database; -import com.healthmarketscience.jackcess.util.ErrorHandler; -import com.healthmarketscience.jackcess.Table; -import com.healthmarketscience.jackcess.util.LinkResolver; import com.healthmarketscience.jackcess.ColumnBuilder; -import com.healthmarketscience.jackcess.IndexBuilder; -import com.healthmarketscience.jackcess.Relationship; -import com.healthmarketscience.jackcess.PropertyMap; import com.healthmarketscience.jackcess.Cursor; -import com.healthmarketscience.jackcess.IndexCursor; -import com.healthmarketscience.jackcess.util.CaseInsensitiveColumnMatcher; import com.healthmarketscience.jackcess.CursorBuilder; import com.healthmarketscience.jackcess.DataType; +import com.healthmarketscience.jackcess.Database; +import com.healthmarketscience.jackcess.IndexBuilder; +import com.healthmarketscience.jackcess.IndexCursor; +import com.healthmarketscience.jackcess.PropertyMap; +import com.healthmarketscience.jackcess.Relationship; +import com.healthmarketscience.jackcess.Row; +import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.query.Query; +import com.healthmarketscience.jackcess.util.CaseInsensitiveColumnMatcher; +import com.healthmarketscience.jackcess.util.ErrorHandler; +import com.healthmarketscience.jackcess.util.LinkResolver; +import org.apache.commons.lang.builder.ToStringBuilder; +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; + /** * @@ -891,7 +893,7 @@ public class DatabaseImpl implements Database } // lookup table info from system catalog - Map<String,Object> objectRow = _tableFinder.getObjectRow( + Row objectRow = _tableFinder.getObjectRow( tableDefPageNumber, SYSTEM_CATALOG_COLUMNS); if(objectRow == null) { return null; @@ -1065,10 +1067,10 @@ public class DatabaseImpl implements Database } // find all the queries from the system catalog - List<Map<String,Object>> queryInfo = new ArrayList<Map<String,Object>>(); + List<Row> queryInfo = new ArrayList<Row>(); Map<Integer,List<Query.Row>> queryRowMap = new HashMap<Integer,List<Query.Row>>(); - for(Map<String,Object> row : + for(Row row : CursorImpl.createCursor(_systemCatalog).iterable(SYSTEM_CATALOG_COLUMNS)) { String name = (String) row.get(CAT_COL_NAME); @@ -1080,7 +1082,7 @@ public class DatabaseImpl implements Database } // find all the query rows - for(Map<String,Object> row : CursorImpl.createCursor(_queries)) { + for(Row row : CursorImpl.createCursor(_queries)) { Query.Row queryRow = new Query.Row(row); List<Query.Row> queryRows = queryRowMap.get(queryRow.objectId); if(queryRows == null) { @@ -1093,7 +1095,7 @@ public class DatabaseImpl implements Database // lastly, generate all the queries List<Query> queries = new ArrayList<Query>(); - for(Map<String,Object> row : queryInfo) { + for(Row row : queryInfo) { String name = (String) row.get(CAT_COL_NAME); Integer id = (Integer)row.get(CAT_COL_ID); int flags = (Integer)row.get(CAT_COL_FLAGS); @@ -1137,7 +1139,7 @@ public class DatabaseImpl implements Database public PropertyMaps getPropertiesForObject(int objectId) throws IOException { - Map<String,Object> objectRow = _tableFinder.getObjectRow( + Row objectRow = _tableFinder.getObjectRow( objectId, SYSTEM_CATALOG_PROPS_COLUMNS); byte[] propsBytes = null; if(objectRow != null) { @@ -1161,7 +1163,7 @@ public class DatabaseImpl implements Database } } - Map<String,Object> objectRow = _tableFinder.getObjectRow( + Row objectRow = _tableFinder.getObjectRow( _dbParentId, dbName, SYSTEM_CATALOG_PROPS_COLUMNS); byte[] propsBytes = null; int objectId = -1; @@ -1226,7 +1228,7 @@ public class DatabaseImpl implements Database Cursor cursor, TableImpl fromTable, TableImpl toTable, List<Relationship> relationships) { - for(Map<String,Object> row : cursor) { + for(Row row : cursor) { String fromName = (String)row.get(REL_COL_FROM_TABLE); String toName = (String)row.get(REL_COL_TO_TABLE); @@ -1351,7 +1353,7 @@ public class DatabaseImpl implements Database Cursor cursor = createCursorWithOptionalIndex( getAccessControlEntries(), ACE_COL_OBJECT_ID, _tableParentId); - for(Map<String, Object> row : cursor) { + for(Row row : cursor) { Integer objId = (Integer)row.get(ACE_COL_OBJECT_ID); if(_tableParentId.equals(objId)) { _newTableSIDs.add((byte[])row.get(ACE_COL_SID)); @@ -1791,7 +1793,7 @@ public class DatabaseImpl implements Database return (Integer)cur.getCurrentRowValue(idCol); } - public Map<String,Object> getObjectRow(Integer parentId, String name, + public Row getObjectRow(Integer parentId, String name, Collection<String> columns) throws IOException { @@ -1799,7 +1801,7 @@ public class DatabaseImpl implements Database return ((cur != null) ? cur.getCurrentRow(columns) : null); } - public Map<String,Object> getObjectRow( + public Row getObjectRow( Integer objectId, Collection<String> columns) throws IOException { @@ -1811,7 +1813,7 @@ public class DatabaseImpl implements Database boolean systemTables) throws IOException { - for(Map<String,Object> row : getTableNamesCursor().iterable( + for(Row row : getTableNamesCursor().iterable( SYSTEM_CATALOG_TABLE_NAME_COLUMNS)) { String tableName = (String)row.get(CAT_COL_NAME); @@ -1893,7 +1895,7 @@ public class DatabaseImpl implements Database return null; } - Map<String,Object> row = _systemCatalogCursor.getCurrentRow( + Row row = _systemCatalogCursor.getCurrentRow( SYSTEM_CATALOG_COLUMNS); Integer pageNumber = (Integer)row.get(CAT_COL_ID); String realName = (String)row.get(CAT_COL_NAME); @@ -1969,7 +1971,7 @@ public class DatabaseImpl implements Database @Override public TableInfo lookupTable(String tableName) throws IOException { - for(Map<String,Object> row : _systemCatalogCursor.iterable( + for(Row row : _systemCatalogCursor.iterable( SYSTEM_CATALOG_TABLE_NAME_COLUMNS)) { Short type = (Short)row.get(CAT_COL_TYPE); diff --git a/src/java/com/healthmarketscience/jackcess/impl/FKEnforcer.java b/src/java/com/healthmarketscience/jackcess/impl/FKEnforcer.java index fcd654f..e0efe15 100644 --- a/src/java/com/healthmarketscience/jackcess/impl/FKEnforcer.java +++ b/src/java/com/healthmarketscience/jackcess/impl/FKEnforcer.java @@ -29,13 +29,14 @@ import java.util.Map; import java.util.Set; import java.util.TreeSet; -import com.healthmarketscience.jackcess.util.ColumnMatcher; -import com.healthmarketscience.jackcess.util.Joiner; -import com.healthmarketscience.jackcess.util.CaseInsensitiveColumnMatcher; -import com.healthmarketscience.jackcess.IndexCursor; -import com.healthmarketscience.jackcess.Index; import com.healthmarketscience.jackcess.Column; +import com.healthmarketscience.jackcess.Index; +import com.healthmarketscience.jackcess.IndexCursor; +import com.healthmarketscience.jackcess.Row; import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.util.CaseInsensitiveColumnMatcher; +import com.healthmarketscience.jackcess.util.ColumnMatcher; +import com.healthmarketscience.jackcess.util.Joiner; /** * Utility class used by Table to enforce foreign-key relationships (if @@ -248,7 +249,7 @@ final class FKEnforcer List<? extends Index.Column> toCols = joiner.getToIndex().getColumns(); Object[] toRow = new Object[joiner.getToTable().getColumnCount()]; - for(Iterator<Map<String,Object>> iter = joiner.findRows( + for(Iterator<Row> iter = joiner.findRows( oldFromRow, Collections.<String>emptySet()); iter.hasNext(); ) { iter.next(); diff --git a/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java b/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java index d262e2a..f6c49e3 100644 --- a/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java +++ b/src/java/com/healthmarketscience/jackcess/impl/IndexCursorImpl.java @@ -27,14 +27,15 @@ import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; -import com.healthmarketscience.jackcess.impl.TableImpl.RowState; -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; import com.healthmarketscience.jackcess.IndexCursor; -import com.healthmarketscience.jackcess.util.ColumnMatcher; +import com.healthmarketscience.jackcess.Row; import com.healthmarketscience.jackcess.RowId; +import com.healthmarketscience.jackcess.impl.TableImpl.RowState; import com.healthmarketscience.jackcess.util.CaseInsensitiveColumnMatcher; +import com.healthmarketscience.jackcess.util.ColumnMatcher; import com.healthmarketscience.jackcess.util.SimpleColumnMatcher; +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; /** * Cursor backed by an index with extended traversal options. @@ -207,27 +208,27 @@ public class IndexCursorImpl extends CursorImpl implements IndexCursor return currentRowMatchesEntryImpl(toRowValues(entryValues)); } - public Iterator<Map<String,Object>> entryIterator(Object... entryValues) + public Iterator<Row> entryIterator(Object... entryValues) { return entryIterator((Collection<String>)null, entryValues); } - public Iterator<Map<String,Object>> entryIterator( + public Iterator<Row> entryIterator( Collection<String> columnNames, Object... entryValues) { return new EntryIterator(columnNames, toRowValues(entryValues)); } - public Iterable<Map<String,Object>> entryIterable(Object... entryValues) + public Iterable<Row> entryIterable(Object... entryValues) { return entryIterable((Collection<String>)null, entryValues); } - public Iterable<Map<String,Object>> entryIterable( + public Iterable<Row> entryIterable( final Collection<String> columnNames, final Object... entryValues) { - return new Iterable<Map<String, Object>>() { - public Iterator<Map<String, Object>> iterator() { + return new Iterable<Row>() { + public Iterator<Row> iterator() { return new EntryIterator(columnNames, toRowValues(entryValues)); } }; @@ -389,7 +390,7 @@ public class IndexCursorImpl extends CursorImpl implements IndexCursor } // check the next row to see if it actually matches - Map<String,Object> row = getCurrentRow(_indexEntryPattern); + Row row = getCurrentRow(_indexEntryPattern); for(IndexData.ColumnDescriptor col : getIndex().getColumns()) { String columnName = col.getName(); diff --git a/src/java/com/healthmarketscience/jackcess/impl/RowImpl.java b/src/java/com/healthmarketscience/jackcess/impl/RowImpl.java new file mode 100644 index 0000000..9ab06a9 --- /dev/null +++ b/src/java/com/healthmarketscience/jackcess/impl/RowImpl.java @@ -0,0 +1,48 @@ +/* +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 +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 +*/ + +package com.healthmarketscience.jackcess.impl; + +import java.util.LinkedHashMap; + +import com.healthmarketscience.jackcess.Row; + +/** + * A row of data as column->value pairs. + * + * @author James Ahlborn + */ +public class RowImpl extends LinkedHashMap<String,Object> implements Row +{ + private static final long serialVersionUID = 20130314L; + + public RowImpl() + { + } + + public RowImpl(int expectedSize) + { + super(expectedSize); + } + + public RowImpl(Row row) + { + super(row); + } +} diff --git a/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java b/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java index 5d7f05d..382c755 100644 --- a/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java +++ b/src/java/com/healthmarketscience/jackcess/impl/TableImpl.java @@ -43,17 +43,18 @@ import java.util.List; import java.util.Map; import java.util.Set; -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; -import com.healthmarketscience.jackcess.Table; -import com.healthmarketscience.jackcess.util.ErrorHandler; -import com.healthmarketscience.jackcess.PropertyMap; -import com.healthmarketscience.jackcess.RowId; -import com.healthmarketscience.jackcess.DataType; -import com.healthmarketscience.jackcess.ColumnBuilder; -import com.healthmarketscience.jackcess.IndexBuilder; import com.healthmarketscience.jackcess.Column; +import com.healthmarketscience.jackcess.ColumnBuilder; +import com.healthmarketscience.jackcess.DataType; import com.healthmarketscience.jackcess.Index; +import com.healthmarketscience.jackcess.IndexBuilder; +import com.healthmarketscience.jackcess.PropertyMap; +import com.healthmarketscience.jackcess.Row; +import com.healthmarketscience.jackcess.RowId; +import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.util.ErrorHandler; +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; /** * A single database table @@ -524,7 +525,7 @@ public class TableImpl implements Table updateTableDefinition(-1); } - public Map<String, Object> getNextRow() throws IOException { + public Row getNextRow() throws IOException { return getDefaultCursor().getNextRow(); } @@ -558,7 +559,7 @@ public class TableImpl implements Table * @param columnNames Only column names in this collection will be returned * @usage _advanced_method_ */ - public Map<String, Object> getRow( + public RowImpl getRow( RowState rowState, RowIdImpl rowId, Collection<String> columnNames) throws IOException { @@ -575,16 +576,15 @@ public class TableImpl implements Table * Reads the row data from the given row buffer. Leaves limit unchanged. * Saves parsed row values to the given rowState. */ - private static Map<String, Object> getRow( - JetFormat format, + private static RowImpl getRow( + JetFormat format, RowState rowState, ByteBuffer rowBuffer, Collection<ColumnImpl> columns, Collection<String> columnNames) throws IOException { - Map<String, Object> rtn = new LinkedHashMap<String, Object>( - columns.size()); + RowImpl rtn = new RowImpl(columns.size()); for(ColumnImpl column : columns) { if((columnNames == null) || (columnNames.contains(column.getName()))) { @@ -876,7 +876,7 @@ public class TableImpl implements Table * operations, the actual exception will be contained within * @usage _general_method_ */ - public Iterator<Map<String, Object>> iterator() + public Iterator<Row> iterator() { reset(); return getDefaultCursor().iterator(); @@ -1870,7 +1870,7 @@ public class TableImpl implements Table } } rtn.append("\n"); - Map<String, Object> row; + Row row; int rowCount = 0; while ((rowCount++ < limit) && (row = getNextRow()) != null) { for(Iterator<Object> iter = row.values().iterator(); iter.hasNext(); ) { diff --git a/src/java/com/healthmarketscience/jackcess/query/Query.java b/src/java/com/healthmarketscience/jackcess/query/Query.java index 15189b3..4fb562c 100644 --- a/src/java/com/healthmarketscience/jackcess/query/Query.java +++ b/src/java/com/healthmarketscience/jackcess/query/Query.java @@ -30,7 +30,6 @@ package com.healthmarketscience.jackcess.query; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; -import java.util.Collections; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.List; @@ -39,6 +38,7 @@ import java.util.Map; import org.apache.commons.lang.builder.ToStringBuilder; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; +import com.healthmarketscience.jackcess.impl.RowImpl; import static com.healthmarketscience.jackcess.query.QueryFormat.*; @@ -54,8 +54,7 @@ public abstract class Query { protected static final Log LOG = LogFactory.getLog(Query.class); - private static final Row EMPTY_ROW = - new Row(Collections.<String,Object>emptyMap()); + private static final Row EMPTY_ROW = new Row(); public enum Type { @@ -593,7 +592,18 @@ public abstract class Query public final Integer objectId; public final byte[] order; - public Row(Map<String,Object> tableRow) { + private Row() { + this.attribute = null; + this.expression = null; + this.flag = null; + this.extra = null; + this.name1 = null; + this.name2= null; + this.objectId = null; + this.order = null; + } + + public Row(com.healthmarketscience.jackcess.Row tableRow) { this((Byte)tableRow.get(COL_ATTRIBUTE), (String)tableRow.get(COL_EXPRESSION), (Short)tableRow.get(COL_FLAG), @@ -618,9 +628,9 @@ public abstract class Query this.order = order; } - public Map<String,Object> toTableRow() + public com.healthmarketscience.jackcess.Row toTableRow() { - Map<String,Object> tableRow = new LinkedHashMap<String,Object>(); + com.healthmarketscience.jackcess.Row tableRow = new RowImpl(); tableRow.put(COL_ATTRIBUTE, attribute); tableRow.put(COL_EXPRESSION, expression); diff --git a/src/java/com/healthmarketscience/jackcess/util/ExportUtil.java b/src/java/com/healthmarketscience/jackcess/util/ExportUtil.java index 20949ba..81bf6da 100644 --- a/src/java/com/healthmarketscience/jackcess/util/ExportUtil.java +++ b/src/java/com/healthmarketscience/jackcess/util/ExportUtil.java @@ -36,13 +36,13 @@ import java.util.Collection; import java.util.HashSet; import java.util.Iterator; import java.util.List; -import java.util.Map; import java.util.regex.Pattern; import com.healthmarketscience.jackcess.Column; import com.healthmarketscience.jackcess.Cursor; import com.healthmarketscience.jackcess.CursorBuilder; import com.healthmarketscience.jackcess.Database; +import com.healthmarketscience.jackcess.Row; import com.healthmarketscience.jackcess.impl.ByteUtil; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; @@ -339,8 +339,8 @@ public class ExportUtil { } // print the data rows - Map<String, Object> row; Object[] unfilteredRowData = new Object[columns.size()]; + Row row; while ((row = cursor.getNextRow(columnNames)) != null) { // fill raw row data in array diff --git a/src/java/com/healthmarketscience/jackcess/util/Joiner.java b/src/java/com/healthmarketscience/jackcess/util/Joiner.java index 3b12c36..df11fd3 100644 --- a/src/java/com/healthmarketscience/jackcess/util/Joiner.java +++ b/src/java/com/healthmarketscience/jackcess/util/Joiner.java @@ -30,6 +30,7 @@ import com.healthmarketscience.jackcess.CursorBuilder; import com.healthmarketscience.jackcess.Index; import com.healthmarketscience.jackcess.IndexCursor; import com.healthmarketscience.jackcess.Table; +import com.healthmarketscience.jackcess.Row; import com.healthmarketscience.jackcess.impl.IndexImpl; /** @@ -147,7 +148,7 @@ public class Joiner * @param fromRow row from the "from" table (which must include the relevant * columns for this join relationship) */ - public Map<String,Object> findFirstRow(Map<String,?> fromRow) + public Row findFirstRow(Map<String,?> fromRow) throws IOException { return findFirstRow(fromRow, null); @@ -162,7 +163,7 @@ public class Joiner * columns for this join relationship) * @param columnNames desired columns in the from table row */ - public Map<String,Object> findFirstRow(Map<String,?> fromRow, + public Row findFirstRow(Map<String,?> fromRow, Collection<String> columnNames) throws IOException { @@ -176,7 +177,7 @@ public class Joiner * @param fromRow row from the "from" table (which must include the relevant * columns for this join relationship) */ - public Iterator<Map<String,Object>> findRows(Map<String,?> fromRow) + public Iterator<Row> findRows(Map<String,?> fromRow) { return findRows(fromRow, null); } @@ -189,7 +190,7 @@ public class Joiner * columns for this join relationship) * @param columnNames desired columns in the from table row */ - public Iterator<Map<String,Object>> findRows(Map<String,?> fromRow, + public Iterator<Row> findRows(Map<String,?> fromRow, Collection<String> columnNames) { toEntryValues(fromRow); @@ -205,7 +206,7 @@ public class Joiner * @param columnNames desired columns in the from table row * @usage _intermediate_method_ */ - public Iterator<Map<String,Object>> findRows(Object[] fromRow, + public Iterator<Row> findRows(Object[] fromRow, Collection<String> columnNames) { toEntryValues(fromRow); @@ -221,7 +222,7 @@ public class Joiner * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String,Object>> findRowsIterable(Map<String,?> fromRow) + public Iterable<Row> findRowsIterable(Map<String,?> fromRow) { return findRowsIterable(fromRow, null); } @@ -236,11 +237,11 @@ public class Joiner * @throws IllegalStateException if an IOException is thrown by one of the * operations, the actual exception will be contained within */ - public Iterable<Map<String,Object>> findRowsIterable( + public Iterable<Row> findRowsIterable( final Map<String,?> fromRow, final Collection<String> columnNames) { - return new Iterable<Map<String, Object>>() { - public Iterator<Map<String, Object>> iterator() { + return new Iterable<Row>() { + public Iterator<Row> iterator() { return findRows(fromRow, columnNames); } }; @@ -277,7 +278,7 @@ public class Joiner * Deletes all the rows and returns whether or not any "to"" rows were * deleted. */ - private static boolean deleteRowsImpl(Iterator<Map<String,Object>> iter) + private static boolean deleteRowsImpl(Iterator<Row> iter) throws IOException { boolean removed = false; diff --git a/src/java/com/healthmarketscience/jackcess/util/RowFilter.java b/src/java/com/healthmarketscience/jackcess/util/RowFilter.java index 5a73dd8..fd13c13 100644 --- a/src/java/com/healthmarketscience/jackcess/util/RowFilter.java +++ b/src/java/com/healthmarketscience/jackcess/util/RowFilter.java @@ -32,6 +32,7 @@ import java.util.Map; import com.healthmarketscience.jackcess.Column; import org.apache.commons.lang.ObjectUtils; +import com.healthmarketscience.jackcess.Row; /** @@ -49,7 +50,7 @@ public abstract class RowFilter * {@code false} otherwise. * @param row current row to test for inclusion in the filter */ - public abstract boolean matches(Map<String, Object> row); + public abstract boolean matches(Row row); /** * Returns an iterable which filters the given iterable based on this @@ -59,8 +60,7 @@ public abstract class RowFilter * * @return a filtering iterable */ - public Iterable<Map<String, Object>> apply( - Iterable<Map<String, Object>> iterable) + public Iterable<Row> apply(Iterable<? extends Row> iterable) { return new FilterIterable(iterable); } @@ -76,13 +76,13 @@ public abstract class RowFilter * @return a filter which matches table rows which match the values in the * row pattern */ - public static RowFilter matchPattern(final Map<String, Object> rowPattern) + public static RowFilter matchPattern(final Map<String,?> rowPattern) { return new RowFilter() { @Override - public boolean matches(Map<String, Object> row) + public boolean matches(Row row) { - for(Map.Entry<String,Object> e : rowPattern.entrySet()) { + for(Map.Entry<String,?> e : rowPattern.entrySet()) { if(!ObjectUtils.equals(e.getValue(), row.get(e.getKey()))) { return false; } @@ -107,7 +107,7 @@ public abstract class RowFilter { return new RowFilter() { @Override - public boolean matches(Map<String, Object> row) + public boolean matches(Row row) { return ObjectUtils.equals(valuePattern, columnPattern.getRowValue(row)); } @@ -127,7 +127,7 @@ public abstract class RowFilter { return new RowFilter() { @Override - public boolean matches(Map<String, Object> row) + public boolean matches(Row row) { return !filter.matches(row); } @@ -145,22 +145,23 @@ public abstract class RowFilter * @return a filtering iterable (or the given iterable if a {@code null} * filter was given) */ - public static Iterable<Map<String, Object>> apply( - RowFilter rowFilter, - Iterable<Map<String, Object>> iterable) + @SuppressWarnings("unchecked") + public static Iterable<Row> apply(RowFilter rowFilter, + Iterable<? extends Row> iterable) { - return((rowFilter != null) ? rowFilter.apply(iterable) : iterable); + return((rowFilter != null) ? rowFilter.apply(iterable) : + (Iterable<Row>)iterable); } /** * Iterable which creates a filtered view of a another row iterable. */ - private class FilterIterable implements Iterable<Map<String, Object>> + private class FilterIterable implements Iterable<Row> { - private final Iterable<Map<String, Object>> _iterable; + private final Iterable<? extends Row> _iterable; - private FilterIterable(Iterable<Map<String, Object>> iterable) + private FilterIterable(Iterable<? extends Row> iterable) { _iterable = iterable; } @@ -171,12 +172,11 @@ public abstract class RowFilter * iterable, returning only rows for which the {@link RowFilter#matches} * method returns {@code true} */ - public Iterator<Map<String, Object>> iterator() + public Iterator<Row> iterator() { - return new Iterator<Map<String, Object>>() { - private final Iterator<Map<String, Object>> _iter = - _iterable.iterator(); - private Map<String, Object> _next; + return new Iterator<Row>() { + private final Iterator<? extends Row> _iter = _iterable.iterator(); + private Row _next; public boolean hasNext() { while(_iter.hasNext()) { @@ -189,7 +189,7 @@ public abstract class RowFilter return false; } - public Map<String, Object> next() { + public Row next() { return _next; } |