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
package org.litesoft.core.util;

import java.util.*;

// Copyright Status:
//
// All Software available from LiteSoft.org (including this file) is
// hereby released into the public domain.
//
// It is free!  As in, you may use it freely in both commercial and
// non-commercial applications, bundle it with your software
// distribution, include it on a CD-ROM, list the source code in a book,
// mirror the documentation at your own web site, or use it in any other
// way you see fit.
//
// NO Warranty!
//
// All software is provided "as is".
//
// There is ABSOLUTELY NO WARRANTY OF ANY KIND: not for the design, fitness
// (for a particular purpose), level of errors (or lack thereof), or
// applicability of this software.  The entire risk as to the quality
// and performance of this software is with you.  Should this software
// prove defective, you assume the cost of all necessary servicing, repair
// or correction.
//
// In no event unless required by applicable law or agreed to in writing
// will any party who created or may modify and/or redistribute this
// software, be liable to you for damages, including any general,
// special, incidental or consequential damages arising out of the use or
// inability to use this software (including but not limited to loss of
// data or data being rendered inaccurate or losses sustained by you or
// third parties or a failure of this software to operate with any
// other programs), even if such holder or other party has been advised
// of the possibility of such damages.
//
// NOTE: Should you discover a bug, have a recogmendation for a change, wish
// to submit modifications, or wish to add new classes/functionality,
// please email them to:
//
//        changes@litesoft.org
//

/**
 * This class's purpose is to be extended by a concrete Filtering Iterator
 * that is wrapping/decorating another Iterator.  The Filtering works
 * by looking ahead for an entry that is acceptable.  This acceptablity
 * is determined by the <i>keepThis</i> method.<p>
 *
 * @author George Smith
 * @version 1.0 7/28/01
 * @see <a href="http://java.sun.com/j2se/1.3/docs/api/java/lang/Util/Iterator.html">java.util.Iterator</a>
 */

public abstract class AbstractFilteringIterator<T> extends AbstractWrappingIterator<T>
{
    /**
     * Construct a Filtering (of another Iterator) Iterator.<p>
     *
     * @param pIterator Iterator to be <i>Filtered</i> (!null).<p>
     *
     * @see AbstractWrappingIterator
     * @see <a href="http://java.sun.com/j2se/1.3/docs/api/java/lang/Util/Iterator.html">java.util.Iterator</a>
     */
    protected AbstractFilteringIterator( Iterator<T> pIterator )
            throws NullPointerException
    {
        super( pIterator );
    }

    private T lookAheadObject = null;
    private boolean lookAheadValid = false;

    /**
     * This method is the <i>heart</i> of a Filtering Iterator.
     * It determines if an Object from the underlying Iterator
     * is to be kept or tossed.<p>
     * <p/>
     * It is abstract here because there is no reasonable, common,
     * implementation and to remind the developer who extends
     * this class that they need to implement it.<p>
     *
     * @param pPossibleValue Object reference to test for keeping (not tossing).<p>
     *
     * @return <tt>true</tt> if the <i>pPossibleValue</i> should be kept (not tossed).
     */
    abstract protected boolean keepThis( T pPossibleValue );

    /**
     * Returns true if the iteration has more elements.<p>
     * <p/>
     * This method relies on a look-ahead buffer and keepThis() to
     * implement the filtering.<p>
     *
     * @see <a href="http://java.sun.com/j2se/1.3/docs/api/java/lang/Util/Iterator.html#hasNext()">java.util.Iterator#hasNext()</a>
     * @see #keepThis(Object)
     */
    public final boolean hasNext()
    {
        while ( !lookAheadValid && super.hasNext() )
        {
            lookAheadValid = keepThis( lookAheadObject = super.next() );
        }

        return lookAheadValid;
    }

    /**
     * Returns the next element in the interation.
     * <p/>
     * This method relies on hasNext (and a look-ahead buffer) to
     * implement the filtering.<p>
     *
     * @see <a href="http://java.sun.com/j2se/1.3/docs/api/java/lang/Util/Iterator.html#next()">java.util.Iterator#next()</a>
     * @see #next()
     */
    public final T next()
    {
        if ( !hasNext() )
        {
            super.next(); // throw exception
        }

        lookAheadValid = false;
        return lookAheadObject;
    }
}

Commits for litesoft/trunk/Java/core/Anywhere/src/org/litesoft/core/util/AbstractFilteringIterator.java

Diff revisions: vs.
Revision Author Commited Message
2 GeorgeS picture GeorgeS Sun 07 Feb, 2010 12:50:58 +0000