Subversion Repository Public Repository

litesoft

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

Diff revisions: vs.
Revision Author Commited Message
947 Diff Diff GeorgeS picture GeorgeS Fri 06 Jun, 2014 23:36:56 +0000

Correct Spelling of package!

151 Diff Diff GeorgeS picture GeorgeS Thu 17 Mar, 2011 04:16:22 +0000
49 Diff Diff GeorgeS picture GeorgeS Mon 12 Apr, 2010 02:59:10 +0000

License Text

24 Diff Diff GeorgeS picture GeorgeS Wed 24 Feb, 2010 01:51:38 +0000
2 GeorgeS picture GeorgeS Sun 07 Feb, 2010 12:50:58 +0000