KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > db4o > inside > fieldindex > FieldIndexProcessorResult


1 /* Copyright (C) 2004 - 2006 db4objects Inc. http://www.db4o.com
2
3 This file is part of the db4o open source object database.
4
5 db4o is free software; you can redistribute it and/or modify it under
6 the terms of version 2 of the GNU General Public License as published
7 by the Free Software Foundation and as clarified by db4objects' GPL
8 interpretation policy, available at
9 http://www.db4o.com/about/company/legalpolicies/gplinterpretation/
10 Alternatively you can write to db4objects, Inc., 1900 S Norfolk Street,
11 Suite 350, San Mateo, CA 94403, USA.
12
13 db4o is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License along
19 with this program; if not, write to the Free Software Foundation, Inc.,
20 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */

21 package com.db4o.inside.fieldindex;
22
23 import com.db4o.*;
24 import com.db4o.foundation.*;
25 import com.db4o.inside.btree.*;
26
27 public class FieldIndexProcessorResult {
28     
29     
30     public static final FieldIndexProcessorResult NO_INDEX_FOUND = new FieldIndexProcessorResult(null);
31
32     public static final FieldIndexProcessorResult FOUND_INDEX_BUT_NO_MATCH = new FieldIndexProcessorResult(null);
33     
34     private final IndexedNode _indexedNode;
35     
36     public FieldIndexProcessorResult(IndexedNode indexedNode) {
37         _indexedNode = indexedNode;
38     }
39     
40     public Tree toQCandidate(QCandidates candidates){
41         return TreeInt.toQCandidate(toTreeInt(), candidates);
42     }
43     
44     public TreeInt toTreeInt(){
45         if(foundMatch()){
46             return _indexedNode.toTreeInt();
47         }
48         return null;
49     }
50     
51     public boolean foundMatch(){
52         return foundIndex() && ! noMatch();
53     }
54     
55     public boolean foundIndex(){
56         return this != NO_INDEX_FOUND;
57     }
58     
59     public boolean noMatch(){
60         return this == FOUND_INDEX_BUT_NO_MATCH;
61     }
62     
63     public Iterator4 iterateIDs(){
64         return new MappingIterator(_indexedNode.iterator()) {
65             protected Object JavaDoc map(Object JavaDoc current) {
66                 FieldIndexKey composite = (FieldIndexKey)current;
67                 return new Integer JavaDoc(composite.parentID());
68             }
69         };
70     }
71     
72 }
Popular Tags