litesoft
@ 947
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 |
// This Source Code is in the Public Domain per: http://unlicense.org package org.litesoft.orsup.nonpublic; import org.litesoft.orsup.base.*; public abstract class AbstractRowSourcePOQueryIterator<T extends PersistentObject> extends AbstractPOQueryIterator<T> { private PersistenceHelperRowSource mRowSource; private RowAcceptor mRowAcceptor = RowAcceptor.NULL; private Class mKeyFilterClass = null; private int mPrimaryKeyIndex = 0; protected AbstractRowSourcePOQueryIterator( MetaDataForPOinternalExtension pMetaDataForPO, Finder pFinder, POQueryFilter pQueryFilter, PersistenceHelperRowSource pRowSource ) { super( pMetaDataForPO, pFinder, determinePOInstanceQueryFilter( pQueryFilter ) ); mRowSource = PersistenceHelperRowSource.NULL.deNull( pRowSource ); try { if ( pQueryFilter != null ) { switch ( pQueryFilter.getType() ) { case NoneAcceptable: releasePOsource(); POQueryFilter.LOGGER.trace.log( "ALL ", getMD(), " POs filtered out by ", // pQueryFilter.getClass() ); return; case PotentialFilteringByKey: Integer zPrimaryKeyIndex = mMetaDataForPO.getPrimaryKeyPersistingAccessorSCDsIndex(); if ( zPrimaryKeyIndex != null ) { mRowAcceptor = new AbstractRowSourcePOQueryIterator.IdRowAcceptor( (POKeyQueryFilter) pQueryFilter, zPrimaryKeyIndex ); mKeyFilterClass = pQueryFilter.getClass(); mPrimaryKeyIndex = zPrimaryKeyIndex; } break; default: break; } } preFetchPO(); } catch ( RuntimeException e ) { releaseResources(); throw e; } } private static POInstanceQueryFilter determinePOInstanceQueryFilter( POQueryFilter pQueryFilter ) { if ( pQueryFilter != null ) { switch ( pQueryFilter.getType() ) { case NoneAcceptable: return POInstanceQueryFilter.NONE_ACCEPTABLE; case AllAcceptable: break; case PotentialFilteringByInstance: return (POInstanceQueryFilter) pQueryFilter; case PotentialFilteringByKey: break; default: // Note: this is an error so that resources do NOT need to be cleaned up! throw new Error( "Combo of '" + pQueryFilter.getType() + "' and " + pQueryFilter.getClass() ); } } return null; } @Override protected void preparePOsource() { mRowSource = mRowSource.prepareForGetNextRow(); } @Override protected T LLfetchPO() { for ( Object[] row; null != (row = mRowSource.getNextRow()); ) { if ( mRowAcceptor.isRowAcceptable( row ) ) { //noinspection unchecked return (T) mMetaDataForPO.createPO( mFinder, row ); } POQueryFilter.LOGGER.trace.log( getMD(), " PO w/ ID ", row[mPrimaryKeyIndex], " filtered out by ", mKeyFilterClass ); } return null; } @Override protected void releasePOsource() { mRowSource.dispose(); mRowSource = PersistenceHelperRowSource.NULL.INSTANCE; } private static class RowAcceptor { public static final RowAcceptor NULL = new RowAcceptor(); public boolean isRowAcceptable( Object[] pRow ) { return true; } } private static class IdRowAcceptor extends RowAcceptor { private POKeyQueryFilter mPOKeyQueryFilter; private int mPrimaryKeyIndex; public IdRowAcceptor( POKeyQueryFilter pPOKeyQueryFilter, int pPrimaryKeyIndex ) { mPOKeyQueryFilter = pPOKeyQueryFilter; mPrimaryKeyIndex = pPrimaryKeyIndex; } @Override public boolean isRowAcceptable( Object[] pRow ) { return mPOKeyQueryFilter.isPO_KeyAcceptable( pRow[mPrimaryKeyIndex] ); } } } |
Commits for litesoft/trunk/Java/core/Server/src/org/litesoft/orsup/nonpublic/AbstractRowSourcePOQueryIterator.java
Revision | Author | Commited | Message |
---|---|---|---|
947 Diff | GeorgeS | Fri 06 Jun, 2014 23:36:56 +0000 | Correct Spelling of package! |
151 Diff | GeorgeS | Thu 17 Mar, 2011 04:16:22 +0000 | |
49 Diff | GeorgeS | Mon 12 Apr, 2010 02:59:10 +0000 | License Text |
24 Diff | GeorgeS | Wed 24 Feb, 2010 01:51:38 +0000 | |
2 | GeorgeS | Sun 07 Feb, 2010 12:50:58 +0000 |