X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;ds=inline;f=source%2Fmir%2Fentity%2FEntityBrowser.java;h=77bc5593e04cba0d2c6a240b825d46c7efc4f20e;hb=8b91e8d8bf4a31a88440a404e83238dcf32f8f4a;hp=8ce7a6e2a455016e6d05ad3bff5c014659e96f96;hpb=55d545036aa5c04676f2d20f0e98316a4679ec27;p=mir.git diff --git a/source/mir/entity/EntityBrowser.java b/source/mir/entity/EntityBrowser.java index 8ce7a6e2..77bc5593 100755 --- a/source/mir/entity/EntityBrowser.java +++ b/source/mir/entity/EntityBrowser.java @@ -1,5 +1,5 @@ /* - * Copyright (C) 2001, 2002 The Mir-coders group + * Copyright (C) 2001, 2002 The Mir-coders group * * This file is part of Mir. * @@ -18,19 +18,20 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * In addition, as a special exception, The Mir-coders gives permission to link - * the code of this program with the com.oreilly.servlet library, any library - * licensed under the Apache Software License, The Sun (tm) Java Advanced - * Imaging library (JAI), The Sun JIMI library (or with modified versions of - * the above that use the same license as the above), and distribute linked - * combinations including the two. You must obey the GNU General Public - * License in all respects for all of the code used other than the above - * mentioned libraries. If you modify this file, you may extend this exception - * to your version of the file, but you are not obligated to do so. If you do - * not wish to do so, delete this exception statement from your version. + * the code of this program with any library licensed under the Apache Software License, + * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library + * (or with modified versions of the above that use the same license as the above), + * and distribute linked combinations including the two. You must obey the + * GNU General Public License in all respects for all of the code used other than + * the above mentioned libraries. If you modify this file, you may extend this + * exception to your version of the file, but you are not obligated to do so. + * If you do not wish to do so, delete this exception statement from your version. */ package mir.entity; +import java.util.List; + import mir.storage.StorageObject; import mir.storage.StorageObjectFailure; import mir.util.RewindableIterator; @@ -38,10 +39,11 @@ import mir.util.RewindableIterator; public class EntityBrowser implements RewindableIterator { private StorageObject storage; + private String mainTablePrefix; + private List extraTables; private String whereClause; private String orderByClause; private int batchSize; - private int toFetch; private EntityList currentBatch; private int skip; @@ -50,10 +52,13 @@ public class EntityBrowser implements RewindableIterator { private int batchPosition; private int positionInBatch; - public EntityBrowser(StorageObject aStorage, String aWhereClause, String anOrderByClause, - int aBatchSize, int aLimit, int aSkip) throws StorageObjectFailure { + public EntityBrowser(StorageObject aStorage, String aMainTablePrefix, List someExtraTables, + String aWhereClause, String anOrderByClause, + int aBatchSize, int aLimit, int aSkip) throws StorageObjectFailure { storage=aStorage; + mainTablePrefix=aMainTablePrefix; + extraTables=someExtraTables; whereClause=aWhereClause; orderByClause=anOrderByClause; batchSize=aBatchSize; @@ -63,6 +68,11 @@ public class EntityBrowser implements RewindableIterator { rewind(); } + public EntityBrowser(StorageObject aStorage, String aWhereClause, String anOrderByClause, + int aBatchSize, int aLimit, int aSkip) throws StorageObjectFailure { + this(aStorage, "", null, aWhereClause, anOrderByClause, aBatchSize, aLimit, aSkip); + } + public EntityBrowser(StorageObject aStorage, String aWhereClause, String anOrderByClause, int aBatchSize) throws StorageObjectFailure { @@ -70,7 +80,7 @@ public class EntityBrowser implements RewindableIterator { } public void readCurrentBatch(int aSkip) throws StorageObjectFailure { - currentBatch = storage.selectByWhereClause(whereClause, orderByClause, aSkip, batchSize); + currentBatch = storage.selectByWhereClause(mainTablePrefix, extraTables, whereClause, orderByClause, aSkip, batchSize); batchPosition = aSkip; positionInBatch = 0; }