diff options
Diffstat (limited to 'src')
4 files changed, 32 insertions, 6 deletions
diff --git a/src/changes/changes.xml b/src/changes/changes.xml index 37b679b..78bf4ea 100644 --- a/src/changes/changes.xml +++ b/src/changes/changes.xml @@ -12,6 +12,15 @@ <action dev="jahlborn" type="update"> Handle input String boolean values. </action> + <action dev="jahlborn" type="add" system="SourceForge2Features" issue="28"> + Added Database.isLinkedTable method to identify if the given Table is + linked to the database. + </action> + <action dev="jahlborn" type="add" system="SourceForge2Features" issue="28"> + Added TableIterableBuilder for advanced Table iteration. This allows + selectively including different table types when iterating the tables + in a Database. + </action> </release> <release version="2.0.8" date="2014-12-26"> <action dev="jahlborn" type="fix" system="SourceForge2" issue="113"> diff --git a/src/main/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java b/src/main/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java index 414b43b..bb3bfac 100644 --- a/src/main/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java +++ b/src/main/java/com/healthmarketscience/jackcess/impl/DatabaseImpl.java @@ -620,8 +620,8 @@ public class DatabaseImpl implements Database return _tableFinder.isLinkedTable(table); } - boolean matchesLinkedTable(Table table, String linkedTableName, - String linkedDbName) { + private boolean matchesLinkedTable(Table table, String linkedTableName, + String linkedDbName) { return (table.getName().equalsIgnoreCase(linkedTableName) && (_linkedDbs != null) && (_linkedDbs.get(linkedDbName) == table.getDatabase())); diff --git a/src/main/java/com/healthmarketscience/jackcess/util/TableIterableBuilder.java b/src/main/java/com/healthmarketscience/jackcess/util/TableIterableBuilder.java index 0390ed0..9563ced 100644 --- a/src/main/java/com/healthmarketscience/jackcess/util/TableIterableBuilder.java +++ b/src/main/java/com/healthmarketscience/jackcess/util/TableIterableBuilder.java @@ -70,6 +70,25 @@ public class TableIterableBuilder implements Iterable<Table> _includeLinkedTables = includeLinkedTables; return this; } + + /** + * Convenience method to set the flags to include only non-linked (local) + * user tables. + */ + public TableIterableBuilder withLocalUserTablesOnly() { + setIncludeNormalTables(true); + setIncludeSystemTables(false); + return setIncludeLinkedTables(false); + } + + /** + * Convenience method to set the flags to include only system tables. + */ + public TableIterableBuilder withSystemTablesOnly() { + setIncludeNormalTables(false); + setIncludeSystemTables(true); + return setIncludeLinkedTables(false); + } public Iterator<Table> iterator() { return ((DatabaseImpl)_db).iterator(this); diff --git a/src/test/java/com/healthmarketscience/jackcess/DatabaseTest.java b/src/test/java/com/healthmarketscience/jackcess/DatabaseTest.java index e2751cb..e8cc98c 100644 --- a/src/test/java/com/healthmarketscience/jackcess/DatabaseTest.java +++ b/src/test/java/com/healthmarketscience/jackcess/DatabaseTest.java @@ -1463,16 +1463,14 @@ public class DatabaseTest extends TestCase assertTrue(tables.contains(t3)); assertFalse(tables.contains(((DatabaseImpl)db).getSystemCatalog())); - tables = getTables(db.newIterable().setIncludeLinkedTables(false)); + tables = getTables(db.newIterable().withLocalUserTablesOnly()); assertEquals(1, tables.size()); assertTrue(tables.contains(t1)); assertFalse(tables.contains(t2)); assertFalse(tables.contains(t3)); assertFalse(tables.contains(((DatabaseImpl)db).getSystemCatalog())); - tables = getTables(db.newIterable().setIncludeLinkedTables(false) - .setIncludeNormalTables(false) - .setIncludeSystemTables(true)); + tables = getTables(db.newIterable().withSystemTablesOnly()); assertTrue(tables.size() > 5); assertFalse(tables.contains(t1)); assertFalse(tables.contains(t2)); |